Android中使用開源框架Citypickerview實現(xiàn)省市區(qū)三級聯(lián)動選擇
1.概述
記得之前做商城項目,需要在地址選擇中實現(xiàn)省市區(qū)三級聯(lián)動,方便用戶快速的填寫地址,當(dāng)時使用的是一個叫做android-wheel 的開源控件,當(dāng)時感覺非常好用,唯一麻煩的是需要自己整理并解析省市區(qū)的xml文件,思路很簡單,但是代碼量相對大了些。偶然期間發(fā)現(xiàn)了另外一個開源組件,也就是今天要介紹的citypickerview。
github地址:crazyandcoder/citypicker
2. 實現(xiàn)效果
下面給大家演示下實現(xiàn)效果:

3. 實現(xiàn)方法
(1)添加依賴
dependencies {
...
compile 'liji.library.dev:citypickerview:0.7.0'
}
(2)代碼實現(xiàn)
這里就不在介紹布局文件了,直接演示實現(xiàn)代碼:
package com.mly.panhouye.anchong.activity;
import android.content.Context;
import android.content.Intent;
import android.graphics.Color;
import android.os.Bundle;
import android.text.TextUtils;
import android.view.View;
import android.view.inputmethod.InputMethodManager;
import android.widget.EditText;
import android.widget.TextView;
import com.lljjcoder.citypickerview.widget.CityPicker;
import com.mly.panhouye.anchong.R;
import com.mly.panhouye.anchong.entity.Anchong_Address;
import com.mly.panhouye.anchong.view.TitleBarView;
import static com.mly.panhouye.anchong.utils.Constant.NEWADDRESS;
public class NewAddressActivity extends BaseActivity {
TitleBarView address_manager_titleBar;
EditText new_address_name,new_address_phone,new_address_address;
Anchong_Address newAddress = new Anchong_Address();
TextView new_address_area;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_new_address);
initView();
}
//Texview的點擊事件
public void chooseArea(View view) {
//判斷輸入法的隱藏狀態(tài)
InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
if (imm.isActive()) {
imm.hideSoftInputFromWindow(view.getWindowToken(),
InputMethodManager.HIDE_NOT_ALWAYS);
selectAddress();//調(diào)用CityPicker選取區(qū)域
}
}
private void selectAddress() {
CityPicker cityPicker = new CityPicker.Builder(NewAddressActivity.this)
.textSize(14)
.title("地址選擇")
.titleBackgroundColor("#FFFFFF")
.titleTextColor("#696969")
.confirTextColor("#696969")
.cancelTextColor("#696969")
.province("江蘇省")
.city("常州市")
.district("天寧區(qū)")
.textColor(Color.parseColor("#000000"))
.provinceCyclic(true)
.cityCyclic(false)
.districtCyclic(false)
.visibleItemsCount(7)
.itemPadding(10)
.onlyShowProvinceAndCity(false)
.build();
cityPicker.show();
//監(jiān)聽方法,獲取選擇結(jié)果
cityPicker.setOnCityItemClickListener(new CityPicker.OnCityItemClickListener() {
@Override
public void onSelected(String... citySelected) {
//省份
String province = citySelected[0];
//城市
String city = citySelected[1];
//區(qū)縣(如果設(shè)定了兩級聯(lián)動,那么該項返回空)
String district = citySelected[2];
//郵編
String code = citySelected[3];
//為TextView賦值
new_address_area.setText(province.trim() + "-" + city.trim() + "-" + district.trim());
}
});
}
@Override
protected void initView() {
new_address_name = (EditText) findViewById(R.id.new_address_name);
new_address_phone = (EditText) findViewById(R.id.new_address_phone);
new_address_address = (EditText) findViewById(R.id.new_address_address);
new_address_area = (TextView) findViewById(R.id.new_address_area);
}
}
4.使用說明
摘自github地址:crazyandcoder/citypicker
結(jié)果返回
只需傳入Context便可獲取選擇的省市區(qū)域的信息,結(jié)果返回四項,可根據(jù)自己的實際需求進(jìn)行選擇。
- citySelected[0]:表示:省份信息
- citySelected[1]:表示:城市信息
- citySelected[2]:表示:區(qū)縣信息
- citySelected[3]:表示:郵編信息
方法說明
- textSize(滾輪文字的大小,int 類型,默認(rèn)為18)
- title(選擇器標(biāo)題,默認(rèn)為“選擇地區(qū)”)
- backgroundPop(背景,默認(rèn)為半透明,16位進(jìn)制顏色代碼,帶alpha值,如0xa0ffffff)
- titleBackgroundColor(標(biāo)題欄背景,默認(rèn)為灰色,#C7C7C7)
- confirTextColor(確認(rèn)按鈕字體顏色,默認(rèn)為系統(tǒng)的colorPrimary顏色值)
- cancelTextColor(取消按鈕字體顏色,默認(rèn)為系統(tǒng)的colorPrimary顏色值)
- province(默認(rèn)的顯示省份,顯示選擇器后直接定位的item位置)
- city(默認(rèn)的顯示市,顯示選擇器后直接定位的item位置)
- district(默認(rèn)的顯示區(qū),顯示選擇器后直接定位的item位置)
- textColor(滾輪文字的顏色 ,int 類型,默認(rèn)為0xFF585858)
- provinceCyclic(省份的滾輪是否循環(huán)滾動)
- cityCyclic(市的滾輪是否循環(huán)滾動)
- districtCyclic(區(qū)的滾輪是否循環(huán)滾動)
- visibleItemsCount(滾輪顯示的item個數(shù),int 類型,默認(rèn)為5個)
- itemPadding(滾輪item間距,默認(rèn)為5dp)
- onlyShowProvinceAndCity(boolean flag)(是否只顯示省份和市的兩級聯(lián)動,去掉區(qū)或者縣)
- titleTextColor(標(biāo)題文字顏色,默認(rèn)為 #E9E9E9)
以上所述是小編給大家介紹的Android中使用開源框架Citypickerview實現(xiàn)省市區(qū)三級聯(lián)動選擇,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Android實現(xiàn)簡易計步器功能隔天步數(shù)清零查看歷史運動紀(jì)錄
這篇文章主要介紹了Android實現(xiàn)簡易計步器功能隔天步數(shù)清零查看歷史運動紀(jì)錄,需要的朋友可以參考下2017-06-06
Android OkHttp Post上傳文件并且攜帶參數(shù)實例詳解
這篇文章主要介紹了Android OkHttp Post上傳文件并且攜帶參數(shù)實例詳解的相關(guān)資料,需要的朋友可以參考下2017-03-03
Android 實現(xiàn)銀聯(lián)刷卡機消費后手動簽名的功能(示例代碼)
在一些商場購物時,不需要用筆在銀聯(lián)機上簽名了,直接用手指觸摸實現(xiàn)消費簽名,非常方便,下面小編給大家分享Android 實現(xiàn)銀聯(lián)刷卡機消費后手動簽名的功能,需要的朋友參考下吧2017-12-12
如何在Android中實現(xiàn)一個簡易的Http服務(wù)器
這篇文章主要介紹了如何在Android中實現(xiàn)一個簡易的Http服務(wù)器,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-05-05
Android編程布局(Layout)之AbsoluteLayout用法實例分析
這篇文章主要介紹了Android編程布局(Layout)之AbsoluteLayout用法,結(jié)合實例形式簡單分析了Android絕對布局AbsoluteLayout的實現(xiàn)方法,需要的朋友可以參考下2015-12-12

