我正在尝试更改工具栏中文本菜单项的颜色
使用时:
<style name="Base.App" parent="Theme.MaterialComponents.Light.NoActionBar">
<item name="actionMenuTextColor">@color/blue</item>
它工作,但使用时:
<style name="Base.App" parent="Theme.MaterialComponents.Light.NoActionBar">
<item name="actionMenuTextColor">?attr/colorPrimary</item>
事实并非如此。
知道吗?
编辑1:
工具栏样式如下
<item name="toolbarStyle">@style/Widget.App.Toolbar</item>
<style name="Widget.App.Toolbar" parent="Widget.MaterialComponents.Toolbar.Primary">
<item name="materialThemeOverlay">@style/ThemeOverlay.App.Toolbar</item>
<item name="titleTextAppearance">@style/Widget.App.Toolbar.TitleTextAppearance</item>
</style>
<style name="Widget.App.Toolbar.TitleTextAppearance" parent="TextAppearance.App.Headline6">
<item name="android:textStyle">bold</item>
</style>
编辑2:
使用
<style name="Base.App" parent="Theme.MaterialComponents.Light.NoActionBar">
<item name="actionMenuTextColor">?attr/colorPrimaryVariant</item>
实际上是有效的。但同样,不是colorPrimary
<item name="actionMenuTextColor">?attr/colorPrimary</item>
它不使用colorPrimary
,因为在Toolbar
中,您使用:覆盖colorPrimary
<style name="Widget.App.Toolbar" parent="Widget.MaterialComponents.Toolbar.Primary">
<item name="materialThemeOverlay">@style/ThemeOverlay.App.Toolbar</item>
</style>
<style name="ThemeOverlay.App.Toolbar" parent="">
<item name="colorPrimary">?attr/colorApp4</item> <!-- HERE -->
</style>
这意味着使用?attr/colorPrimary
的actionMenuTextColor
使用Toolbar
中的colorApp4
。
如果你想更改默认颜色,只需应用:
<style name="ThemeOverlay.App.Toolbar" parent="">
<item name="colorPrimary">?attr/colorApp4</item>
<item name="actionMenuTextColor">......</item>
</style>