NavigationView 子菜单问题
在Android 5.0之后,Google推出了Material Design兼容库,在Material Design的兼容库中,有个用的比较多的控件就是NavigationView
。在我们平时使用过程中,对于NavigationView
的一些小细节可能也并没有过多的关注,所以就导致我们在遇到特殊需求的时候无从下手,那么在这里我就简单记录一下使用NavigationView
的一些小坑,暂时可能也并没有遇到很多的坑,如果以后遇到的话会不定时更新。
NavigationView基本使用
有很多人对于NavigationView
的基本使用还是比较了解的, 那么我这里推荐一种非常偷懒的方法,就是我们在Android Studio
中新建Activity
时可以直接进行如下操作:
在选择了Navigation Drawer Activity
之后会出现如下界面:
然后点击Finish
就可以完成一个最基础的带有NavigationView
的Activity
创建,创建之后就可以在原有的基础上进行修改了,这样也是非常的方便。
NavigationView Menu的设置
Menu的第一种布局设置
最基本的Menu
的设置就是每行一个项目。在menu
中的代码是这样的:
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item
android:id="@+id/nav_camera"
android:icon="@drawable/ic_menu_camera"
android:title="Import"/>
<item
android:id="@+id/nav_gallery"
android:icon="@drawable/ic_menu_gallery"
android:title="Gallery"/>
<item
android:id="@+id/nav_slideshow"
android:icon="@drawable/ic_menu_slideshow"
android:title="Slideshow"/>
<item
android:id="@+id/nav_manage"
android:icon="@drawable/ic_menu_manage"
android:title="Tools"/>
<item
android:id="@+id/nav_share"
android:icon="@drawable/ic_menu_share"
android:title="Share"/>
<item
android:id="@+id/nav_send"
android:icon="@drawable/ic_menu_send"
android:title="Send"/>
</menu>
实际效果是这样的:
normal menu.png通过上面的图片我们可以看到,这样设置之后,每个item
都是独立的,各占一行,每一行代表着一个操作。
Menu的第二种布局设置
子菜单的设置是这样的:
<?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_camera"
android:icon="@drawable/ic_menu_camera"
android:title="Import"/>
<item
android:id="@+id/nav_gallery"
android:icon="@drawable/ic_menu_gallery"
android:title="Gallery"/>
<item
android:id="@+id/nav_slideshow"
android:icon="@drawable/ic_menu_slideshow"
android:title="Slideshow"/>
<item
android:id="@+id/nav_manage"
android:icon="@drawable/ic_menu_manage"
android:title="Tools"/>
</group>
<item android:title="Communicate">
<menu>
<item
android:id="@+id/nav_share"
android:icon="@drawable/ic_menu_share"
android:title="Share"/>
<item
android:id="@+id/nav_send"
android:icon="@drawable/ic_menu_send"
android:title="Send"/>
</menu>
</item>
<item
android:title="about">
<menu>
<item
android:id="@+id/nav_about"
android:icon="@drawable/ic_history"
android:title="about"/>
</menu>
</item>
</menu>
设置之后的效果是这样的:
group menu.png通过这种设置分组之后,我们可以发现,每个组是一起的,是通过group
将同一个组的item
包裹起来,组内的item
可能会相互影响,这取决于你设置属性android:checkableBehavior
的值。而且在上面的图片中我们也可以发现一个小的细节,就是我们组和组之间有一条小横线隔开了,有点类似于我们在ListView
中设置的divider
属性。
Menu的第三种布局设置
那么在我们实际的开发过程中,有时候我们需要把第一种和第二种结合起来,也就是说呈现出下图中的效果:
group menu special.png细心的朋友可能已经看出来第三种和第二种的区别。
第二种的布局结果是每个group
下有一个title
,然后在title
下面才是我们的子item
第三种是直接每个group
下就是子item
并没有第二种中出现的title
很显然在某些情况下,我们的开发需求需要像第三种这样简约但是不简单的Navigation Menu
还是先来看看我们第三种布局的menu
文件:
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<group
android:id="@+id/nav_group_normal"
android:checkableBehavior="single">
<item
android:id="@+id/nav_camera"
android:icon="@drawable/ic_menu_camera"
android:title="Import"/>
<item
android:id="@+id/nav_gallery"
android:icon="@drawable/ic_menu_gallery"
android:title="Gallery"/>
<item
android:id="@+id/nav_slideshow"
android:icon="@drawable/ic_menu_slideshow"
android:title="Slideshow"/>
<item
android:id="@+id/nav_manage"
android:icon="@drawable/ic_menu_manage"
android:title="Tools"/>
</group>
<group
android:id="@+id/nav_commnunicate"
android:title="Communicate">
<item
android:id="@+id/nav_share"
android:icon="@drawable/ic_menu_share"
android:title="Share"/>
<item
android:id="@+id/nav_send"
android:icon="@drawable/ic_menu_send"
android:title="Send"/>
</group>
<group
android:id="@+id/nav_about_group">
<item
android:title="about">
<item
android:id="@+id/nav_about"
android:icon="@drawable/ic_history"
android:title="about"/>
</item>
</group>
</menu>
这个布局文件就是用group
包裹起每个组的item
,有点类似第二种布局,但是最关键的地方就是要为每一个group
设置一个id
,设置完成之后就可以得到第三种布局的效果。