NavigationView是基于MD风格的控件,是一种google官方推出导航界面,可以用listView实现同样的效果。NavigationView的使用十分方便,只用写xml即可,最后在activity中监听按键。
xml文件:
<android.support.design.widget.NavigationView
android:id="@+id/id_nv_menu"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="left"
android:fitsSystemWindows="true"
app:headerLayout="@layout/header_layout"
app:menu="@menu/navigation_view_menu"
/>
然后分别写header_layout和menu文件(注意放在正确的文件夹下)。
header_layout:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="200dp"
android:orientation="vertical">
<ImageView
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:srcCompat="@mipmap/ic_launcher"
android:id="@+id/imageView"
android:layout_gravity="left"/>
<TextView
android:text="Header_view"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/textView"
android:gravity="center"
android:textSize="15sp"/>
</LinearLayout>
navigation_view_menu.xml:
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item android:title="First items">
<menu>
<item
android:id="@+id/nav_fab_test"
android:title="FloatingActionButtonTest"
android:checkable="true"/>
<item
android:id="@+id/nav_messages"
android:title="Messages"
android:checkable="true"/>
<item
android:id="@+id/nav_friends"
android:title="Friends"
android:checkable="true"/>
<item
android:id="@+id/nav_discussion"
android:title="Discussion"
android:checkable="true"/>
</menu>
</item>
<item android:title="Sub items">
<menu>
<item
android:title="Sub item 1"
android:checkable="true"/>
<item
android:title="Sub item 2"
android:checkable="true"/>
</menu>
</item>
</menu>
Activity中的使用:
nav = (NavigationView) findViewById(R.id.id_nv_menu);
nav.setNavigationItemSelectedListener(new NavigationView.OnNavigationItemSelectedListener() {
@Override
public boolean onNavigationItemSelected(MenuItem item) {
switch (item.getItemId()) {
case R.id.nav_fab_test :
....
break;
default:
break;
}
return true;
}
});