最近在用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 是更好的选择。

807

被折叠的 条评论
为什么被折叠?



