我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Android高仿IOS 滚轮选择控件

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Android高仿IOS 滚轮选择控件

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

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

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


public class Util {
 
 public interface TimerPickerCallBack {
  void onTimeSelect(String date);
 }
 
 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);
 }
 
 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 中找到设置显示内容的方法:



 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 滚轮选择控件的实例(源码下载)Android仿ios年龄、生日、性别滚轮效果


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Android高仿IOS 滚轮选择控件

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Android高仿IOS 滚轮选择控件

最近根据项目需要,整理了一个相对比较全面的 WheelView 使用控件,借用之前看到的一句话来说,就是站在巨人肩膀上,进行了一些小调整。 这里先贴上效果图一般常用的时间选择格式,,单项选择,以及城市联动,这里基本都可以满足了。 这里把
2022-06-06

Android 实现IOS 滚轮选择控件的实例(源码下载)

Android 实现IOS 滚轮选择控件的实例 最近根据项目需要,整理了一个相对比较全面的 WheelView 使用控件,借用之前看到的一句话来说,就是站在巨人肩膀上,进行了一些小调整。 这里先贴上效果图一般常用的时间选择格式,,单项选择
2022-06-06

怎么在Android应用中实现一个IOS 滚轮选择控件

今天就跟大家聊聊有关怎么在Android应用中实现一个IOS 滚轮选择控件,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。代码如下:public class Util { /**
2023-05-31

Android滚轮选择时间控件使用详解

滚轮选择控件 Android自带的选择时间控件有点丑,往往产品和设计都比较嫌弃,希望做成ios一样的滚轮选择,下面是我在NumberPicker的基础上自定义的选择控件,效果如下: 原理基于NumberPicker实现动态填充数值联动接口监
2022-06-06

iOS自定义时间滚动选择控件

本文实例为大家分享了iOS自定义时间滚动选择控件的具体代码,供大家参考,具体内容如下 1.先上自定义的控件: public class WheelVi
2022-05-19

轻松实现可扩展自定义的Android滚轮时间选择控件

项目需求中有个功能模块需要用到时间选择控件,但是android系统自带的太丑了,只能自己优化下,结合WheelView实现滚轮选择日期,好像网上也挺多这种文章的。但是适用范围还是不同,希望这个能够对需求相同的朋友有一定帮助。控件标题还有年月
2022-06-06

Android自定义view实现滚动选择控件详解

最近在开发中需要实现滚动进行类别的选择,也就是我们所说的滚动选择器,这里我们自定义来实现这个功能,这篇文章主要介绍了Android自定义view实现滚动选择控件
2022-11-13

编程热搜

  • Android:VolumeShaper
    VolumeShaper(支持版本改一下,minsdkversion:26,android8.0(api26)进一步学习对声音的编辑,可以让音频的声音有变化的播放 VolumeShaper.Configuration的三个参数 durati
    Android:VolumeShaper
  • Android崩溃异常捕获方法
    开发中最让人头疼的是应用突然爆炸,然后跳回到桌面。而且我们常常不知道这种状况会何时出现,在应用调试阶段还好,还可以通过调试工具的日志查看错误出现在哪里。但平时使用的时候给你闹崩溃,那你就欲哭无泪了。 那么今天主要讲一下如何去捕捉系统出现的U
    Android崩溃异常捕获方法
  • android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
    系统的设置–>电池–>使用情况中,统计的能耗的使用情况也是以power_profile.xml的value作为基础参数的1、我的手机中power_profile.xml的内容: HTC t328w代码如下:
    android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
  • Android SQLite数据库基本操作方法
    程序的最主要的功能在于对数据进行操作,通过对数据进行操作来实现某个功能。而数据库就是很重要的一个方面的,Android中内置了小巧轻便,功能却很强的一个数据库–SQLite数据库。那么就来看一下在Android程序中怎么去操作SQLite数
    Android SQLite数据库基本操作方法
  • ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
    工作的时候为了方便直接打开编辑文件,一些常用的软件或者文件我们会放在桌面,但是在ubuntu20.04下直接直接拖拽文件到桌面根本没有效果,在进入桌面后发现软件列表中的软件只能收藏到面板,无法复制到桌面使用,不知道为什么会这样,似乎并不是很
    ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
  • android获取当前手机号示例程序
    代码如下: public String getLocalNumber() { TelephonyManager tManager =
    android获取当前手机号示例程序
  • Android音视频开发(三)TextureView
    简介 TextureView与SurfaceView类似,可用于显示视频或OpenGL场景。 与SurfaceView的区别 SurfaceView不能使用变换和缩放等操作,不能叠加(Overlay)两个SurfaceView。 Textu
    Android音视频开发(三)TextureView
  • android获取屏幕高度和宽度的实现方法
    本文实例讲述了android获取屏幕高度和宽度的实现方法。分享给大家供大家参考。具体分析如下: 我们需要获取Android手机或Pad的屏幕的物理尺寸,以便于界面的设计或是其他功能的实现。下面就介绍讲一讲如何获取屏幕的物理尺寸 下面的代码即
    android获取屏幕高度和宽度的实现方法
  • Android自定义popupwindow实例代码
    先来看看效果图:一、布局
  • Android第一次实验
    一、实验原理 1.1实验目标 编程实现用户名与密码的存储与调用。 1.2实验要求 设计用户登录界面、登录成功界面、用户注册界面,用户注册时,将其用户名、密码保存到SharedPreference中,登录时输入用户名、密码,读取SharedP
    Android第一次实验

目录