View—NavigationView學(xué)習(xí)

NavigationView是什么

[站外圖片上傳中...(image-e0f5ab-1511429906836)]

導(dǎo)航View,一般我們用它和DrawerLayout實(shí)現(xiàn)抽屜式導(dǎo)航設(shè)計

分為兩部分

  1. 上面一部分叫做HeaderLayout
  2. 下面的那些點(diǎn)擊項都是menu

怎么用

  1. app:headerLayout—指定頭部的布局
  2. app:menu—指定下面的點(diǎn)擊項
  3. 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


  1. menu部分的菜單層級
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容