Меню "Ящик навигации" Пункт Название Цвет в Android
У меня проблема с изменением Color
заголовка элемента меню в itemTextColor
Navigation Drawer
Я устанавливаю itemTextColor
но он меняет только Color
элементов, а не Title
меню.
Вот мой Activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.DrawerLayout 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:id="@+id/drawer_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
tools:openDrawer="start">
<include
layout="@layout/app_bar_main"
android:layout_width="match_parent"
android:layout_height="match_parent" />
<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:menu="@menu/activity_main_drawer"
app:itemTextColor="#ffffff"
android:background="#283135"
/>
</android.support.v4.widget.DrawerLayout>
activity_main_drawer.xml
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<group android:checkableBehavior="single">
<item
android:id="@+id/nav_home"
android:icon="@mipmap/hospital"
android:title="Home"
/>
<item
android:id="@+id/nav_reminder"
android:icon="@mipmap/alarm"
android:title="Reminders" />
</group>
<item android:title="Tools">
<menu>
<item
android:id="@+id/nav_settings"
android:icon="@mipmap/settings"
android:title="Settings" />
<item
android:id="@+id/nav_help"
android:icon="@mipmap/information"
android:title="Help" />
<item
android:id="@+id/nav_about"
android:icon="@mipmap/team"
android:title="About Us" />
</menu>
</item>
</menu>
Проверьте это:
Ответы
Ответ 1
Чтобы textSize
color
title
элемента Menu
и textSize
Создайте этот способ..
добавьте это в свой файл styles.xml
.
<style name="TextAppearance44">
<item name="android:textColor">#FF0000</item>
<item name="android:textSize">20sp</item>
</style>
теперь в файле activity_main_drawer.xml
укажите attribute
id
для title
.
<item android:title="Tools"
android:id="@+id/tools">
<menu>
<item
android:id="@+id/nav_settings"
android:icon="@mipmap/settings"
android:title="Settings" />
<item
android:id="@+id/nav_help"
android:icon="@mipmap/information"
android:title="Help" />
<item
android:id="@+id/nav_about"
android:icon="@mipmap/team"
android:title="About Us" />
</menu>
</item>
теперь в файле MainActivity.java
используйте этот путь..
NavigationView navigationView = (NavigationView) findViewById(R.id.nav_view);
Menu menu = navigationView.getMenu();
MenuItem tools= menu.findItem(R.id.tools);
SpannableString s = new SpannableString(tools.getTitle());
s.setSpan(new TextAppearanceSpan(this, R.style.TextAppearance44), 0, s.length(), 0);
tools.setTitle(s);
navigationView.setNavigationItemSelectedListener(this);
Он изменит color
ваших tools
на Red
и TextSize
на 20sp
.. Внедрите его..
В моем случае Выход:
Ответ 2
Вы также можете определить новый стиль в styles.xml:
<style name="NavigationView">
<item name="android:textColorSecondary">@color/white</item>
</style>
а затем применить этот стиль в теме NavigationView:
<android.support.design.widget.NavigationView
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="start"
android:theme="@style/NavigationView" />
Ответ 3
Просто добавьте app:itemTextColor="@color/accent
в свой тег представления навигации, как app:itemTextColor="@color/accent
ниже.
<com.google.android.material.navigation.NavigationView
android:id="@+id/nav_view"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:backgroundTint="@color/primary"
android:layout_gravity="start"
android:fitsSystemWindows="true"
app:headerLayout="@layout/nav_header_main"
app:menu="@menu/activity_main_drawer"
app:itemTextColor="@color/accent"/>
Ответ 4
<style name="AppTheme.NavigationView">
<item name="android:textColorSecondary">@color/colorPrimaryDark</item>
<item name="android:textSize">20sp</item>
</style>
Установите textSize, если вы хотите изменить размер заголовка тоже
Ответ 5
Для тех, кто может наткнуться на этот вопрос и не может найти рабочего ответа, как я, добавьте <item name="android:textColorSecondary">@color/white</item>
в ваш файл AppTheme
и AppTheme.NoActionBar
styles.xml, например, так:
<resources>
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
<item name="colorPrimary">@color/colorPrimary</item>
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
<item name="colorAccent">@color/colorAccent</item>
<item name="android:textColorSecondary">@color/white</item>
</style>
<style name="AppTheme.NoActionBar">
<item name="windowActionBar">false</item>
<item name="windowNoTitle">true</item>
<item name="android:textColorSecondary">@color/white</item>
</style>
...
</resources>
Это должно привести к чему-то вроде этого:
Примечание: я сделал текст элемента "Поделиться" или "Отправить" белым, добавив app:itemTextColor="@color/white"
внутри NavigationView
. Полный код NavigationView:
<com.google.android.material.navigation.NavigationView
android:id="@+id/nav_view"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="start"
android:fitsSystemWindows="true"
app:itemTextColor="@color/white"
android:background="#283135"
app:headerLayout="@layout/nav_header_main"
app:menu="@menu/activity_main_drawer"/>
Ответ 6
С NavigationView
, включенным в Библиотеку компонентов материала , вы можете использовать app:itemTextColor
, чтобы определить цвет или селектор, и app:itemTextAppearance
, если вы хотите настроить используемый TextAppearance.
<com.google.android.material.navigation.NavigationView
app:itemTextColor="@color/colorPrimaryDark"
app:itemTextAppearance="@style/...."
...>
Для цвета вы можете использовать селектор, например:
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:color="?attr/colorPrimary" android:state_checked="true"/>
<item android:alpha="0.38" android:color="?attr/colorOnSurface" android:state_enabled="false"/>
<item android:color="?attr/colorOnSurface"/>
</selector>