【问题标题】:Android ToolBar can change back button color but not title colorAndroid ToolBar 可以更改后退按钮颜色但不能更改标题颜色
【发布时间】:2018-11-23 15:48:12
【问题描述】:

我想将我的 Toolbar 标题颜色更改为蓝色。它保持白色。我可以设置后退按钮,但不能设置标题颜色 - 我错过了什么吗?

我尝试在 3 个不同的地方进行更改:

活动

    Toolbar toolbar = (Toolbar) findViewById(R.id.detail_toolbar);
    toolbar.setTitleTextColor(0xff00ff99);
    setSupportActionBar(toolbar);

activity.xml

        <android.support.v7.widget.Toolbar
            android:id="@+id/detail_toolbar"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            app:theme="@style/ToolBarStyle"
            android:background="@color/colorPrimaryDark"
            android:titleTextColor="@android:color/holo_red_dark"
            app:subtitleTextColor="@color/colorPrimaryDark"
            app:layout_collapseMode="pin"

            app:popupTheme="@style/ToolBarStyle" />

v21 样式.xml

    <!-- ToolBar -->
    <style name="ToolBarStyle" parent="Theme.AppCompat">

    <item name="titleTextColor">@color/colorPrimaryDark</item>
    <item name="android:titleTextColor">@color/colorPrimaryDark</item>
    <item name="android:textColorPrimary">@color/colorPrimaryDark</item>
    <item name="android:textColorSecondary">@color/colorPrimaryDark</item>
    <item name="actionMenuTextColor">@color/colorPrimaryDark</item>
    <item name="android:textColor">@color/colorPrimaryDark</item>
</style>

styles.xml

    <style name="ToolBarStyle" parent="Theme.AppCompat">
    <item name="titleTextColor">@color/colorPrimaryDark</item>
    <item name="android:titleTextColor">@color/colorPrimaryDark</item>
    <item name="android:textColorPrimary">@color/colorPrimaryDark</item>
    <item name="android:textColorSecondary">@color/colorPrimaryDark</item>
    <item name="actionMenuTextColor">@color/colorPrimaryDark</item>
    <item name="android:textColor">@color/colorPrimaryDark</item>
</style>

我错过了什么? 无论如何它都保持白色。我什至浏览了整个项目中对 #ffffff 的 150 次引用,但那里没有引用工具栏。

targetSdk 26,在 Android 7.1.1 上运行

【问题讨论】:

    标签: android toolbar android-xml android-appcompat


    【解决方案1】:

    像这样创建自定义Toolbar

    toolbar_layout.xml

    <?xml version="1.0" encoding="utf-8"?>
    <android.support.design.widget.AppBarLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        xmlns:tools="http://schemas.android.com/tools"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:fitsSystemWindows="false"
        android:theme="@style/AppTheme.AppBarOverlay">
    
        <android.support.v7.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="?android:attr/actionBarSize"
            android:background="@android:color/backgroundColor"
            app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
            app:theme="@style/Base.Theme.AppCompat.Light.DarkActionBar">
    
            <TextView
                android:id="@+id/toolbar_title"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:textColor="@color/blue"/>
    
        </android.support.v7.widget.Toolbar>
    </android.support.design.widget.AppBarLayout>
    

    将它包含在你的布局中:

    <include layout="@layout/toolbar_layout"/>
    

    在活动的 onCreate 方法中使用它:

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_new_card);
    
        Toolbar toolbar = findViewById(R.id.toolbar);
        TextView toolbarTitle = findViewById(R.id.toolbar_title);
    
        setSupportActionBar(toolbar);
        if (getSupportActionBar() != null)
            getSupportActionBar().setDisplayShowTitleEnabled(false);
    
        toolbarTitle.setText("Your title");
        ...
    }
    

    希望它会有所帮助。

    【讨论】:

      【解决方案2】:

      尝试改变这一点:

      android:titleTextColor="@android:color/holo_red_dark"

      到:

      app:titleTextColor="@android:color/holo_red_dark"

      在您的 activity.xml android.support.v7.widget.Toolbar 部分中。

      【讨论】:

      • 应该,在styles.xml中也不需要这个。尝试删除此行: @color/colorPrimaryDark 某些样式定义会干扰其他样式。应该删除样式中不必要的项目
      • 嘿伙计,我现在发现了问题。一分钟后写答案
      • 我已经添加了我的答案。非常感谢您的支持,我的朋友,请继续加油!
      【解决方案3】:

      好的,所以我通过逐字堆栈跟踪我的代码找到了答案。

      我有一个返回不同片段的 PagerAdapter。我认为每个Activity 都对Tabbar 负责(这是每个不同选项卡的主/详细模式),因为我必须设置setSupportActionBar() 之类的东西,我在随后的Activities 中完成了这些设置。

      Stacktracing 我的代码,我意识到有一个 CollapsingToolbarLayout 正在通过视图 ID 找到。这是我设置栏标题的地方。从那里,我没有找到任何 title 属性,但我让自动完成将我带到 setCollapsedTitleTextColorsetExpandedTitleColor

      所以虽然getColor() 部分已被弃用,但它是

      bar.setCollapsedTitleTextColor(getResources().getColor(R.color.colorPrimaryDark));
      bar.setExpandedTitleColor(getResources().getColor(R.color.colorPrimaryDark));
      

      仍然不知道为什么我设置的所有其他地方都没有成功,但很高兴它现在可以正常工作。

      【讨论】:

        【解决方案4】:

        在 Layout 文件中使用 Toolbar 作为 AppBarLayout 的子布局

        <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
            xmlns:app="http://schemas.android.com/apk/res-auto"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:orientation="vertical">
        <android.support.design.widget.AppBarLayout
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:theme="@style/AppTheme.AppBarOverlay">
        
                <android.support.v7.widget.Toolbar
                    android:id="@+id/toolbar"
                    android:layout_width="match_parent"
                    android:layout_height="?attr/actionBarSize"
                    android:background="?attr/colorPrimary"
                    app:popupTheme="@style/AppTheme.PopupOverlay">
        
                </android.support.v7.widget.Toolbar>
            </android.support.design.widget.AppBarLayout>
        </LinearLayout>
        

        样式.xml

        <style name="AppTheme.AppBarOverlay" parent="ThemeOverlay.AppCompat.Dark.ActionBar" />
        <style name="AppTheme.PopupOverlay" parent="ThemeOverlay.AppCompat.Light" />
        

        MainActivity 内部

         @Override
            protected void onCreate(Bundle savedInstanceState) {
                super.onCreate(savedInstanceState);
                setContentView(R.layout.activity_main);
               Toolbar  toolbar = (Toolbar) findViewById(R.id.toolbar);
                setSupportActionBar(toolbar);
        }
        

        【讨论】:

          猜你喜欢
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 2018-01-12
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          相关资源
          最近更新 更多