Вариант 1) Быстрый и простой способ (только панель инструментов)
Начиная с appcompat-v7-r23, вы можете использовать следующие атрибуты непосредственно в Toolbar
своем стиле:
app:titleTextColor="@color/primary_text"
app:subtitleTextColor="@color/secondary_text"
Если ваш минимальный SDK - 23 и вы используете собственный, Toolbar
просто измените префикс пространства имен на android
.
В Java вы можете использовать следующие методы:
toolbar.setTitleTextColor(Color.WHITE);
toolbar.setSubtitleTextColor(Color.WHITE);
Эти методы принимают цвет int, а не идентификатор цветового ресурса!
Вариант 2) Переопределить стиль и атрибуты темы панели инструментов
макет / xxx.xml
<android.support.v7.widget.Toolbar
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:minHeight="?attr/actionBarSize"
android:theme="@style/ThemeOverlay.MyApp.ActionBar"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
style="@style/Widget.MyApp.Toolbar.Solid"/>
Значения / styles.xml
<style name="Widget.MyApp.Toolbar.Solid" parent="Widget.AppCompat.ActionBar">
<item name="android:background">@color/actionbar_color</item>
<item name="android:elevation" tools:ignore="NewApi">4dp</item>
<item name="titleTextAppearance">...</item>
</style>
<style name="ThemeOverlay.MyApp.ActionBar" parent="ThemeOverlay.AppCompat.ActionBar">
<!-- Parent theme sets colorControlNormal to textColorPrimary. -->
<item name="android:textColorPrimary">@color/actionbar_title_text</item>
</style>
Помогите! Мои значки тоже изменили цвет!
@PeterKnut сообщил, что это влияет на цвет кнопки переполнения, кнопки панели навигации и кнопки возврата. Он также меняет цвет текста SearchView
.
Относительно цвета значков: colorControlNormal
наследуется от
android:textColorPrimary
для темных тем (белое на черном)
android:textColorSecondary
для светлых тем (черный на белом)
Если вы примените это к теме панели действий , вы можете настроить цвет значка.
<item name="colorControlNormal">#de000000</item>
В appcompat-v7 до r23 была ошибка, из-за которой вы также должны были переопределить собственный аналог следующим образом:
<item name="android:colorControlNormal" tools:ignore="NewApi">?colorControlNormal</item>
Помогите! Мой SearchView - беспорядок!
Примечание: возможно, этот раздел устарел.
Поскольку вы используете виджет поиска, который по какой-то причине использует другую стрелку назад (не визуально, технически), чем та, которая включена в appcompat-v7, вам необходимо установить ее вручную в теме приложения . Чертежи библиотеки поддержки окрашиваются правильно. В противном случае он всегда был бы белым.
<item name="homeAsUpIndicator">@drawable/abc_ic_ab_back_mtrl_am_alpha</item>
Что касается текста в режиме поиска ... простого способа нет. Покопавшись в его источнике, я нашел способ перейти к текстовому представлению. Я не тестировал это, поэтому, пожалуйста, дайте мне знать в комментариях, если это не сработало.
SearchView sv = ...; // get your search view instance in onCreateOptionsMenu
// prefix identifier with "android:" if you're using native SearchView
TextView tv = sv.findViewById(getResources().getIdentifier("id/search_src_text", null, null));
tv.setTextColor(Color.GREEN); // and of course specify your own color
Бонус: переопределение стиля и атрибутов темы ActionBar
Соответствующий стиль для панели действий по умолчанию appcompat-v7 будет выглядеть следующим образом:
<!-- ActionBar vs Toolbar. -->
<style name="Widget.MyApp.ActionBar.Solid" parent="Widget.AppCompat.ActionBar.Solid">
<item name="background">@color/actionbar_color</item> <!-- No prefix. -->
<item name="elevation">4dp</item> <!-- No prefix. -->
<item name="titleTextStyle">...</item> <!-- Style vs appearance. -->
</style>
<style name="Theme.MyApp" parent="Theme.AppCompat">
<item name="actionBarStyle">@style/Widget.MyApp.ActionBar.Solid</item>
<item name="actionBarTheme">@style/ThemeOverlay.MyApp.ActionBar</item>
<item name="actionBarPopupTheme">@style/ThemeOverlay.AppCompat.Light</item>
</style>