Android * IOS 滚轮选择控件

作者:lv_fq 时间:2023-07-13 10:51:24 

最近根据项目需要,整理了一个相对比较全面的 WheelView 使用控件,借用之前看到的一句话来说,就是站在巨人肩膀上,进行了一些小调整。
这里先贴上效果图

Android * IOS 滚轮选择控件

一般常用的时间选择格式,,单项选择,以及城市联动,这里基本都可以满足了。

这里把 单项选择,和 日期时间选择 给提出到 Util 类中,代码如下:


public class Util {

/**
 * 时间选择回调
 */
public interface TimerPickerCallBack {
 void onTimeSelect(String date);
}

/**
 * 弹出时间选择
 *
 * @param context
 * @param type  TimerPickerView 中定义的 选择时间类型
 * @param format 时间格式化
 * @param callBack 时间选择回调
 */
public static void alertTimerPicker(Context context, TimePickerView.Type type, final String format, final TimerPickerCallBack callBack) {
 TimePickerView pvTime = new TimePickerView(context, type);
 //控制时间范围
 //  Calendar calendar = Calendar.getInstance();
 //  pvTime.setRange(calendar.get(Calendar.YEAR) - 20, calendar.get(Calendar.YEAR));
 pvTime.setTime(new Date());
 pvTime.setCyclic(false);
 pvTime.setCancelable(true);
 //时间选择后回调
 pvTime.setOnTimeSelectListener(new TimePickerView.OnTimeSelectListener() {

@Override
  public void onTimeSelect(Date date) {
//      tvTime.setText(getTime(date));
   SimpleDateFormat sdf = new SimpleDateFormat(format);
   callBack.onTimeSelect(sdf.format(date));
  }
 });
 pvTime.setTextSize(16);
 //弹出时间选择器
 pvTime.show();
}

/**
 * 底部滚轮点击事件回调
 */
public interface OnWheelViewClick {
 void onClick(View view, int postion);
}

/**
 * 弹出底部滚轮选择
 *
 * @param context
 * @param list
 * @param click
 */
public static void alertBottomWheelOption(Context context, ArrayList<?> list, final OnWheelViewClick click) {

final PopupWindow popupWindow = new PopupWindow();

View view = LayoutInflater.from(context).inflate(R.layout.layout_bottom_wheel_option, null);
 TextView tv_confirm = (TextView) view.findViewById(R.id.btnSubmit);
 final WheelView wv_option = (WheelView) view.findViewById(R.id.wv_option);
 wv_option.setAdapter(new ArrayWheelAdapter(list));
 wv_option.setCyclic(false);
 wv_option.setTextSize(16);
 tv_confirm.setOnClickListener(new View.OnClickListener() {
  @Override
  public void onClick(View view) {
   popupWindow.dismiss();
   click.onClick(view, wv_option.getCurrentItem());
  }
 });

view.findViewById(R.id.btnCancel).setOnClickListener(new View.OnClickListener() {
  @Override
  public void onClick(View view) {
   // TODO: 2016/8/11 0011 取消
   popupWindow.dismiss();
  }
 });
 view.setOnTouchListener(new View.OnTouchListener() {
  @Override
  public boolean onTouch(View view, MotionEvent motionEvent) {
   int top = view.findViewById(R.id.ll_container).getTop();
   if (motionEvent.getAction() == MotionEvent.ACTION_UP) {
    int y = (int) motionEvent.getY();
    if (y < top) {
     popupWindow.dismiss();
    }
   }
   return true;
  }
 });
 popupWindow.setContentView(view);
 popupWindow.setOutsideTouchable(true);
 popupWindow.setFocusable(true);
 popupWindow.setBackgroundDrawable(new BitmapDrawable());
 popupWindow.setWidth(ViewGroup.LayoutParams.MATCH_PARENT);
 popupWindow.setHeight(ViewGroup.LayoutParams.MATCH_PARENT);
 popupWindow.showAtLocation(((ViewGroup) ((Activity) context).findViewById(android.R.id.content)).getChildAt(0), Gravity.CENTER, 0, 0);
}
}

 •单项选择

这里是模拟传入 ArrayList 形式的 String 类型 :


// 单项选择
 for (int i = 0; i <= 10; i++) {
  mList.add("模拟数据" + i);
 }

tv_single_option.setOnClickListener(new View.OnClickListener() {
  @Override
  public void onClick(View v) {
   Util.alertBottomWheelOption(MainActivity.this, mList, new Util.OnWheelViewClick() {
    @Override
    public void onClick(View view, int postion) {
     Toast.makeText(MainActivity.this, mList.get(postion), Toast.LENGTH_SHORT).show();
    }
   });
  }
 });

补充:我们实际项目中用法可能是传入一个实体对象,那么我们到 WheelView 中找到设置显示内容的方法:


/**
 * 根据传进来的对象反射出getPickerViewText()方法,来获取需要显示的值
 * @param item
 * @return
 */
private String getContentText(Object item) {
 String contentText = item.toString();
 try {
  Class<?> clz = item.getClass();
  Method m = clz.getMethod(GETPICKERVIEWTEXT);
  contentText = m.invoke(item, new Object[0]).toString();
 } catch (NoSuchMethodException e) {
 } catch (InvocationTargetException e) {
 } catch (IllegalAccessException e) {
 } catch (Exception e){
 }
 return contentText;
}

根据以上代码,可以看到如果是一个实体对象,那么就是通过对象内部定义的一个方法名为 GETPICKERVIEWTEXT(静态常量=”getPickerViewText”)的返回值来作为显示内容,

所以在创建对象的时候,要注意在对象内部添加一个 getPickerViewText()方法,代码如下:


