工具栏默认样式和导航图标

时间:2016-07-04 09:52:39

标签: android toolbar android-appcompat

我在Toolbar内有AppBarLayout。 以下是两种视图的XML:

<android.support.design.widget.AppBarLayout
    android:id="@+id/appbarlayout"
    android:layout_height="wrap_content"
    android:layout_width="match_parent"
    android:theme="@style/App.ThemeOverlay.Toolbar">

    <android.support.v7.widget.Toolbar
        android:id="@+id/toolbar"
        android:layout_height="?attr/actionBarSize"
        android:layout_width="match_parent"/>

</android.support.design.widget.AppBarLayout>

主题为:

<style name="App.ThemeOverlay.Toolbar" parent="ThemeOverlay.AppCompat.Dark.ActionBar"/>

主题适用于Activity

<style name="App.Theme" parent="Theme.AppCompat.Light.NoActionBar">
    <item name="colorPrimary">@color/colorPrimary</item>
    <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
    <item name="colorAccent">@color/colorAccent</item>
    <item name="android:windowBackground">@android:color/white</item>
</style>

现在,我想为工具栏应用自定义titleTextAppearance

我知道我可以在我的布局XML中使用app:titleTextAppearance,但我想从主题配置它,以便我的应用的每个工具栏都具有相同的样式,而不会在每个设置中设置文本外观布局。

在对AppCompat源代码进行了一些挖掘之后,我发现Toolbar使用当前主题的toolbarStyle作为默认主题。

此样式的默认值为Widget.AppCompat.ActionBar

所以我的第一个猜测是在我的主题叠加层中覆盖此样式,并更改此新样式中的titleTextAppearance

<style name="App.ThemeOverlay.Toolbar" parent="ThemeOverlay.AppCompat.Dark.ActionBar">
    <item name="toolbarStyle">@style/App.Style.Toolbar</item>    
</style>

<style name="App.Style.Toolbar" parent="Widget.AppCompat.ActionBar">
    <item name="titleTextAppearance">@style/App.TextAppearance.Toolbar.Title</item>
</style>

<style name="App.TextAppearance.Toolbar.Title" parent="TextAppearance.Widget.AppCompat.Toolbar.Title">
    <item name="android:textColor">#00FF00</item> (this is some green)
    <item name="android:textAllCaps">true</item>
</style>

这实际上覆盖了我的工具栏的titleTextAppearance,但它也打破了导航图标:

Weasyprint

我的配置中断了导航图标有什么问题?

为了记录,我尝试删除主题叠加层的toolbarStyle,并直接在工具栏style="@style/App.Style.Toolbar"的布局XML中使用。

这正确地应用了标题文字外观并且没有破坏导航图标,但这不是最佳的,因为我必须将样式应用于我的应用的每个工具栏,这就是我和我#39;我试图从一开始就避免。

感谢您的帮助, 皮尔

1 个答案:

答案 0 :(得分:5)

您的默认样式应该是Widget.AppCompat.Toolbar,而不是Widget.AppCompat.ActionBar。之后它会正常工作。