NavigationView是什么
[站外圖片上傳中...(image-e0f5ab-1511429906836)]
導(dǎo)航View,一般我們用它和DrawerLayout實(shí)現(xiàn)抽屜式導(dǎo)航設(shè)計
分為兩部分
- 上面一部分叫做HeaderLayout
- 下面的那些點(diǎn)擊項都是menu
怎么用
- app:headerLayout—指定頭部的布局
- app:menu—指定下面的點(diǎn)擊項
- android:layout_gravity—指定滑動方向
<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.DrawerLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/drawer_layout"
android:layout_width="match_parent"
android:layout_height="match_parent">
<!--主頁面布局內(nèi)容 -->
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/app_name3"/>
</LinearLayout>
<!--側(cè)滑菜單的布局 -->
<android.support.design.widget.NavigationView
android:id="@+id/navigation"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="start"
app:headerLayout="@layout/drawer_header"
app:menu="@menu/menu_nav" />
</android.support.v4.widget.DrawerLayout>
頭部布局 —drawer_header.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:fitsSystemWindows="false"
android:layout_width="match_parent"
android:layout_height="150dp"
android:background="@mipmap/nav_header"
>
<ImageView
android:layout_marginBottom="10dp"
android:layout_marginLeft="20dp"
android:layout_width="50dp"
android:layout_height="50dp"
android:id="@+id/iv_user_photo"
android:src="@mipmap/nav_photo"
android:layout_above="@+id/tv_login"/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:textSize="12sp"
android:text="點(diǎn)擊頭像登錄,開啟更多功能"
android:textColor="@color/white"
android:padding="8dp"
android:layout_marginLeft="20dp"
android:layout_marginBottom="20dp"
android:gravity="center"
android:id="@+id/tv_login"
android:layout_alignParentBottom="true"/>
</RelativeLayout>
菜單項—menu_nav.xml
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<group android:checkableBehavior="single">
<item android:title="首頁" android:id="@+id/mn_home" android:checked="true" android:icon="@mipmap/home"/>
<item android:title="我的信息" android:id="@+id/mn_information" android:icon="@mipmap/myinformation"/>
<item android:title="猜你喜歡" android:id="@+id/mn_guess" android:icon="@mipmap/guess_like"/>
<item android:title="電影" android:id="@+id/mn_movie" android:icon="@mipmap/movie"/>
<item android:title="音樂" android:id="@+id/mn_music" android:icon="@mipmap/music"/>
</group>
<item android:title="更多" android:id="@+id/mn_more">
<menu>
<item android:title="關(guān)于" android:id="@+id/mn_about" android:icon="@mipmap/about"/>
<item android:title="注銷" android:id="@+id/mn_out" android:icon="@mipmap/out"/>
</menu>
</item>
</menu>
監(jiān)聽點(diǎn)擊事件
通過 setNavigationItemSelectedListener 來給菜單添加點(diǎn)擊事件
navigation.setNavigationItemSelectedListener(new NavigationView.OnNavigationItemSelectedListener() {
@Override
public boolean onNavigationItemSelected(@NonNull MenuItem item) {
switch(item.getItemId()){
case R.id.mn_home:
Toast.makeText(MainActivity.this, "home", Toast.LENGTH_SHORT).show();
break;
case R.id.mn_movie:
Toast.makeText(MainActivity.this, "movie", Toast.LENGTH_SHORT).show();
break;
default:
break;
}
return true;
}
});
TODO
- menu部分的菜單層級