Coder Social home page Coder Social logo

citypicker-master's Introduction

citypicker Android Studio实现

前言

在实际的项目中需要使用到省市区三级联动的功能,在网上找来找去,都没有找到一个合适的库, 所以自己就封装了一个,不需要自己添加数据源,直接引用即可,一行代码搞定城市选择。怎么简单,怎么方便,怎么来,就是这么任性!

亮点

无需自己配置省市区域的数据,不需要再进行解析之类的繁杂操作,只需引用即可,结果返回省市区和邮编等四项数据信息,如果不满意样式的话可以自己修改源码!

效果预览

应用在实际项目中效果

APK下载

这里写图片描述

  1. fir下载apk演示

V0.4.0版本更新内容(2016.10.24)

更新内容

  1. 新增只显示省市两级联动设置
  2. 新增确认和取消按钮文字颜色的设置
  3. 新增设置默认省市区的设置

gradle引用

    compile 'liji.library.dev:citypickerview:0.4.0'

代码示例(v0.4.0)

 CityPicker cityPicker = new CityPicker.Builder(MainActivity.this).textSize(20) //滚轮文字的大小
                        .onlyShowProvinceAndCity(true) //显示省市两级联动
                        .confirTextColor("#000000") //设置确认按钮文字颜色
                        .cancelTextColor("#000000") //设置取消按钮文字颜色
                        .province("江苏省") //设置默认省
                        .city("常州市") //设置默认城市
                        .district("新北区") //设置默认地区(县)
                        .textColor(Color.parseColor("#000000")) //滚轮文字的颜色
                        .provinceCyclic(true) //省份滚轮是否循环显示
                        .cityCyclic(false) //城市滚轮是否循环显示
                        .districtCyclic(false) //地区(县)滚轮是否循环显示
                        .visibleItemsCount(7) //滚轮显示的item个数
                        .itemPadding(10) //滚轮item间距
                        .build();
                        
                cityPicker.show();
                cityPicker.setOnCityItemClickListener(new CityPicker.OnCityItemClickListener() {
                    @Override
                    public void onSelected(String... citySelected) {
                       //省份
		               String province = citySelected[0];
		               //城市
		               String city = citySelected[1];
		               //区县(如果设定了两级联动,那么该项返回空)
		               String district = citySelected[2];
		               //邮编
		               String code = citySelected[3]; 
                    }
                });

属性说明

onlyShowProvinceAndCity(boolean flag)

省市两级联动,boolean 类型,默认false,三级联动

confirTextColor

确认按钮文字的颜色 ,int 类型,默认为#0000FF(BLUE)

cancelTextColor

取消按钮文字的颜色 ,int 类型,默认为#000000(BLACK)

province

设置默认省 ,String类型,默认为江苏省

city

设置默认市 ,String 类型,默认为常州市

district

设置默认区(县),String 类型,默认为新北区


V0.3.0版本更新内容(2016.10.13)

更新内容

  1. 新增item间距属性
  2. 拆分省市区三个滚轮循环显示为分别是否循环滚动
  3. 优化代码结构

gradle引用

    compile 'liji.library.dev:citypickerview:0.3.0'

代码示例(v0.3.0)

CityPicker cityPicker = new CityPicker.Builder(context).textSize(20)//滚轮文字的大小
                        .textColor(Color.parseColor("#000000"))//滚轮文字的颜色
                        .provinceCyclic(true)//省份滚轮是否循环显示
                        .cityCyclic(false)//城市滚轮是否循环显示
                        .districtCyclic(false)//地区(县)滚轮是否循环显示
                        .visibleItemsCount(7)//滚轮显示的item个数
                        .itemPadding(10)//滚轮item间距
                        .build();
                
                cityPicker.show();
                cityPicker.setOnCityItemClickListener(new CityPicker.OnCityItemClickListener() {
                    @Override
                    public void onSelected(String... citySelected) {
                       //省份
		               String province = citySelected[0];
		               //城市
		               String city = citySelected[1];
		               //区县
		               String district = citySelected[2];
		               //邮编
		               String code = citySelected[3]; 
                    }
                });

属性说明

textSize

滚轮文字的大小,int 类型,默认为18

textColor

滚轮文字的颜色 ,int 类型,默认为0xFF585858

visibleItemsCount

滚轮显示的item个数,int 类型,默认为5个

provinceCyclic

省份滚轮是否循环显示,boolean 类型,默认为true

cityCyclic

城市滚轮是否循环显示,boolean 类型,默认为true

districtCyclic

地区(县)滚轮是否循环显示,boolean 类型,默认为true

itemPadding

滚轮item间距,默认为5dp

结果返回

只需传入Context便可获取选择的省市区域的信息,结果返回四项,可根据自己的实际需求进行选择。

  1. citySelected[0]:表示:省份信息
  2. citySelected[1]:表示:城市信息
  3. citySelected[2]:表示:区县信息
  4. citySelected[3]:表示:邮编信息

V0.2.0版本更新内容(2016.05.16)

更新内容

  1. 滚轮是否循环滚动
  2. 新增文字颜色修改
  3. 新增文字大小修改
  4. 新增滚轮内容可见数量

gradle引用

    compile 'liji.library.dev:citypickerview:0.2.0'

代码示例(v0.2.0)

 CityPickerView cityPickerView = new CityPickerView(MainActivity.this);
        cityPickerView.setOnCityItemClickListener(new CityPickerView.OnCityItemClickListener() {
            @Override
            public void onSelected(String... citySelected) {
                //省份
                String province = citySelected[0];
                //城市
                String city = citySelected[1];
                //区县
                String district = citySelected[2];
                //邮编
                String code = citySelected[3];
                 
            }
        });
        cityPickerView.setTextColor(Color.BLUE);//新增文字颜色修改
        cityPickerView.setTextSize(20);//新增文字大小修改
        cityPickerView.setVisibleItems(5);//新增滚轮内容可见数量
        cityPickerView.setIsCyclic(true);//滚轮是否循环滚动
        cityPickerView.show();

结果返回

只需传入Context便可获取选择的省市区域的信息,结果返回四项,可根据自己的实际需求进行选择。

  1. citySelected[0]:表示:省份信息
  2. citySelected[1]:表示:城市信息
  3. citySelected[2]:表示:区县信息
  4. citySelected[3]:表示:邮编信息

V0.1.0版本更新内容

  1. 直接传入context获取省市区信息

数据来源

数据来源主要有2种方式,可根据喜好选择哪种方式使用。

xml数据

json数据

关于我

我的个人博客

感谢

citypicker-master's People

Stargazers

 avatar  avatar  avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.