Android 如何更改NavigationView中的分隔符颜色?
我正在尝试使用NavigationView实现NavigationDrawer。我通过在菜单中设置组id添加了分隔符。但是我看不到分隔符。我猜这是因为分隔符颜色与背景相同。所以我想更改分隔符的颜色。但我没有办法改变它。有人能帮我吗 在屏幕截图中,它似乎在Android 如何更改NavigationView中的分隔符颜色?,android,navigation-drawer,navigationview,android-navigationview,Android,Navigation Drawer,Navigationview,Android Navigationview,我正在尝试使用NavigationView实现NavigationDrawer。我通过在菜单中设置组id添加了分隔符。但是我看不到分隔符。我猜这是因为分隔符颜色与背景相同。所以我想更改分隔符的颜色。但我没有办法改变它。有人能帮我吗 在屏幕截图中,它似乎在历史和设置之间有一个分隔符,但您看不到它 activity_main.xml <?xml version="1.0" encoding="utf-8"?> <android.support.v4.widget.DrawerLa
历史
和设置
之间有一个分隔符,但您看不到它
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>
只需在style.xml上应用以下行
<item name="android:listDivider">your_color</item>
你的颜色
以下仅是供您参考的信息…
如果您看过设计支持库。。他们正在为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:background=“?android:attr/listDivider”。。
所以享受。。。
这是我的输出,我把颜色改成全息蓝
使用菜单作为视图时,这里是最简单的方法
<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" />
完美答案:
@颜色/原色
@颜色/原色暗
@颜色/颜色重音
@颜色/菜单\文本\颜色
@颜色/菜单\文本\颜色
textColorPrimary更改标题的颜色。在styles.xml中创建样式。在android:listDivider中输入您的首选颜色
<style name="NavigationView" parent="Base.Theme.AppCompat">
<item name="android:listDivider">@color/text_lightgray</item>
</style>
@颜色/文字为浅灰色
将样式引用为导航视图的主题:
<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="false"
android:theme="@style/NavigationView"
app:headerLayout="@layout/nav_header"
app:menu="@menu/drawer_view"
app:itemTextColor="@color/text_white"/>
最后,确保菜单中的组具有唯一的ID。如果您的组没有id属性,这将不起作用
<group android:checkableBehavior="single"
android:id="@+id/group1">
<item
android:id="@+id/item1"
android:title="@string/item1" />
</group>
<group android:checkableBehavior="single"
android:id="@+id/group2">
<item
android:id="@+id/item2"
android:title="@string/item2" />
</group>
有什么编程方式吗?@ElYeante没有遗憾的是,没有编程方式的选择。。。可能会在未来的库中,它会出现。在应用程序中,这是一个糟糕的解决方案。如果您只想将其设置为导航视图,那么它根本不起作用,如果您将其设置为活动-它可以工作,但它会更改整个活动中的分隔符颜色,对于列表中的每个项目。主题工具栏是什么?它是应用程序主题的任何名称,在这里它仅添加到与主题工具栏相关联的导航视图中,因此写为主题工具栏。导航视图。NavigationView可以自己编写。如果我添加了我所熟悉的样式,并且使用了相同的样式,但无法放置分隔符,您可以建议我@O'one将样式添加到您的值文件styles.xml中吗?如果这是您给@mhanazyed的名称,或者如果您仍然在这方面提供帮助,您可以共享您的代码@qkx需要帮助吗
<style name="NavigationView" parent="Base.Theme.AppCompat">
<item name="android:listDivider">@color/text_lightgray</item>
</style>
<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="false"
android:theme="@style/NavigationView"
app:headerLayout="@layout/nav_header"
app:menu="@menu/drawer_view"
app:itemTextColor="@color/text_white"/>
<group android:checkableBehavior="single"
android:id="@+id/group1">
<item
android:id="@+id/item1"
android:title="@string/item1" />
</group>
<group android:checkableBehavior="single"
android:id="@+id/group2">
<item
android:id="@+id/item2"
android:title="@string/item2" />
</group>