Android开发年月选择器

一、效果图

年月选择器.png

二、思路

其实用的是'cn.aigestudio.wheelpicker:WheelPicker:1.1.3',可自行百度这个别人写的库,它还能实现很多功能
注:我这个是没联动效果的,它的库其他方法有

三、案例关键代码

xml

<?xml version="1.0" encoding="utf-8"?>

<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="200dp"
android:background="@color/m_white">


<TextView
    android:id="@+id/cancel"
    android:layout_width="60dp"
    android:layout_height="40dp"
    android:gravity="center"
    android:text="取消"
    android:textColor="@color/color_666666"
    android:textSize="@dimen/m_size_17"
    app:layout_constraintLeft_toLeftOf="parent"
    app:layout_constraintTop_toTopOf="parent" />


<TextView
    android:id="@+id/ok"
    android:layout_width="60dp"
    android:layout_height="40dp"
    android:gravity="center"
    android:text="确定"
    android:textColor="@color/color_3C76FF"
    android:textSize="@dimen/m_size_17"
    app:layout_constraintRight_toRightOf="parent"
    app:layout_constraintTop_toTopOf="parent" />


<View
    android:id="@+id/view_line"
    style="@style/full_under_line"
    app:layout_constraintLeft_toLeftOf="parent"
    app:layout_constraintTop_toBottomOf="@id/cancel" />


<com.aigestudio.wheelpicker.WheelPicker
    android:id="@+id/mWheelPicker_1"
    android:layout_width="0dp"
    android:layout_height="0dp"
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintLeft_toLeftOf="parent"
    app:layout_constraintRight_toLeftOf="@id/mWheelPicker_2"
    app:layout_constraintTop_toBottomOf="@id/view_line"
    android:layout_marginLeft="30dp"
    app:wheel_atmospheric="true"
    app:wheel_curtain_color="@color/m_blue"
    app:wheel_curved="true"
    app:wheel_cyclic="true"
    app:wheel_indicator_color="@color/m_red_one"
    app:wheel_item_text_color="@color/color_919191"
    app:wheel_item_text_size="@dimen/m_size_23"
    app:wheel_selected_item_text_color="@color/color_000000" />


<com.aigestudio.wheelpicker.WheelPicker
    android:id="@+id/mWheelPicker_2"
    android:layout_width="0dp"
    android:layout_height="0dp"
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintLeft_toRightOf="@id/mWheelPicker_1"
    app:layout_constraintRight_toRightOf="parent"
    app:layout_constraintTop_toTopOf="@id/mWheelPicker_1"
    android:layout_marginRight="30dp"
    app:wheel_atmospheric="true"
    app:wheel_curtain_color="@color/m_blue"
    app:wheel_curved="true"
    app:wheel_cyclic="true"
    app:wheel_indicator_color="@color/m_red_one"
    app:wheel_indicator_size="@dimen/m_size_24"
    app:wheel_item_text_color="@color/color_919191"
    app:wheel_item_text_size="@dimen/m_size_23"
    app:wheel_selected_item_text_color="@color/color_000000" />


</android.support.constraint.ConstraintLayout>

java代码

val CEOYEAR = arrayListOf<String>("2020","2021","2022","2023","2024","2025","2026","2027","2028","2029","2030")
val CEOMONTH= arrayListOf<String>("1","2","3","4","5","6","7","8","9","10","11","12")
val STARTYEAR = arrayListOf<String>("2017","2018","2019","2020","2021","2022","2023","2024","2025","2026","2027")
/**
* @desc : 两个滚动器
* @author : congge on 2020/2/20 17:20
**/
fun showTwoWheelPicker(context:Context,data1: MutableList<String>,data2: MutableList<String>,twoWheelListener: TwoWheelListener?){

    var dialog = getDialog(context)
    val window = dialog.window
    window.setGravity(Gravity.BOTTOM)
    window.setLayout(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT)
    window.setContentView(R.layout.dialog_two_wheel)

    val wv1 = window.findViewById<WheelPicker>(R.id.mWheelPicker_1)
    val wv2 = window.findViewById<WheelPicker>(R.id.mWheelPicker_2)

    wv1.data = data1
    wv2.data = data2

    //取消
    window.findViewById<View>(R.id.cancel).setOnClickListener {
        dialog.dismiss()
    }

    //确定
    window.findViewById<View>(R.id.ok).setOnClickListener {
        dialog.dismiss()
        twoWheelListener?.onOk(data1[wv1.currentItemPosition],data2[wv2.currentItemPosition])
    }


}

interface TwoWheelListener {

    fun onOk(str1: String, str2: String)
}

private fun getDialog(context:Context):Dialog{
    return AlertDialog.Builder(context, R.style.mydialog).setCancelable(false).show()
}

四、总结

有更多需求的还是去阅读第三方库

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 156,069评论 4 358
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 66,212评论 1 287
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 105,912评论 0 237
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,424评论 0 202
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 51,741评论 3 285
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,194评论 1 206
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,553评论 2 307
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,289评论 0 194
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 33,923评论 1 237
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,251评论 2 240
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 31,775评论 1 255
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,144评论 2 249
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,698评论 3 228
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 25,936评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,658评论 0 192
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,214评论 2 267
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,159评论 2 258

推荐阅读更多精彩内容