【问题标题】:How can I change separator color in NavigationView?如何更改 NavigationView 中的分隔符颜色?
【发布时间】:2015-08-24 04:46:25
【问题描述】:

我正在尝试使用 NavigationView 来实现 NavigationDrawer。我通过在菜单中设置组 ID 添加了分隔符。但是我看不到分隔符。我猜这是因为分隔符颜色与背景相同。所以我想改变分隔符的颜色。但我没有办法改变它。谁能帮帮我?

在截图中,HistorySettings 之间似乎有一个分隔空间,但你看不到它。

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>

抽屉.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>

【问题讨论】:

    标签: android navigation-drawer navigationview android-navigationview


    【解决方案1】:

    只需在 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" .. 所以享受... 这是我的输出,我将颜色更改为 holo_blue

    【讨论】:

    • 以编程方式进行的任何方式?
    • @ElYeante 不,不幸的是,没有以编程方式执行此操作的选项......可能在未来的库中它会出现......
    • 在哪里应用下面的行 your_color
    • 到您的主要风格,例如。 在应用主题中
    • 这是一个糟糕的解决方案。如果您只想为导航视图设置它,那么它根本不起作用,如果您为活动设置它 - 它可以工作,但它会更改整个活动中的分隔线颜色,对于您的每个列表。
    【解决方案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>
    

    【讨论】:

    • 什么是主题工具栏?
    • 它是应用程序主题的任何名称,这里它只是添加到与 ThemeToolbar 关联的 NavigationView 中,因此写为 ThemeToolbar.NavigationView。 NavigationView 可以自己写。
    • 我在哪里添加了我已经使用的样式并使用相同但无法放置分隔符你能建议我@O'one
    • 只需将样式添加到您的值文件中
    • 这个@qkx你需要什么帮助
    【解决方案3】:

    在您的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>
    

    【讨论】:

      【解决方案4】:
      <!-- 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 改变标题的颜色。

      【讨论】:

        【解决方案5】:

        完美答案:

        <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"/>
        

        【讨论】:

          猜你喜欢
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 2019-12-18
          • 1970-01-01
          • 1970-01-01
          相关资源
          最近更新 更多