如何使用AppCompat更改ActionBar的动作文本颜色

时间:2014-03-26 04:42:29

标签: android android-actionbar android-actionbar-compat

我正在尝试更改操作栏上操作菜单项的文本颜色。使用app compat。溢出图标也不会改变。这是我自定义样式的styles.xml文件。

RES /值/ styles.xml

<style name="AppTheme" parent="@style/Theme.AppCompat.Light">
    <!-- Setting values in the default namespace affects API levels 7-13 -->
    <item name="actionBarStyle">@style/MyStyledActionBar</item>
</style>

<style name="MyStyledActionBar" parent="@style/Widget.AppCompat.Light.ActionBar">
    <!-- Setting values in the default namespace affects API levels 7-13 -->
    <item name="background">@drawable/bg_action_bar</item>
    <item name="titleTextStyle">@style/MyActionBarTitleText</item>
    <item name="actionMenuTextAppearance">@style/MyActionBarMenuText</item>
    <item name="actionMenuTextColor">@style/MyActionBarMenuText</item>
    <item name="actionOverflowButtonStyle">@style/MyActionButtonOverFlow</item>
</style>

<style name="MyActionBarTitleText" parent="@style/TextAppearance.AppCompat.Widget.ActionBar.Title">
    <item name="android:textColor">@color/font_half_white</item>
</style>

<style name="MyActionBarMenuText" parent="@style/TextAppearance.AppCompat.Widget.ActionBar.Menu">
    <item name="android:textColor">@color/font_half_white</item>
</style>

<style name="MyActionButtonOverFlow" parent="@style/Widget.AppCompat.Light.ActionButton.Overflow">
    <item name="android:src">@drawable/ic_action_search</item>
</style>

RES /值-14 / styles.xml

<style name="AppTheme" parent="@style/Theme.AppCompat.Light">
    <!-- Setting values in the android namespace affects API levels 14+ -->
    <item name="android:actionBarStyle">@style/MyStyledActionBar</item>
</style>

<style name="MyStyledActionBar" parent="@style/Widget.AppCompat.Light.ActionBar">
    <!-- Setting values in the android namespace affects API levels 14+ -->
    <item name="android:background">@drawable/bg_action_bar</item>
    <item name="android:titleTextStyle">@style/MyActionBarTitleText</item>
    <item name="android:actionMenuTextAppearance">@style/MyActionBarMenuText</item>
    <item name="android:actionMenuTextColor">@style/MyActionBarMenuText</item>
    <item name="android:actionOverflowButtonStyle">@style/MyActionButtonOverFlow</item>
</style>

<style name="MyActionBarTitleText" parent="@style/TextAppearance.AppCompat.Widget.ActionBar.Title">
    <item name="android:textColor">@color/font_half_white</item>
</style>

<style name="MyActionBarMenuText" parent="@style/TextAppearance.AppCompat.Widget.ActionBar.Menu">
    <item name="android:textColor">@color/font_half_white</item>
</style>

<style name="MyActionButtonOverFlow" parent="@style/Widget.AppCompat.Light.Base.ActionButton.Overflow">
    <item name="android:src">@drawable/ic_action_search</item>
</style>

RES / colors.xml     #F3F3F3

文字颜色仍为黑色,不会变为白色。是否有人成功更改了操作菜单文本颜色。请提出一些见解。我正在测试4.4 Nexus5设备。

enter image description here

3 个答案:

答案 0 :(得分:16)

使用

<item name="android:actionMenuTextColor">@color/font_half_white</item>
// added style directly 

而不是

<item name="android:actionMenuTextColor">@style/MyActionButtonStyle</item>
res/values-14/styles.xml

中的

res/values/styles.xml

<item name="actionMenuTextColor">@color/font_half_white</item>

我使用红色进行测试。请参阅快照中的红色操作菜单项目主页

enter image description here

编辑:

完整代码

res/values-14/styles.xml

<resources>

    <!--
        Base application theme for API 14+. This theme completely replaces
        AppBaseTheme from BOTH res/values/styles.xml and
        res/values-v11/styles.xml on API 14+ devices.
    -->
    <style name="AppBaseTheme" parent="Theme.AppCompat.Light.DarkActionBar">
        <!-- API 14 theme customizations can go here. -->
            <item name="android:actionMenuTextColor">@color/red</item>
    </style>

</resources>

然后在res / values / stles.xml

  <resources>
    <style name="AppBaseTheme" parent="Theme.AppCompat.Light">
        <!-- API 11 theme customizations can go here. -->
         <item name="actionMenuTextColor">@color/red</item>
    </style>

</resources>

在清单

android:theme =“@ style / AppBaseTheme”&gt;

另一个快照

enter image description here

答案 1 :(得分:1)

您可以使用它来更改操作栏的文本,而不管您的appcompat版本。给出所需颜色的十六进制代码并将其添加到onCreate()中。

actionBar.setTitle(Html.fromHtml("<font color='#ff0000'>Some Title</font>"));

答案 2 :(得分:0)

  1. 检查您的布局xml文件中是否有android:theme<Toolbar>指定的属性,该属性优先于主题

  2. 覆盖您在互联网上随处指出的actionBarStyle属性。