Как изменить цвет разделителя в NavigationView?
Я пытаюсь использовать NavigationView для реализации NavigationDrawer. Я добавил разделитель, установив идентификатор группы в меню. Однако я не вижу разделителя. Я думаю, это потому, что цвет разделителя совпадает с цветом фона. Поэтому я хочу изменить цвет разделителя. Но я не могу изменить его. Кто-нибудь может мне помочь?
На снимке экрана, кажется, есть место для разделителя между History
и Settings
, но вы не можете его увидеть.
![enter image description here]()
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:tools="http://schemas.android.com/tools"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/drawer_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:fitsSystemWindows="true"
tools:context=".ui.MapActivity">
<LinearLayout
android:id="@+id/main_content"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<include layout="@layout/toolbar_actionbar" />
<!--main content-->
</LinearLayout>
<android.support.design.widget.NavigationView
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="start"
android:background="@color/navdrawer_background"
app:insetForeground="#4000"
app:itemTextColor="@color/navdrawer_item_text_color"
app:itemIconTint="@color/navdrawer_item_icon_tint"
app:headerLayout="@layout/drawer_header"
app:menu="@menu/drawer"/>
</android.support.v4.widget.DrawerLayout>
drawer.xml
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<group android:id="@+id/group_feature"
android:checkableBehavior="single">
<item android:id="@+id/navdrawer_item_map"
android:checked="true"
android:icon="@drawable/ic_drawer_map"
android:title="@string/navdrawer_item_map"/>
<item android:id="@+id/navdrawer_item_favourite"
android:icon="@drawable/ic_drawer_fav"
android:title="@string/navdrawer_item_fav"/>
<item android:id="@+id/navdrawer_item_history"
android:icon="@drawable/ic_drawer_history"
android:title="@string/navdrawer_item_history"/>
</group>
<group android:id="@+id/group_settings"
android:checkableBehavior="single">
<item android:id="@+id/navdrawer_item_settings"
android:icon="@drawable/ic_drawer_settings"
android:title="@string/navdrawer_item_settings"/>
<item android:id="@+id/navdrawer_item_help"
android:icon="@drawable/ic_drawer_help"
android:title="@string/navdrawer_item_help"/>
<item android:id="@+id/navdrawer_item_about"
android:icon="@drawable/ic_drawer_about"
android:title="@string/navdrawer_item_about"/>
</group>
</menu>
Ответы
Ответ 1
просто примените следующую строку в файле style.xml
<item name="android:listDivider">your_color</item>
Ниже приведена только информация для ваших знаний...
Если вы видели библиотеку поддержки дизайна, они используют следующий макет для seapator NavigationView.
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<View android:layout_width="match_parent"
android:layout_height="1dp"
android:background="?android:attr/listDivider"/>
</FrameLayout>
здесь вы можете увидеть андроид: фон = "? android: attr/listDivider" .
Так что наслаждайтесь...
и вот мой вывод, что я меняю цвет на holo_blue
![enter image description here]()
Ответ 2
Вот лучший и простой способ при использовании меню в виде
<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"
android:theme="@style/ThemeToolbar.NavigationView"
app:itemTextColor="@color/white"
app:itemIconTint="@color/white"
app:headerLayout="@layout/activity_home_nav_header"
app:menu="@menu/activity_home_drawer" />
ThemeToolbar.NavigatinoView
<style name="ThemeToolbar.NavigationView" >
<item name="android:listDivider">@color/white</item>
<item name="android:textColorSecondary">@color/white</item>
</style>
![введите описание изображения здесь]()
Ответ 3
yas вам нужно добавить пустой заголовок в качестве разделителя.
как
<group android:id="@+id/my_id">
<!-- Divider will appear above this item -->
<item ... />
</group>
оригинальный ответ
Ответ 4
Perfeita respostap >
![введите описание изображения здесь]()
<android.support.design.widget.NavigationView
android:id="@+id/activity_principal_nav_view"
android:layout_width="@dimen/size_230"
android:layout_height="match_parent"
android:layout_gravity="start"
android:background="@color/black"
android:fitsSystemWindows="true"
app:insetForeground="@color/white"
app:menu="@menu/settings_menu"
app:itemTextColor="@color/white"
app:itemIconTint="@color/white"
app:headerLayout="@layout/settings_menu_header"
android:theme="@style/NavigationDrawerStyle"/>
Ответ 5
<!-- 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>
<item name="android:textColorPrimary">@color/menu_text_color</item>
<item name="android:textColorSecondary">@color/menu_text_color</item>
</style>
textColorPrimary изменяет цвет заголовка.