如何在材质设计android中自定义TimePicker?

jas*_*son 9 android android-theme android-timepicker

我无法更改选择器颜色和TimePicker的其他部分.到目前为止,我可以更改标题颜色和背景,但我无法更改innercircle和textcolor.

更改自定义主题链接.

我的代码:

<TimePicker
    android:id="@+id/tp"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:timePickerMode="clock"
    android:headerBackground="#565466"
    android:amPmBackgroundColor="#500126"
    android:numbersBackgroundColor="#57e326"
    android:numbersTextColor="#995394"
    android:numbersSelectorColor="#675543"
    android:textColorSecondary="#897530"
    android:textColorPrimary="#359875"
/>
Run Code Online (Sandbox Code Playgroud)

Ger*_*ssy 18

基本模式

您所要做的就是在Activity的主题中设置强调色:

<item name="colorAccent">#3333cc</item>
Run Code Online (Sandbox Code Playgroud)

这将为您设置所有颜色,这样您就不会弄乱样式.

(这也意味着你不应该amPmBackgroundColor直接在你的TimePicker上设置值,让Android为你做的事情.)

高级模式

如果要分别指定所有可能的值,请执行以下操作:

首先在Activity的主题中定义它:

<item name="android:timePickerStyle">@style/Theme.MyTheme.TimePicker</item>
Run Code Online (Sandbox Code Playgroud)

然后创建合适的样式:

<style name="Theme.MyTheme.TimePicker" parent="android:Widget.Material.Light.TimePicker">
    <item name="android:timePickerMode">clock</item>
    <item name="android:headerBackground">#ff555555</item>
    <item name="android:numbersTextColor">?android:attr/textColorPrimaryActivated</item>
    <item name="android:numbersInnerTextColor">?android:attr/textColorSecondaryActivated</item>
    <item name="android:numbersSelectorColor">?android:attr/colorControlActivated</item>
    <item name="android:numbersBackgroundColor">#ff555555</item>
    <item name="android:amPmTextColor">?android:attr/textColorSecondary</item>
</style>
Run Code Online (Sandbox Code Playgroud)

请注意,numbersInnerTextColor只能从API级别23获得,并且headerTextColor无法设置其他样式(例如)(或者至少我无法使其工作).

我建议不要使用"高级"模式,因为TimePicker应该与包含Activity的颜色相同,否则可能会以一种糟糕的方式影响你的用户体验.


Arn*_*Rao 6

时间选择器材质样式:

带自定义颜色的 TimePickerDialog 材质样式

<style name="MyTimePickerDialogStyle" parent="@style/ThemeOverlay.AppCompat.Dialog.Alert">
<item name="showTitle">false</item>
<item name="colorControlActivated">#ffd600</item>
<item name="colorAccent">#b71c1c</item>
<item name="android:textColorPrimary">#43a047</item>
<item name="android:textColorSecondary">#f44336</item>
</style>
Run Code Online (Sandbox Code Playgroud)

时间选择器小部件样式

<style name="MyTimePickerWidgetStyle" parent="@android:style/Widget.Material.TimePicker">
    <item name="android:headerBackground">#ffe082</item>
    <item name="android:numbersTextColor">#b71c1c</item>
    <item name="android:numbersInnerTextColor">#f44336</item>
    <item name="android:numbersSelectorColor">#33691e</item>
    <item name="android:numbersBackgroundColor">#ef9a9a</item>
    <item name="android:amPmTextColor">#9c27b0</item>
</style>
Run Code Online (Sandbox Code Playgroud)

有关 TimePicker 的更多信息,请参阅http://www.zoftino.com/android-timepicker-example