热门标签 | HotTags
当前位置:  开发笔记 > 前端 > 正文

WheelView实现上下滑动选择器

这篇文章主要为大家详细介绍了WheelView实现上下滑动选择器的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了WheelView实现上下滑动选择器的具体代码,供大家参考,具体内容如下

1.获得wheel

wheel是GitHub上的一个开源控件,我们可以直接在GitHub上下载,地址https://github.com/maarek/android-wheel,下载完成之后我们可以把里边的wheel文件直接当作一个library来使用,也可以把wheel里边的Java类和xml文件拷贝到我们的项目中使用。

2.使用方法

首先我们来看看主布局文件:

 
 
   
 
   
 
     
     
 
     
     
 
     
     
   
 
  

好了,在主布局文件中我们用到了三个WheelView,分别用来表示省市县,在MainActivity中,我们首先要拿到这三个控件:

provinceView = (WheelView) this.findViewById(R.id.province_view); 
    cityView = (WheelView) this.findViewById(R.id.city_view); 
    areaView = (WheelView) this.findViewById(R.id.area_view); 

拿到之后,我们要使用ArrayWheelAdapter数据适配器来进行数据适配,这里需要两个参数,一个是上下文,另外一个是一个数组,这个数组就是我们要展示的内容,也就是说我们要把省、市、区县都存为数组的形式,但是考虑到一个省对应多个市,一个市对应多个区县,为了把省市县之间关联起来,我们还要用到一个Map集合,因此,我们设计的数据结构是这样的:

/** 
   * 省 
   */ 
  private String[] provinceArray; 
  /** 
   * 省-市 
   */ 
  private Map citiesMap; 
  /** 
   * 市-区县 
   */ 
  private Map areasMap; 

第一个数组中存所有省的数据,第二个Map中存所有省对应的市的数据,第三个Map中存所有市对应的区县的数据,我们现在要给这是三个数据集赋值,先来看看我们的json数据格式:
[{"name":"北京","city":[{"name":"北京","area":["东城区","西城区","崇文区","宣武区"...]}]}.....] 

我们的json数据就是这样一种格式,json数据存在assets文件夹中,下面我们看看怎么解析json数据并赋值给上面三个数据集:

