转载请注明出处:http://blog.csdn.net/lmj623565791/article/details/23382805
今天没事跟群里面侃大山,有个哥们说道Android Wheel这个控件,以为是Andriod内置的控件,google一把,发现是个github上的一个控件。
下载地址:https://code.google.com/p/android-wheel/ 发现很适合做省市县三级联动就做了一个。
先看下效果图:

1、首先导入github上的wheel项目
2、新建个项目,然后选择记得右键->Properties->Android中将wheel添加为lib:

上面两个步骤是导入所有开源项目的过程了。
3、下面开始代码的编写:首先是省市区的json文件,放置在asserts的city.json中:
大概的格式先了解一下,一会代码会根据这样的格式解析
{"citylist":
[{"p":"河北",
"c":[{"n":"石家庄",
"a":[{"s":"长安区"},{"s":"桥东区"},{"s":"鹿泉市"}]
}]
}
4、布局文件,比较简单就3个WheelView分别代表省,市,县,还有一个按钮:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#000000"
android:orientation="vertical" >
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_margin="10dp"
android:text="请选择城市"
android:textColor="#ffffff"
android:textSize="20sp" />
<LinearLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:background="@drawable/layout_bg"
android:orientation="horizontal" >
<kankan.wheel.widget.WheelView
android:id="@+id/id_province"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1" >
</kankan.wheel.widget.WheelView>
<kankan.wheel.widget.WheelView
android:id="@+id/id_city"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1" >
</kankan.wheel.widget.WheelView>
<kankan.wheel.widget.WheelView
android:id="@+id/id_area"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1" >
</kankan.wheel.widget.WheelView>
</LinearLayout>
<Button
android:onClick="showChoose"
android:layout_gravity="right"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="确定"
/>
</LinearLayout>
5、Activity的编写:注释相当详细,节不赘述了。
package com.example.wheel_province;
import java.io.IOException;
import java.io.InputStream;
import java.util.HashMap;
import java.util.Map;
import kankan.wheel.widget.OnWheelChangedListener;
import kankan.wheel.widget.WheelView;
import kankan.wheel.widget.adapters.ArrayWheelAdapter;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.Toast;
/**
*
* @author zhy
*
*/
public class CitiesActivity extends Activity implements OnWheelChangedListener
{
/**
* 把全国的省市区的信息以json的格式保存,解析完成后赋值为null
*/
private JSONObject mJsonObj;
/**
* 省的WheelView控件
*/
private WheelView mProvince;
/**
* 市的WheelView控件
*/
private WheelView mCity;
/**
* 区的WheelView控件
*/
private WheelView mArea;
/**
* 所有省
*/
private String[] mProvinceDatas;
/**
* key - 省 value - 市s
*/
private Map<String, String[]> mCitisDatasMap = new HashMap<String, String[]>();
/**
* key - 市 values - 区s
*/
private Map<String, String[]> mAreaDatasMap = new HashMap<String, String[]>();
/**
* 当前省的名称
*/
private String mCurrentProviceName;
/**
* 当前市的名称
*/
private String mCurrentCityName;
/**
* 当前区的名称
*/
private String mCurrentAreaName ="";
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.citys);
initJsonData();
mProvince = (WheelView) findViewById(R.id.id_province);
mCity = (WheelView) findViewById(R.id.id_city);
mArea = (WheelView) findViewById(R.id.id_area);
initDatas();
mProvince.setViewAdapter(new ArrayWheelAdapter<String>(this, mProvinceDatas));
// 添加change事件
mProvince.addChangingListener(this);
// 添加change事件
mCity.addChangingListener(this);
// 添加change事件
mArea.addChangingListener(this);
mProvince.setVisibleItems(5);
mCity.setVisibleItems(5);
mArea.setVisibleItems(5);
updateCities();
updateAreas();
}
/**
* 根据当前的市,更新区WheelView的信息
*/
private void updateAreas()
{
int pCurrent = mCity.getCurrentItem();
mCurrentCityName = mCitisDatasMap.get(mCurrentProviceName)[pCurrent];
String[] areas = mAreaDatasMap.get(mCurrentCityName);
if (areas == null)
{
areas = new String[] { "" };
}
mArea.setViewAdapter(new ArrayWheelAdapter<String>(this, areas));
mArea.setCurrentItem(0);
}
/**
* 根据当前的省,更新市WheelView的信息
*/
private void updateCities()
{
int pCurrent = mProvince.getCurrentItem();
mCurrentProviceName = mProvinceDatas[pCurrent];
String[] cities = mCitisDatasMap.get(mCurrentProviceName);
if (cities == null)
{
cities = new String[] { "" };
}
mCity.setViewAdapter(new ArrayWheelAdapter<String>(this, cities));
mCity.setCurrentItem(0);
updateAreas();
}
/**
* 解析整个Json对象,完成后释放Json对象的内存
*/
private void initDatas()
{
try
{
JSONArray jsonArray = mJsonObj.getJSONArray("citylist");
mProvinceDatas = new String[jsonArray.length()];
for (int i = 0; i < jsonArray.length(); i++)
{
JSONObject jsonP = jsonArray.getJSONObject(i);// 每个省的json对象
String province = jsonP.getString("p");// 省名字
mProvinceDatas[i] = province;
JSONArray jsonCs = null;
try
{
/**
* Throws JSONException if the mapping doesn't exist or is
* not a JSONArray.
*/
jsonCs = jsonP.getJSONArray("c");
} catch (Exception e1)
{
continue;
}
String[] mCitiesDatas = new String[jsonCs.length()];
for (int j = 0; j < jsonCs.length(); j++)
{
JSONObject jsonCity = jsonCs.getJSONObject(j);
String city = jsonCity.getString("n");// 市名字
mCitiesDatas[j] = city;
JSONArray jsonAreas = null;
try
{
/**
* Throws JSONException if the mapping doesn't exist or
* is not a JSONArray.
*/
jsonAreas = jsonCity.getJSONArray("a");
} catch (Exception e)
{
continue;
}
String[] mAreasDatas = new String[jsonAreas.length()];// 当前市的所有区
for (int k = 0; k < jsonAreas.length(); k++)
{
String area = jsonAreas.getJSONObject(k).getString("s");// 区域的名称
mAreasDatas[k] = area;
}
mAreaDatasMap.put(city, mAreasDatas);
}
mCitisDatasMap.put(province, mCitiesDatas);
}
} catch (JSONException e)
{
e.printStackTrace();
}
mJsonObj = null;
}
/**
* 从assert文件夹中读取省市区的json文件,然后转化为json对象
*/
private void initJsonData()
{
try
{
StringBuffer sb = new StringBuffer();
InputStream 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"));
}
is.close();
mJsonObj = new JSONObject(sb.toString());
} catch (IOException e)
{
e.printStackTrace();
} catch (JSONException e)
{
e.printStackTrace();
}
}
/**
* change事件的处理
*/
@Override
public void onChanged(WheelView wheel, int oldValue, int newValue)
{
if (wheel == mProvince)
{
updateCities();
} else if (wheel == mCity)
{
updateAreas();
} else if (wheel == mArea)
{
mCurrentAreaName = mAreaDatasMap.get(mCurrentCityName)[newValue];
}
}
public void showChoose(View view)
{
Toast.makeText(this, mCurrentProviceName + mCurrentCityName + mCurrentAreaName, 1).show();
}
}
这样就完成了代码的编写,如果这篇文章对你有帮助,可以顶一个~嘿嘿~
分享到:
相关推荐
这个例子中,我们将详细探讨如何使用`android-wheel`库来实现省市区三级联动的效果。 首先,`android-wheel`库是基于Android原生的`AbsSeekBar`类进行扩展的,提供了一个可滚动的选项列表,用户可以方便地通过手指...
总的来说,这个项目展示了如何利用第三方库"android-wheel"来实现Android上的省市县三级联动选择,并通过代码的修改优化了原有功能。对于Android开发者来说,理解和掌握这样的实现方式有助于提升开发效率,同时也能...
总结,省市县三级联动选择的实现主要依赖于`android-wheel`库,通过创建和绑定数据、监听滚动事件、自定义样式以及处理异常情况,我们可以创建出功能完备、交互良好的选择器。结合`Cascade_Master`示例进行实践,将...
"Android省市区三级联动滚轮选择——Cascade_Master"是一个专门为解决这一问题而设计的组件。这个组件是从实际项目中提炼出来的,旨在提供一个高效、直观且易于集成的解决方案。 该组件是基于开源库`Android-wheel`...
从真实项目中提取出来的,Android省市区三级联动滚轮选择组件,基于开源组件Android-wheel来实现,效果非常不错,可以直接拿去用.zip,太多无法一一验证是否可用,程序如果跑不起来需要自调,部分代码功能进行参考...
在这个"Android省市区三级联动的实现"项目中,开发者巧妙地利用了`android-wheel`库来创建一个自定义的地区选择器。 `android-wheel`是一个开源的Android滚动选择控件,它提供了一个类似滚轮的界面,用户可以通过...
在Android开发中,"省市县三级联动"是一个常见的需求,特别是在设计地址选择或者信息填写时。这个功能允许用户逐级选择省、市、县(区),确保数据输入的准确性和完整性。在这里,我们主要探讨如何利用Wheel控件来...
"Android省市区三级联动滚轮选择"就是一个解决此类问题的组件,它基于开源库`Android-wheel`来实现,提供了良好的用户体验和高效的数据处理能力。下面我们将详细探讨这个组件的核心知识点及其在实际开发中的应用。 ...
总结起来,这个项目提供了一个基于`Android-wheel`组件的省市区三级联动滚轮选择器,它具有良好的可定制性和用户体验,适用于各种需要级联选择的场景。通过阅读源码和相关文档,开发者可以快速理解和使用这个组件,...
在Android应用开发中,"三级联动"是一种常见的交互设计,特别是在选择特定信息时,如日期、地区等。这种设计涉及到三个互相依赖的下拉菜单,每个菜单的选择会影响到下一个菜单的选项。例如,从年到月再到日的选择,...
下载地址:https://code.google.com/p/android-wheel/ 发现很适合做省市县三级联动就做了一个。 先看下效果图: 1、首先导入github上的wheel项目 2、新建个项目,然后选择记得右键->Properties->Android中将wheel...
在Android开发中,"省市县三级联动"是一个常见的需求,特别是在需要用户选择详细地址的场景,如电商应用的收货地址填写。这个功能涉及到的数据结构和网络请求是本知识点的重点。 首先,"三级联动"指的是在界面上...
在Android开发中,有时我们需要为用户提供便捷的地址选择功能,这就是所谓的省市区三级联动选择。在这种场景下,我们可以借助开源库来简化开发流程。本文将详细介绍如何使用名为Citypickerview的开源框架在Android中...
在Android开发中,实现省市区3级联动菜单是一项常见的需求,尤其在地址选择、物流配送等场景中。这个"Android例子源码省市区3级联动菜单和数据库"提供了实现这一功能的具体示例,有助于开发者更好地理解和掌握相关...
"Cascade_Master"是一个特定的实现,展示了如何使用这个轮盘选择器来创建一个省市区三级联动选择器。在许多中国的应用程序中,这种功能是必不可少的,因为它允许用户快速地定位到他们的具体位置。这个实现通过三个...