我在XML中声明了Button
:
<Button
android:id="@+id/custom_id"
android:theme="@style/BlueButtonTheme"
android:layout_width="0dp"
android:layout_height="fill_parent"
android:layout_weight="1"
android:text="@string/custom_string"/>
最重要的一行是BlueButtonTheme
的样式:
<style name="BlueButtonTheme" parent="AppTheme">
<item name="android:buttonStyle">@style/BlueButtonStyle</item>
<item name="buttonStyle">@style/BlueButtonStyle</item>
<item name="colorAccent">@color/blue_dark</item>
<item name="colorControlActivated">@color/blue_dark</item>
<item name="colorControlHighlight">@color/blue_dark</item>
<item name="colorButtonNormal">@color/blue</item>
<item name="android:colorAccent">@color/blue_dark</item>
<item name="android:colorControlActivated">@color/blue_dark</item>
<item name="android:colorControlHighlight">@color/blue_dark</item>
<item name="android:colorButtonNormal">@color/blue</item>
<item name="android:textColor">@color/white</item>
</style>
<style name="BlueButtonStyle" parent="Widget.AppCompat.Button.Colored">
<item name="colorAccent">@color/blue_dark</item>
<item name="colorControlActivated">@color/blue_dark</item>
<item name="colorControlHighlight">@color/blue_dark</item>
<item name="colorButtonNormal">@color/blue</item>
<item name="android:colorAccent">@color/blue_dark</item>
<item name="android:colorControlActivated">@color/blue_dark</item>
<item name="android:colorControlHighlight">@color/blue_dark</item>
<item name="android:colorButtonNormal">@color/blue</item>
<item name="android:textColor">@color/white</item>
</style>
并且Button
在所有操作系统版本中都是蓝色的,很好......现在我想创建自定义MyButton extends Button
,但是当我在XML中设置时:
<com.package.name.MyButton
android:id="@+id/custom_id"
android:theme="@style/BlueButtonTheme"
...
小部件将保持灰色,例如Android 4.1(物理测试设备),但在按下/选择时有白色文字和蓝色。 5.0及以上的作品。我的按钮没有任何额外的逻辑(现在),只有一组构造函数。如何为此Button
的自定义窗口小部件应用工作主题?
答案 0 :(得分:0)
几个小时的尝试和发布上述问题后10分钟我找到了正确答案:extends AppCompatButton
(来自支持v7),而不是android.widget.Button