可以使用Material Components库中的MaterialDatePicker来替换默认的DatePickerDialogue,并且可以轻松地添加所需的功能。以下是使用MaterialDatePicker自定义日期选择对话框的示例代码:
val builder = MaterialDatePicker.Builder.datePicker()
builder.setTitleText("Choose date")
// 设置默认日期
val calendar = Calendar.getInstance(TimeZone.getTimeZone("UTC"))
calendar.clear()
val defaultDate = arguments?.getLong(ARG_DEFAULT_DATE)
if (defaultDate != null) {
calendar.timeInMillis = defaultDate
}
val constraintsBuilder = CalendarConstraints.Builder()
constraintsBuilder.setStart(calendar.timeInMillis)
constraintsBuilder.setEnd(System.currentTimeMillis()) // 设置最大可选日期
builder.setCalendarConstraints(constraintsBuilder.build())
// 确认回调方法
val picker = builder.build()
picker.addOnPositiveButtonClickListener {
// “it” parameter is the selected date in milliseconds
val selectedDate = Date(it)
// ... do something with the selected date
}
picker.show(childFragmentManager, picker.toString())
上面的代码创建了一个MaterialDatePicker,并按照需要设置了日期范围和默认日期。该代码通过调用addOnPositiveButtonClickListener()方法添加确认回调,以在用户选择日期时获取所选日期。在回调方法中,我们可以将所选日期转换为Date对象,然后进行任何其他必要的操作。这个MaterialDatePicker甚至包含了一个主题,可以让我们轻松地更改选择器的外观和感觉。