如何在NavigationDrawer中创建标签指示器?

时间:2019-07-10 03:50:19

标签: android navigation-drawer

如何创建像这样的导航绘图标签指示器? NavigationDrawer类是否具有类似TabLayout的指示器?

enter image description here

1 个答案:

答案 0 :(得分:1)

您可以定义带有左边框的自定义图形并将其设置为所选项目的背景。请按照以下步骤操作

  

第1步:在可绘制对象中定义带有左边框(selected_item.xml)的可绘制对象

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item>
    <shape android:shape="rectangle">
        <solid android:color="#000000" />
    </shape>
</item>
<item android:left="2dp">
    <shape android:shape="rectangle">
        <solid android:color="#FF0000" />
    </shape>
</item>
</layer-list>
  

第2步:在可绘制对象中定义一个选择器(navi_selector.xml)

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">

    <item android:state_checked="true" android:drawable="@drawable/selected_item"/>
    <item android:state_pressed="true" android:drawable="#000000"/>

</selector>
  

第3步:为app:itemBackground设置navi_selector

 <android.support.design.widget.NavigationView
        app:itemTextColor="@android:color/white"
        android:fitsSystemWindows="true"
        android:id="@+id/nav_view"
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
        android:layout_gravity="start"
        app:menu="@menu/activity_main_drawer"
        android:background="#000000"
        app:itemBackground="@drawable/navi_selector"/>