AndroidPicker

Introduction: 安卓选择器类库,包括日期选择器、时间选择器、单项选择器、双项选择器、城市地址选择器、车牌号选择器、数字选择器、星座选择器、生肖选择器、颜色选择器、文件选择器、目录选择器等,可自定义顶部及底部界面,可自定义窗口动画……Picker for android, include date&time/option/number/address/city/color/file&directory.
More: Author   ReportBugs   
Tags:

API 14+ Download JitPack Build Status

安卓选择器类库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、职业、学历、星座等)、城市地址选择器(分省级、地级及县级)、数字选择器(可用于年龄、身高、体重、温度等)、双项选择器、颜色选择器、文件及目录选择器等…… 欢迎大伙儿在Issues提交你的意见或建议。
欢迎 Fork & Pull requests 贡献您的代码,大家共同学习【AndroidPicker 交流群 604235437】。 查看更新日志,新版本可能未对旧版 API 作兼容处理,升级后若编译报错请根据错误提示更改。

Install

“app”是测试用例;“library”包括 WheelPicker、ColorPicker、FilePicker、MultiplePicker, WheelPicker 包括 DatePicker、TimePicker、OptionPicker、LinkagePicker、AddressPicker、NumberPicker、DoublePicker 等。

懒人建议直接远程加载 jcenter 里的

WheelPicker、FilePicker 及 ColorPicker 是独立的,需要用哪个就 compile 哪个。 latest.release 表示使用最新版,也可以参照此处指定具体的版本号1.3.x 之前的版本基于 ScrollView,1.4.x 版本基于 ListView,1.5.x 之后的版本基于 View:

dependencies {
    compile('cn.qqtheme.framework:WheelPicker:版本号') {
        exclude group: 'com.android.support'
    }
    compile('cn.qqtheme.framework:FilePicker:版本号') {
        exclude group: 'com.android.support'
    }
    compile('cn.qqtheme.framework:ColorPicker:版本号') {
        exclude group: 'com.android.support'
    }
}

若 jcenter 仓库里的无法下载的话,可换JitPack的仓库试试:

第一步,在项目根目录下的 build.gradle 里加:

repositories {
    maven {
        url "https://www.jitpack.io"
    }
}

第二步,在项目的 app 模块下的 build.gradle 里加:

dependencies {
    compile('com.github.gzu-liyujiang.AndroidPicker:WheelPicker:版本号') {
        exclude group: 'com.android.support'
    }
    compile('com.github.gzu-liyujiang.AndroidPicker:FilePicker:版本号') {
        exclude group: 'com.android.support'
    }
    compile('com.github.gzu-liyujiang.AndroidPicker:ColorPicker:版本号') {
        exclude group: 'com.android.support'
    }
}

使用 Eclipse 的话如何集成?

直接下载 AndroidPicker 的 jar 包复制到你的项目的 libs 下即可。

ProGuard

由于地址选择器使用了fastjson来解析,混淆时候需要加入以下类似的规则,不混淆 Province、City 等实体类。

-keepattributes InnerClasses,Signature
-keepattributes *Annotation*

-keep class cn.qqtheme.framework.entity.** { *;}

Sample (更多用法详见示例项目)

各种设置方法:

picker.setXXX(...);

如:
设置选项偏移量,可用来要设置显示的条目数,范围为 1-5,1 显示 3 行、2 显示 5 行、3 显示 7 行……

picker.setOffset(...);

设置启用循环

picker.setCycleDisable(false);

设置每项的高度,范围为 2-4

picker.setLineSpaceMultiplier(...);
picker.setItemHeight(...);

设置文字颜色、字号、字体等

picker.setTextColor(...);
picker.setTextSize(...);
picker.setTextPadding(...);
picker.setTextSizeAutoFit(...);
picker.setTypeface(...);

设置单位标签

picker.setLabel(...);
picker.setOnlyShowCenterLabel(...))

设置默认选中项

picker.setSelectedItem(...);
picker.setSelectedIndex(...);

设置滚轮项填充宽度,分割线最长

picker.setUseWeight(true);
picker.setDividerRatio(WheelView.DividerConfig.FILL);

设置触摸弹窗外面是否自动关闭

picker.setCanceledOnTouchOutside(...);

设置分隔线配置项,设置 null 将隐藏分割线及阴影

picker.setDividerConfig(...);
picker.setDividerColor(...);
picker.setDividerRatio(...);
picker.setDividerVisible(...);

设置内容边距

picker.setContentPadding(...);

设置选中项背景色

picker.setShadowColor(...)

自定义顶部及底部视图

picker.setHeaderView(...);
picker.setFooterView(...);

获得内容视图(不要调用 picker.show()方法),可以将其加入到其他容器视图(如自定义的 Dialog 的视图)中

picker.getContentView();

获得按钮视图(需要先调用 picker.show()方法),可以调用该视图相关方法,如 setVisibility()

picker.getCancelButton();
picker.getSubmitButton();

自定义选择器示例:

        CustomHeaderAndFooterPicker picker = new CustomHeaderAndFooterPicker(this);
        picker.setOnOptionPickListener(new OptionPicker.OnOptionPickListener() {
            @Override
            public void onOptionPicked(int position, String option) {
                showToast(option);
            }
        });
        picker.show();
核心滚轮控件为 WheelView,可以参照 SinglePicker、DateTimePicker 及 LinkagePicker 自行扩展。

Screenshots

以下图片显示的效果可能已修改过,实际效果请运行 demo 查看。
滑轮选择器内嵌效果图 自定义选择器效果图 日期选择器效果图 日期选择器效果图 时间选择器效果图 单项选择器效果图 地址选择器效果图 数字选择器效果图 星座选择器效果图 颜色选择器效果图 文件选择器效果图 目录选择器效果图

Thanks

基于 View 的 WheelView
基于 ListView 的 WheelView
基于 ScrollView 的 WheelView

Contact

点击这里给我发消息

Support Me
Apps
About Me
Google+: Trinea trinea
GitHub: Trinea