• Android 省市县 三级联动(android-wheel的使用)[转]


    转载: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中:

    大概的格式先了解一下,一会代码会根据这样的格式解析

    [html] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. {"citylist":  
    2.     [{"p":"河北",  
    3.       "c":[{"n":"石家庄",  
    4.       "a":[{"s":"长安区"},{"s":"桥东区"},{"s":"鹿泉市"}]  
    5.     }]  
    6. }  


    4、布局文件,比较简单就3个WheelView分别代表省,市,县,还有一个按钮:

    [html] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    2.     xmlns:tools="http://schemas.android.com/tools"  
    3.     android:layout_width="match_parent"  
    4.     android:layout_height="match_parent"  
    5.     android:background="#000000"  
    6.     android:orientation="vertical" >  
    7.   
    8.     <TextView  
    9.         android:layout_width="wrap_content"  
    10.         android:layout_height="wrap_content"  
    11.         android:layout_gravity="center"  
    12.         android:layout_margin="10dp"  
    13.         android:text="请选择城市"  
    14.         android:textColor="#ffffff"  
    15.         android:textSize="20sp" />  
    16.   
    17.     <LinearLayout  
    18.         android:layout_width="fill_parent"  
    19.         android:layout_height="wrap_content"  
    20.         android:background="@drawable/layout_bg"  
    21.         android:orientation="horizontal" >  
    22.   
    23.         <kankan.wheel.widget.WheelView  
    24.             android:id="@+id/id_province"  
    25.             android:layout_width="0dp"  
    26.             android:layout_height="wrap_content"  
    27.             android:layout_weight="1" >  
    28.         </kankan.wheel.widget.WheelView>  
    29.   
    30.         <kankan.wheel.widget.WheelView  
    31.             android:id="@+id/id_city"  
    32.             android:layout_width="0dp"  
    33.             android:layout_height="wrap_content"  
    34.             android:layout_weight="1" >  
    35.         </kankan.wheel.widget.WheelView>  
    36.   
    37.         <kankan.wheel.widget.WheelView  
    38.             android:id="@+id/id_area"  
    39.             android:layout_width="0dp"  
    40.             android:layout_height="wrap_content"  
    41.             android:layout_weight="1" >  
    42.         </kankan.wheel.widget.WheelView>  
    43.     </LinearLayout>  
    44.       
    45.     <Button   
    46.         android:onClick="showChoose"  
    47.         android:layout_gravity="right"  
    48.         android:layout_width="wrap_content"  
    49.         android:layout_height="wrap_content"  
    50.         android:text="确定"  
    51.         />  
    52.       
    53.   
    54. </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();
            //此处代码有bug,修改成一下
    //        mCurrentCityName = mCitisDatasMap.get(mCurrentProviceName)[pCurrent];
            
            String[] cities =  mCitisDatasMap.get(mCurrentProviceName);
            if (cities == null)
            {
                cities = new String[] { "" };
                mCurrentCityName = "";
            }        
            else
            {
                mCurrentCityName = cities[pCurrent];
            }
            
            
            String[] areas = mAreaDatasMap.get(mCurrentCityName);
    
            if (areas == null)
            {
                areas = new String[] { "" };
            }
            mArea.setViewAdapter(new ArrayWheelAdapter<String>(this, areas));
            mArea.setCurrentItem(0);
            
            mCurrentAreaName = areas[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, "utf8"));
                }
                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();
        }
    }

    这样就完成了代码的编写,如果这篇文章对你有帮助,可以顶一个~嘿嘿~

     红色部分是我转载过修复的bug部分

    源码下载点击这里

  • 相关阅读:
    JavaScript-12(事件)
    JavaScript-11(DOM对象)
    JavaScript-10(去重数组)
    js中三元运算符的用法拓展
    JavaScript-5(常见题目-4)
    JavaScript-6(数组的大小排序)
    【CSP-S2019】10.28比赛总结
    【CSP-S2019模拟】10.27比赛总结
    JZOJ6392. 【NOIP2019模拟2019.10.26】僵尸
    【Comet OJ
  • 原文地址:https://www.cnblogs.com/exmyth/p/4527712.html
Copyright © 2020-2023  润新知