Android Kotlin 实现底部弹框日历组件的案例
更新时间:2024年08月02日 10:55:54 作者:代码x手莓莓
这篇文章主要介绍了Android Kotlin 实现底部弹框日历组件的案例,本文通过实例代码给大家介绍的非常详细,对大家大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
需求
如下图所示, 底部弹出日历组件
原生插件使用的有一个好处是可以根据你的系统语言切换插件内的语言, 刚好我们这个app面向的国外用户, 而产品对日历组件的日期显示有特别要求, 因此这无疑减少了我们切换语言的开发工作量
代码
1. custom_bottom_datepicker.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="wrap_content" android:background="#98ADABAB"> <RelativeLayout android:id="@+id/dialog_bottom" android:layout_width="match_parent" android:layout_height="320dp" android:layout_alignParentBottom="true" android:layout_centerHorizontal="true" android:background="@drawable/rounded_button_white" android:padding="20dp"> <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:layout_marginBottom="40dp"> <TextView android:id="@+id/cancel" android:layout_width="0dp" android:layout_weight="1.5" android:layout_height="38dp" android:layout_gravity="center_horizontal" android:text="Cancel" android:textAllCaps="false" android:textColor="@color/colorPrimary" android:textSize="14sp" android:gravity="center" /> <TextView android:id="@+id/title" android:layout_width="0dp" android:layout_weight="5" android:layout_height="38dp" android:layout_gravity="center_horizontal" android:text="Date of Birth" android:textAllCaps="false" android:textColor="@color/colorPrimary" android:textSize="16sp" android:gravity="center" /> <TextView android:id="@+id/save" android:layout_width="0dp" android:layout_weight="1.5" android:layout_height="38dp" android:layout_gravity="center_horizontal" android:layout_marginTop="139dp" android:text="Save" android:textAllCaps="false" android:gravity="center" android:textColor="@color/colorPrimary" android:textSize="14sp" /> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginTop="40dp" android:gravity="center_horizontal" android:orientation="vertical"> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" android:padding="5dp"> // 这个是最关键的 <DatePicker android:id="@+id/dp_date" android:layout_width="match_parent" android:layout_height="wrap_content" android:calendarViewShown="false" android:datePickerMode="spinner" /> </LinearLayout> </LinearLayout> </RelativeLayout> </RelativeLayout>
2. Activity.kt
import java.util.Date /** * 个人信息页 */ class PersonnalInfoActivity : AppCompatActivity() { private var year: String? = null private var month: String? = null private var day: String? = null @RequiresApi(Build.VERSION_CODES.N) override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_personal_info) birthday.setOnClickListener { chooseBirthFun() } } private fun chooseBirthFun() = run { val userInfo = SharedPrefs.loadUserFromPreferences(this@PersonnalInfoActivity) val view = layoutInflater.inflate(R.layout.custom_bottom_datepicker, null) val popupWindow = PopupWindow( view, ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT, true ) // 设置PopupWindow是否能响应外部点击事件 popupWindow.isOutsideTouchable = true // 设置PopupWindow是否能响应点击事件 popupWindow.isTouchable = true // 设置PopupWindow弹出窗体的背景 popupWindow.setBackgroundDrawable( ColorDrawable( ContextCompat.getColor( this, android.R.color.transparent ) ) ) // 设置PopupWindow从底部弹出 popupWindow.showAtLocation(view, Gravity.BOTTOM, 0, 0) val save = view.findViewById<TextView>(R.id.save) val cancel = view.findViewById<TextView>(R.id.cancel) val dpDate = view.findViewById<DatePicker>(R.id.dp_date); // 设置默认日期 if (userInfo != null) { if (userInfo.birthday == "") { dpDate.init(1970, 0, 1, null); } else { year?.let { (month)?.let { it1 -> day?.let { it2 -> dpDate.init( it.toInt(), (it1.toInt()) - 1, it2.toInt(), null ) } } }; } } save.setOnClickListener { if (popupWindow.isShowing) { year = dpDate.getYear().toString() month = ((dpDate.getMonth() + 1).toString()) day = dpDate.getDayOfMonth().toString() val birthStr = "${year}-${month}-${day}" // 此处可以处理选择好的日期 popupWindow.dismiss() } } cancel.setOnClickListener { if (popupWindow.isShowing) { popupWindow.dismiss() } } } }
完成~
到此这篇关于Android Kotlin 实现底部弹框日历组件的文章就介绍到这了,更多相关Android Kotlin底部弹框内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
AndriodStudio使用listview实现简单图书管理
这篇文章主要为大家详细介绍了AndriodStudio使用listview实现简单图书管理,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2022-03-03Android BottomNavigationBar底部导航控制器使用方法详解
这篇文章主要为大家详细介绍了Android BottomNavigationBar底部导航控制器使用方法,感兴趣的小伙伴们可以参考一下2016-03-03android教程之textview解析带图片的html示例
本文介绍的示例适用于android中需要解析带图片的htlm数据,需要的朋友可以参考下2014-02-02Android 自定义SeekBar 实现分段显示不同背景颜色的示例代码
这篇文章主要介绍了Android 自定义SeekBar 实现分段显示不同背景颜色,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2020-06-06
最新评论