NavigationView是DesignSupport库提供的控件
引入DesignSupport库
compile 'com.android.support:design:25.0.0'
作为DrawerLayout的第二个子控件
<android.support.design.widget.NavigationView
android:id="@+id/nav_view"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="start"
app:menu="@menu/nav_menu"
app:headerLayout="@layout/nav_header"/>
NavigationView包含两个部分:menu,headerLayout
- headerLayout
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="180dp"
android:padding="10dp"
android:background="@drawable/headerlayout">
</RelativeLayout>
可写任意布局,此处经常被用于展示用户信息
注意height写成180dp比较合适
- menu
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<group android:checkableBehavior="single">
<item
android:id="@+id/nav_tv"
android:icon="@drawable/ic_action_tv"
android:title="TV"/>
<item
android:id="@+id/nav_song"
android:icon="@drawable/ic_action_song"
android:title="SONG"/>
<item
android:id="@+id/nav_word"
android:icon="@drawable/ic_action_word"
android:title="WORD"/>
</group>
</menu>
menu就是普通menu的写法,但要注意这里的group标签表示该组中的item只能单选
设置菜单中的item的监听事件
NavigationView navigationView=(NavigationView)findViewById(R.id.nav_view);
navigationView.setCheckedItem(R.id.nav_tv);
navigationView.setNavigationItemSelectedListener(new NavigationView.OnNavigationItemSelectedListener(){
@Override
public boolean onNavigationItemSelected(MenuItem item){
mDrawerLayout.closeDrawers();
return true;
}
});
setCheckedItem(int id)设置默认选中项
setNavigationItemSelectedListener()设置监听器