最近在用AndroidStudio开发app时,发现设置按钮背景色无效(android:background = "#xxxxxx"),并且确认了其父布局中也没有设置背景色,可以排除是父布局的影响,最终经过排查发现是主题(themes.xml)的影响:
<style name="Theme.Rd_App_VehicleSentry" parent="Theme.Material3.DayNight.NoActionBar"> <item name="colorPrimary">@color/purple_500</item> <item name="colorPrimaryVariant">@color/purple_700</item> <item name="colorOnPrimary">@color/white</item> <!-- Secondary brand color. --> <item name="colorSecondary">@color/teal_200</item> <item name="colorSecondaryVariant">@color/teal_700</item> <item name="colorOnSecondary">@color/black</item> <!-- Status bar color. --> <item name="android:statusBarColor" tools:targetApi="l">?attr/colorPrimaryVariant</item> <!-- Customize your theme here. --> </style>
继承的主题是Theme.Material3.DayNight.NoActionBar,特点:基于最新的 Material Design 3 风格,支持日间模式和夜间模式的自动切换。Material3
提供了最新的设计标准和控件,适用于更现代的 Android 版本和更丰富的用户体验,而我设计的app需要兼容老版本,因此需要继承Theme.AppCompat.Light.NoActionBar。
修改如下:
<style name="Theme.Rd_App" parent="Theme.AppCompat.Light.NoActionBar"> <item name="colorPrimary">@color/purple_500</item> <item name="colorPrimaryVariant">@color/purple_700</item> <item name="colorOnPrimary">@color/white</item> <!-- Secondary brand color. --> <item name="colorSecondary">@color/teal_200</item> <item name="colorSecondaryVariant">@color/teal_700</item> <item name="colorOnSecondary">@color/black</item> <!-- Status bar color. --> <item name="android:statusBarColor" tools:targetApi="l">?attr/colorPrimaryVariant</item> <!-- Customize your theme here. --> </style>
总结:Theme.Material3
是更新的主题体系,提供了更现代的设计和功能,而 AppCompat
主题则更加兼容旧版设备。如果你的应用需要使用最新的 Material Design 3 特性,选择 Theme.Material3
会更合适;如果需要兼容较旧的 Android 版本,AppCompat
是更好的选择。