private void initJson() { 
  citiesMap = new HashMap(); 
  areasMap = new HashMap(); 
  InputStream is = null; 
  try { 
    StringBuffer sb = new StringBuffer(); 
    is = getAssets().open("city.json"); 
    int len = -1; 
    byte[] buf = new byte[1024]; 
    while ((len = is.read(buf)) != -1) { 
      sb.append(new String(buf, 0, len, "gbk")); 
    } 
    JSONArray ja = new JSONArray(sb.toString()); 
    provinceArray = new String[ja.length()]; 
    String[] citiesArr = null; 
    for (int i = 0; i 

json解析技术上没有难点,这里的逻辑稍微有点复杂,用到了三个嵌套的for循环,大家慢慢琢磨一下其实也不难。好了,当数据集中都有数据之后,我们就可以给三个wheel设置Adapter了:

private void initView() { 
  provinceView.setViewAdapter(new ArrayWheelAdapter( 
      MainActivity.this, provinceArray)); 
  // 默认显示北京直辖市里边的市(只有北京市) 
  cityView.setViewAdapter(new ArrayWheelAdapter( 
      MainActivity.this, citiesMap.get("北京"))); 
  // 默认显示北京市里边的区县 
  areaView.setViewAdapter(new ArrayWheelAdapter( 
      MainActivity.this, areasMap.get("北京"))); 
 
  // 默认显示第一项 
  provinceView.setCurrentItem(0); 
  // 默认显示第一项 
  cityView.setCurrentItem(0); 
  // 默认显示第一项 
  areaView.setCurrentItem(0); 
  // 页面上显示7项 
  provinceView.setVisibleItems(7); 
  cityView.setVisibleItems(7); 
  areaView.setVisibleItems(7); 
  // 添加滑动事件 
  provinceView.addChangingListener(this); 
  cityView.addChangingListener(this); 
} 

设置完Adapter之后我们还设置了一些缺省值,都很简单,大家直接看注释即可,我们这里设置了两个监听事件,我们看看:

@Override 
  public void onChanged(WheelView wheel, int oldValue, int newValue) { 
    if (wheel == provinceView) { 
      // 更新省的时候不仅要更新市同时也要更新区县 
      updateCity(); 
      updateArea(); 
    } else if (wheel == cityView) { 
      // 更新市的时候只用更新区县即可 
      updateArea(); 
    } 
  } 
 
  private void updateArea() { 
    // 获得当前显示的City的下标 
    int cityIndex = cityView.getCurrentItem(); 
    // 获得当前显示的省的下标 
    int provinceIndex = provinceView.getCurrentItem(); 
    // 获得当前显示的省的名字 
    String proviceName = provinceArray[provinceIndex]; 
    // 获得当前显示的城市的名字 
    String currentName = citiesMap.get(proviceName)[cityIndex]; 
    // 根据当前显示的城市的名字获得该城市下所有的区县 
    String[] areas = areasMap.get(currentName); 
    // 将新获得的数据设置给areaView 
    areaView.setViewAdapter(new ArrayWheelAdapter( 
        MainActivity.this, areas)); 
    // 默认显示第一项 
    areaView.setCurrentItem(0); 
  } 
 
  private void updateCity() { 
    // 获得当前显示的省的下标 
    int currentIndex = provinceView.getCurrentItem(); 
    // 获得当前显示的省的名称 
    String currentName = provinceArray[currentIndex]; 
    // 根据当前显示的省的名称获得该省中所有的市 
    String[] cities = citiesMap.get(currentName); 
    // 将新获得的数据设置给cityView 
    cityView.setViewAdapter(new ArrayWheelAdapter( 
        MainActivity.this, cities)); 
    // 默认显示第一项 
    cityView.setCurrentItem(0); 
  } 

几乎每行代码都有注释,我就不啰嗦了,最后我们再来看看点击事件:

public void onClick(View v) { 
  // 获得当前显示的省的下标 
  int provinceIndex = provinceView.getCurrentItem(); 
  // 获得当前显示的省的名称 
  String provinceName = provinceArray[provinceIndex]; 
  // 获得当前显示的城市的下标 
  int cityIndex = cityView.getCurrentItem(); 
  // 获得当前显示的城市的名称 
  String cityName = citiesMap.get(provinceName)[cityIndex]; 
  // 获得当前显示的区县的下标 
  int areaIndex = areaView.getCurrentItem(); 
  Toast.makeText( 
      this, 
      "您选择的地区是" + provinceArray[provinceIndex] + cityName 
          + areasMap.get(cityName)[areaIndex], Toast.LENGTH_SHORT) 
      .show(); 
} 

好了,到这里我们想要的功能基本上就实现了,但是我们可以看到,系统默认的样式略显丑陋,那我我们可以通过修改源码来获得我们想要的样式,首先上下的黑边看这里:

private int[] SHADOWS_COLORS = new int[] { 0xFF111111, 0x00AAAAAA, 
      0x00AAAAAA }; 

在WheelView.java文件中,这一行代码定义了上下黑边的颜色的变化,三个参数分别是起始颜色,过渡颜色以及结束时的颜色,那么我们可以通过修改这里的源码来去掉上下的黑边,还有中间那个透明的东东黑不拉叽的,我们想改,通过源码找到了这个文件wheel_val.xml:

 
   
 
    
 

这里定义了中间那个透明条的样式,我们可以根据自己的需要进行修改。好了,这里的源码不多,也不难,大家可以自己去琢磨琢磨,关于wheel的介绍我们就说这么多。

本文Demo下载https://github.com/lenve/wheelTest

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


推荐阅读
  • 本文总结了在使用Ionic 5进行Android平台APK打包时遇到的问题,特别是针对QRScanner插件的改造。通过详细分析和提供具体的解决方法,帮助开发者顺利打包并优化应用性能。 ... [详细]
  • Android LED 数字字体的应用与实现
    本文介绍了一种适用于 Android 应用的 LED 数字字体(digital font),并详细描述了其在 UI 设计中的应用场景及其实现方法。这种字体常用于视频、广告倒计时等场景,能够增强视觉效果。 ... [详细]
  • RecyclerView初步学习(一)
    RecyclerView初步学习(一)ReCyclerView提供了一种插件式的编程模式,除了提供ViewHolder缓存模式,还可以自定义动画,分割符,布局样式,相比于传统的ListVi ... [详细]
  • QUIC协议:快速UDP互联网连接
    QUIC(Quick UDP Internet Connections)是谷歌开发的一种旨在提高网络性能和安全性的传输层协议。它基于UDP,并结合了TLS级别的安全性,提供了更高效、更可靠的互联网通信方式。 ... [详细]
  • 本文基于对相关论文和开源代码的研究,详细介绍了LOAM(激光雷达里程计与建图)的工作原理,并对其关键技术进行了分析。 ... [详细]
  • Android 九宫格布局详解及实现:人人网应用示例
    本文深入探讨了人人网Android应用中独特的九宫格布局设计,解析其背后的GridView实现原理,并提供详细的代码示例。这种布局方式不仅美观大方,而且在现代Android应用中较为少见,值得开发者借鉴。 ... [详细]
  • 本文详细记录了在基于Debian的Deepin 20操作系统上安装MySQL 5.7的具体步骤,包括软件包的选择、依赖项的处理及远程访问权限的配置。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 资源推荐 | TensorFlow官方中文教程助力英语非母语者学习
    来源:机器之心。本文详细介绍了TensorFlow官方提供的中文版教程和指南,帮助开发者更好地理解和应用这一强大的开源机器学习平台。 ... [详细]
  • 探讨如何高效使用FastJSON进行JSON数据解析,特别是从复杂嵌套结构中提取特定字段值的方法。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 构建基于BERT的中文NL2SQL模型:一个简明的基准
    本文探讨了将自然语言转换为SQL语句(NL2SQL)的任务,这是人工智能领域中一项非常实用的研究方向。文章介绍了笔者在公司举办的首届中文NL2SQL挑战赛中的实践,该比赛提供了金融和通用领域的表格数据,并标注了对应的自然语言与SQL语句对,旨在训练准确的NL2SQL模型。 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 本文详细介绍了如何使用 Yii2 的 GridView 组件在列表页面实现数据的直接编辑功能。通过具体的代码示例和步骤,帮助开发者快速掌握这一实用技巧。 ... [详细]
  • XNA 3.0 游戏编程:从 XML 文件加载数据
    本文介绍如何在 XNA 3.0 游戏项目中从 XML 文件加载数据。我们将探讨如何将 XML 数据序列化为二进制文件,并通过内容管道加载到游戏中。此外,还会涉及自定义类型读取器和写入器的实现。 ... [详细]
author-avatar
电筒_574
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有