#Android项目# ——day06城市选择

CityPicker送上GitHub地址:https://github.com/zaaach/CityPicker

一、效果图展示

在这里插入图片描述

二、导入依赖

app:build.gradle

dependencies {
	implementation 'com.zaaach:citypicker:2.0.3'	//必选
	implementation 'androidx.recyclerview:recyclerview:1.0.0'
}

三、基本使用:

步骤1:manifest配置

manifest.xml中给使用CityPickeractivity添加主题android:theme="@style/DefaultCityPickerTheme"

<activity android:name=".MainActivity" android:theme="@style/DefaultCityPickerTheme">
  ......
</activity>

步骤2:activity/fragment调用

注意:热门城市使用HotCity ,定位城市使用LocatedCity

//自定义热门城市
List<HotCity> hotCities = new ArrayList<>();
hotCities.add(new HotCity("北京", "北京", "101010100")); //code为城市代码
hotCities.add(new HotCity("上海", "上海", "101020100"));
hotCities.add(new HotCity("广州", "广东", "101280101"));
hotCities.add(new HotCity("深圳", "广东", "101280601"));
hotCities.add(new HotCity("杭州", "浙江", "101210101"));
......

 //城市列表
    private void getCity() {
        CityPicker.from(Objects.requireNonNull(getActivity()))
                //启用动画效果,默认无
                .enableAnimation(true)
                //自定义动画
                .setAnimationStyle(R.style.CustomAnim)
                //APP自身已定位的城市,传null会自动定位(默认)
                .setLocatedCity(null)
                //指定热门城市
                .setHotCities(hotCities)
                .setOnPickListener(new OnPickListener() {
                    /**
                     * 选中某个城市点击事件
                     * @param position 第几个
                     * @param data   获取具体的数据
                     */
                    @Override
                    public void onPick(int position, City data) {
                        //获取到的地区数据传值给全局使用
                        get_where.setWhere(data.getName());
                        //刷新界面
                        onStart();
                        //设置地区控件显示地区数据
                        homeArea.setText(data.getName());
                    }

                    /**
                     * 取消点击事件
                     */
                    @Override
                    public void onCancel() {
                        onStart();
                    }

                    @Override
                    public void onLocate() {
                        //开始定位,这里模拟一下定位
                        new Handler().postDelayed(() -> CityPicker.from(Objects.requireNonNull(getActivity())).locateComplete(new LocatedCity(get_where.getGPS_where(), "广东", "101280601"), LocateState.SUCCESS), 0);
                    }
                })
                .show();
    }

四、自定义主题

style.xml 中自定义主题并且继承DefaultCityPickerTheme ,别忘了在manifest.xml 设置给activity

<style name="CustomTheme" parent="DefaultCityPickerTheme">
        <item name="cpCancelTextColor">@color/color_green</item>
        <item name="cpSearchCursorDrawable">@color/color_green</item>
        <item name="cpIndexBarNormalTextColor">@color/color_green</item>
        <item name="cpIndexBarSelectedTextColor">@color/color_green</item>
        <item name="cpSectionHeight">@dimen/custom_section_height</item>
        <item name="cpOverlayBackground">@color/color_green</item>
  		......
</style>

CityPicker 中自定义的所有属性如下,有些属性值必须是引用类型refrence,使用时注意。

<resources>
    <attr name="cpCancelTextSize" format="dimension|reference" />
    <attr name="cpCancelTextColor" format="color|reference" />

    <attr name="cpClearTextIcon" format="reference" />
    <attr name="cpSearchTextSize" format="dimension|reference" />
    <attr name="cpSearchTextColor" format="color|reference" />
    <attr name="cpSearchHintText" format="string|reference" />
    <attr name="cpSearchHintTextColor" format="color|reference" />
    <attr name="cpSearchCursorDrawable" format="reference" />

    <attr name="cpListItemTextSize" format="dimension|reference" />
    <attr name="cpListItemTextColor" format="color|reference" />
    <attr name="cpListItemHeight" format="dimension|reference"/>

    <attr name="cpEmptyIcon" format="reference"/>
    <attr name="cpEmptyIconWidth" format="dimension|reference"/>
    <attr name="cpEmptyIconHeight" format="dimension|reference"/>
    <attr name="cpEmptyText" format="string|reference"/>
    <attr name="cpEmptyTextSize" format="dimension|reference"/>
    <attr name="cpEmptyTextColor" format="color|reference"/>

    <attr name="cpGridItemBackground" format="color|reference"/>
    <attr name="cpGridItemSpace" format="reference"/>
	<!--悬浮栏-->
    <attr name="cpSectionHeight" format="reference"/>
    <attr name="cpSectionTextSize" format="reference" />
    <attr name="cpSectionTextColor" format="reference" />
    <attr name="cpSectionBackground" format="reference" />

    <attr name="cpIndexBarTextSize" format="reference" />
    <attr name="cpIndexBarNormalTextColor" format="reference" />
    <attr name="cpIndexBarSelectedTextColor" format="reference" />
	<!--特写布局-->
    <attr name="cpOverlayWidth" format="dimension|reference"/>
    <attr name="cpOverlayHeight" format="dimension|reference"/>
    <attr name="cpOverlayTextSize" format="dimension|reference"/>
    <attr name="cpOverlayTextColor" format="color|reference"/>
    <attr name="cpOverlayBackground" format="color|reference"/>
</resources>

OK,enjoy it~

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
现在使用较多的类似美团、外卖等APP的城市选择界面,一行代码搞定,就是这么简单粗暴!!!主要功能:字母悬浮栏指定热门城市自定义动画效果自定义主题名称或拼音搜索Preview  APK下载demo.apk体验.InstallGradle:implementation 'com.zaaach:citypicker:2.0.0'or Maven:   com.zaaach   citypicker   2.0.0   pom or 下载library手动导入.UsageCityPicker 继承于DialogFragment ,本身没有定位功能,需要APP自身实现定位。基本使用:Step1:在manifest.xml给使用CityPicker 的activity添加主题android:theme="@style/DefaultCityPickerTheme"   ...... Step2:new CityPickerBuilder()         .setFragmentManager(getSupportFragmentManager()) //此方法必须调用         .setCurrentCity("杭州") //APP自身已定位的城市         .setAnimationStyle(anim)  //自定义动画         .setHotCities(new String[]{"北京", "上海", "广州", "深圳"}) //指定热门城市         .setOnPickListener(new OnPickListener() {               @Override               public void onPick(int position, String data) {                       Toast.makeText(getApplicationContext(), data, Toast.LENGTH_SHORT).show();               }})          .show();关于自定义主题:在style.xml 自定义主题并且继承DefaultCityPickerTheme ,别忘了在manifest.xml 设置给activity。<style name="CustomTheme" parent="DefaultCityPickerTheme">         @color/color_green         @color/color_green         @color/color_green         @color/color_green         @dimen/custom_section_height         @color/color_green    ...... </style>CityPicker 自定义的所有属性如下,有些属性值必须是引用类型refrence,使用时注意。                    <attr name="cpS

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值