第三十二篇-NavigationView導航抽屜的使用


效果圖:

導航抽屜所用到的布局是DrawerLayout,可以在里面添加一個線性布局和TextView組件,TextView組件的文本信息就是"主頁面"。然后和線性布局平行添加一個導航抽屜NavigationView

設置導航抽屜在左邊,並且添加它的頭部以及菜單

android:layout_gravity="left"
app:headerLayout="@layout/head"
app:menu="@menu/menu_main"

所以現在建立一個頭部layout和一個菜單layout

head.xml

menu_main.xml

group是將其放在一個組里面,所以可以注意到效果圖里面item1和item2下面都有條橫線,目的是將其隔開。還可以為每個item添加圖標

android:icon="@mipmap/ic_launcher"

圖標可以自己選擇圖片。如果要讓圖標顯示出來,需要在MainActivity中設置

navigationView.setItemIconTintList(null);

如果要設置頭部的單擊事件,可以

View view1=navigationView.getHeaderView(0);
ImageView imageView=view1.findViewById(R.id.imageView);
imageView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Toast.makeText(MainActivity.this,"您選擇的是頭部組件",Toast.LENGTH_SHORT).show();
}
});

如果想要設置選擇菜單事件的話,可以

final TextView textView=view1.findViewById(R.id.textView3);
navigationView.setNavigationItemSelectedListener(new NavigationView.OnNavigationItemSelectedListener() {
@Override
public boolean onNavigationItemSelected(@NonNull MenuItem item) {
textView.setText("您選擇的是: "+item.getTitle().toString());
return true;
}
});

效果已經完成,附上代碼

main_activity.xml

<?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"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#fffff0"
    tools:context=".MainActivity">

    <LinearLayout
        android:gravity="center"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="horizontal">

        <TextView
            android:textSize="56dp"
            android:id="@+id/textView"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="主界面"
            />
    </LinearLayout>

    <android.support.design.widget.NavigationView
        android:id="@+id/navi"
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
        android:layout_gravity="left"
        app:headerLayout="@layout/head"
        app:menu="@menu/menu_main" />

</android.support.v4.widget.DrawerLayout>
View Code

 

head.xml

<?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:orientation="vertical"
    android:gravity="center"
    android:layout_height="match_parent">

    <ImageView
        android:id="@+id/imageView"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:srcCompat="@mipmap/ic_launcher" />

    <TextView
        android:id="@+id/textView2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="抽屜組件的應用" />

    <TextView
        android:layout_marginTop="20dp"
        android:id="@+id/textView3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="" />
</LinearLayout>
View Code

 

menu_main.xml

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
    <group android:id="@+id/g1">
    <item
        android:id="@+id/item1"
        android:title="收藏"
        android:icon="@mipmap/ic_launcher"
        >

    </item>
    </group>

    <group android:id="@+id/g2">
    <item
        android:id="@+id/item2"
        android:title="錢包"
        android:icon="@mipmap/ic_launcher"
        >

    </item>
    </group>

    <item
        android:id="@+id/item3"
        android:title="相冊"
        android:icon="@mipmap/ic_launcher"
        >

    </item>

    <item
        android:id="@+id/item4"
        android:title="文件"
        android:icon="@mipmap/ic_launcher"
        >

    </item>

</menu>
View Code

 

MainActivity.java

package com.example.aimee.navigationviewtest;

import android.support.annotation.NonNull;
import android.support.design.widget.NavigationView;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.MenuItem;
import android.view.View;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity {
    NavigationView navigationView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        navigationView=findViewById(R.id.navi);
        navigationView.setItemIconTintList(null);
        View view1=navigationView.getHeaderView(0);
        ImageView imageView=view1.findViewById(R.id.imageView);
        imageView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Toast.makeText(MainActivity.this,"您選擇的是頭部組件",Toast.LENGTH_SHORT).show();
            }
        });
        final TextView textView=view1.findViewById(R.id.textView3);
        navigationView.setNavigationItemSelectedListener(new NavigationView.OnNavigationItemSelectedListener() {
            @Override
            public boolean onNavigationItemSelected(@NonNull MenuItem item) {
                textView.setText("您選擇的是: "+item.getTitle().toString());
                return true;
            }
        });
    }
}
View Code

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM