Изменить цвет значка навигационного ящика в шаблоне по умолчанию для Android Studio
Новый шаблон активности навигационного ящика по умолчанию в Android Studio
![введите описание изображения здесь]()
определяет его названия и значки в файле меню activity_main_drawer
следующим образом:
<group android:checkableBehavior="single">
<item
android:id="@+id/nav_camara"
android:icon="@drawable/ic_action_emo_cool"
android:title="Import" />
<item
android:id="@+id/nav_gallery"
android:icon="@android:drawable/ic_menu_gallery"
android:title="Gallery" />
<item
android:id="@+id/nav_slideshow"
android:icon="@android:drawable/ic_menu_slideshow"
android:title="Slideshow" />
...
В первом примере в моем примере используется красный значок:
![введите описание изображения здесь]()
но когда я запускаю приложение, цвет значка остается черным. Я тестировал это для синих, зеленых, желтых и фиолетовых значков, но результат тот же.
![введите описание изображения здесь]()
Я где-то читал, что панель инструментов должна использовать ThemeOverlay.AppCompat.Dark.ActionBar
, и мое приложение уже использует это в файле styles.xml
:
<resources>
<!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
<!-- Customize your theme here. -->
<item name="colorPrimary">@color/colorPrimary</item>
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
<item name="colorAccent">@color/colorAccent</item>
</style>
<style name="AppTheme.NoActionBar">
<item name="windowActionBar">false</item>
<item name="windowNoTitle">true</item>
</style>
<style name="AppTheme.AppBarOverlay" parent="ThemeOverlay.AppCompat.Dark.ActionBar" />
<style name="AppTheme.PopupOverlay" parent="ThemeOverlay.AppCompat.Light" />
Первоначально я думал, что это имеет какое-то отношение к функции кеша Android Studio, поэтому я сделал недействительным кеш и перезапустил Android Studio без везения.
Ответы
Ответ 1
На основе комментария @MD все, что мне нужно было сделать, это добавить:
app:itemIconTint="@color/my_desired_colour"
to NavigationView
(он находится в файле макета activity_main.xml
). Значение по умолчанию - черный, но вы можете использовать еще более темный оттенок черного с помощью #000000
<android.support.design.widget.NavigationView
android:id="@+id/nav_view"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="start"
android:fitsSystemWindows="true"
app:headerLayout="@layout/nav_header_main"
app:itemIconTint="#000000"
app:menu="@menu/activity_main_drawer" />
Ответ 2
Создайте новый стиль:
<style name="DrawerIconStyle" parent="Widget.AppCompat.DrawerArrowToggle">
<item name="color">@android:color/red</item>
</style>
и n ваша тема:
<item name="drawerArrowStyle">@style/DrawerIconStyle</item>
Ответ 3
Основываясь на комментариях @ojonugwa ochalifu и @MD,
Вы можете достичь, написав app:itemIconTint
, но если вы это сделаете, цвет значка навигационных ящиков также будет изменен. Простое и простое решение, которое я нашел после множества R & D, состоит в том, что вы определили <item name="colorControlNormal">#FFE730</item>
в теме AppBarLayout
, или если вы используете Toolbar
только без AppBarLayout
, вы также можете написать <item name="colorControlNormal">#FFE730</item>
в теме или popupTheme
Toolbar
в вашем xml.
Это также изменит цвет стрелки назад.
Надеюсь, это поможет вам всем, кто сталкивается с этим типом проблемы.
Ответ 4
В моем случае у меня был стиль
<style name="MyToolbarStyle" parent="Theme.AppCompat">
<item name="actionOverflowButtonStyle">@style/ActionButtonOverflowStyle</item>
<item name="drawerArrowStyle">@style/DrawerArrowStyle</item>
</style>
<style name="ActionButtonOverflowStyle">
<item name="android:color">@color/colorPrimary</item>
</style>
<style name="DrawerArrowStyle">
<item name="android:color">@color/colorPrimary</item>
</style>
и применили тему к макету панели приложений, чтобы программно связать цвет не получилось.
Итак, попробуйте удалить все примененные вами стили, если вы не можете изменить цвет значка, а затем попробуйте указанные выше решения.
Ответ 5
Вы должны изменить colorAccent в файле цветов, который вам нужен всегда:
<color name="colorAccent">whichever color required</color>
Это решение сработало для меня
Ответ 6
Добавьте атрибут ниже к android.support.design.widget.NavigationView
app:itemIconTint="@color/color_u_want"