使用深色主题时,MaterialDatePicker和TimePickerDialog的样式不同

时间:2020-08-27 09:22:44

标签: android material-design material-components-android android-datepicker android-timepicker

我目前正在使用MaterialDatePicker,并且由于物料团队没有使用相应的TimePicker,因此我选择使用TimePickerDialog。

val calendarConstraints = CalendarConstraints.Builder().setOpenAt(datetimeAsUTC)
val datePicker: MaterialDatePicker<Long> = MaterialDatePicker
       .Builder
       .datePicker()
       .setSelection(datetimeAsUTC)
       .setCalendarConstraints(calendarConstraints.build())
       .setTitleText(label)
       .build()

datePicker.show(requireFragmentManager(), datePicker.toString())
val timePicker : TimePickerDialog = TimePickerDialog(requireContext(), { _, hour, minute ->
        vm.process(event(hour, minute))
    },
    datetime.value?.hourOfDay ?: 0,
    datetime.value?.minuteOfHour ?: 0,
    DateFormat.is24HourFormat(requireContext())
)           
timePicker.show()

效果不错,但在深色主题下风格却不匹配

enter image description here

这似乎是很多人都会遇到的问题,因此希望有一个简单的解决方案。 我可以自己尝试更改颜色,但是我对此没有太多经验,因此考虑 我不是要寻找自定义外观,而是要与其他应用程序匹配的标准外观,我认为有更好的解决方案。

1 个答案:

答案 0 :(得分:4)

使用材料成分库中的MaterialTimePicker

val materialTimePicker = MaterialTimePicker.Builder()
    .setTimeFormat(TimeFormat.CLOCK_24H)
    .setHour(22)
    .setMinute(10)
    .build()

materialTimePicker.show(supportFragmentManager, "fragment_tag")

注意:该代码至少需要版本 1.3.0-alpha03

enter image description here

相关问题