public class TypeBean {

private int id;
private String name;

public TypeBean(int id, String name) {
 this.id = id;
 this.name = name;
}

public int getId() {
 return id;
}

public void setId(int id) {
 this.id = id;
}

public String getName() {
 return name;
}

public void setName(String name) {
 this.name = name;
}

//这个用来显示在PickerView上面的字符串,PickerView会通过反射获取getPickerViewText方法显示出来。
public String getPickerViewText() {
 //这里还可以判断文字超长截断再提供显示
 return name;
}
}

 •日期选择
这里是传入 选择日期类型,和 回调时间格式 就能直接得到想要的结果,


@Override
public void onClick(View v) {
 String format = "";
 TimePickerView.Type type = null;
 switch (v.getId()) {
  case R.id.btn_ymdhm:
   type = TimePickerView.Type.ALL;
   format = "yyyy-MM-dd HH:mm";
   break;
  case R.id.btn_ymdh:
   type = TimePickerView.Type.YEAR_MONTH_DAY_HOUR;
   format = "yyyy-MM-dd HH";
   break;
  case R.id.btn_ymd:
   type = TimePickerView.Type.YEAR_MONTH_DAY;
   format = "yyyy-MM-dd";
   break;
  case R.id.btn_mdhm:
   type = TimePickerView.Type.MONTH_DAY_HOUR_MIN;
   format = "MM-dd HH:mm";
   break;
  case R.id.btn_hm:
   type = TimePickerView.Type.HOURS_MINS;
   format = "HH:mm";
   break;
  case R.id.btn_ym:
   type = TimePickerView.Type.YEAR_MONTH;
   format = "yyyy-MM";
   break;
 }
 Util.alertTimerPicker(this, type, format, new Util.TimerPickerCallBack() {
  @Override
  public void onTimeSelect(String date) {
   Toast.makeText(TestActivity.this, date, Toast.LENGTH_SHORT).show();
  }
 });

}

 •条件选择 


private ArrayList<ProvinceBean> options1Items = new ArrayList<ProvinceBean>();
private ArrayList<ArrayList<String>> options2Items = new ArrayList<ArrayList<String>>();
private ArrayList<ArrayList<ArrayList<String>>> options3Items = new ArrayList<ArrayList<ArrayList<String>>>();

OptionsPickerView pvOptions;

private void showOptions(){
 //选项选择器
 pvOptions = new OptionsPickerView(this);
 // 初始化三个列表数据
 DataModel.initData(options1Items, options2Items, options3Items);

// * 联动效果
 pvOptions.setPicker(options1Items, options2Items, options3Items, true);
 //设置选择的 * 单位
//  pwOptions.setLabels("省", "市", "区");
 pvOptions.setTitle("选择城市");
 pvOptions.setCyclic(false, false, false);
 //设置默认选中的 * 项目
 //监听确定选择按钮
 pvOptions.setSelectOptions(1, 1, 1);
 pvOptions.setTextSize(18);
 pvOptions.setOnoptionsSelectListener(new OptionsPickerView.OnOptionsSelectListener() {

@Override
  public void onOptionsSelect(int options1, int option2, int options3) {
   //返回的分别是三个级别的选中位置
   String tx = options1Items.get(options1).getPickerViewText()
     + options2Items.get(options1).get(option2)
     + options3Items.get(options1).get(option2).get(options3);
   tvOptions.setText(tx);
   vMasker.setVisibility(View.GONE);
  }
 });
 //点击弹出选项选择器
 tvOptions.setOnClickListener(new View.OnClickListener() {

@Override
  public void onClick(View v) {
   pvOptions.show();
  }
 });
}

基本使用就这些了,也没什么技术含量,只是作为常用工具整理,也希望能给大家带来方便。

点击下载:源码

标签:Android,IOS,滚轮,选择
0
投稿

猜你喜欢

  • Java编程实现帕斯卡三角形代码示例

    2023-11-02 08:08:24
  • springboot之如何获取项目目录路径

    2022-08-09 21:44:17
  • java实现文件下载的两种方式

    2023-11-11 06:37:14
  • Matlab实现贪吃蛇小游戏的示例代码

    2023-07-14 14:13:00
  • spring mvc高级技术实例详解

    2022-10-11 12:50:15
  • java集合Collection实现类解析ArrayList LinkedList及Vector

    2022-05-01 05:44:12
  • @TransactionalEventListener的使用和实现原理分析

    2022-01-19 06:15:11
  • spring boot实战之本地jar包引用示例

    2021-11-01 20:44:45
  • Kotlin基础教程之面向对象

    2023-06-21 19:54:36
  • SpringBoot上传文件到本服务器 目录与jar包同级问题

    2022-01-27 07:15:41
  • Java内存模型final的内存语义

    2023-06-05 08:02:25
  • 初识Spring Boot框架之Spring Boot的自动配置

    2022-08-25 10:27:57
  • intellij idea使用git stash暂存一次提交的操作

    2023-03-08 08:30:11
  • C# 从枚举值获取对应的文本描述详解

    2021-06-14 00:47:58
  • Spring Mvc中传递参数方法之url/requestMapping详解

    2021-11-03 05:48:46
  • C# TreeView无限目录树实现方法

    2023-04-20 03:05:46
  • Winform控件优化Paint事件实现圆角组件及提取绘制圆角的方法

    2022-04-04 15:41:13
  • ActiveMQ结合Spring收发消息的示例代码

    2023-11-24 06:01:12
  • Java实现人脸识别登录、注册等功能(最新完整版)

    2022-09-25 00:20:13
  • MybatisPlus中@TableField注解的使用详解

    2021-11-01 23:05:35
  • asp之家 软件编程 m.aspxhome.com