DrawerLayout 实现了侧滑菜单效果的布局,它显示在屏幕的最左侧(右侧),默认情况下是隐藏的,当用户用手指从屏幕左侧向右侧滑动(右侧向左侧滑动)时该组件将显示,单击该布局外侧或者向原来的方向滑动时该组件消失。
见下图演示:
DrawerLayout 是一个布局文件管理器,在这个布局当中允许放入 3 个组件或者是布局,第 1 个用于显示在主屏幕当中,第 2,3 个用于显示滑动菜单中的内容,在设置滑动菜单实现的内容时在该组件或布局中需要添加 android:layout_gravity=”start”(左侧菜单)属性将需要显示的内容放在布局的左侧或者android:layout_gravity=”end”(右侧菜单)属性将需要显示的内容放在布局的右侧。
activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<androidx.drawerlayout.widget.DrawerLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/drawer_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<!-- 主界面-->
<FrameLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#D50000">
</FrameLayout>
<!-- 右滑界面-->
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="start"
android:orientation="vertical"
android:background="#2962FF">
</LinearLayout>
<!-- 左划界面-->
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="end"
android:orientation="vertical"
android:background="#00C853">
</LinearLayout>
</androidx.drawerlayout.widget.DrawerLayout>
可以看出这个组件的使用很简单。除此之外我们还可以给DrawerLayout组件设置事件监听。
drawerLayout.addDrawerListener(new DrawerLayout.DrawerListener() {
//当抽屉位置发生变化时调用
@Override
public void onDrawerSlide(@NonNull View drawerView, float slideOffset) {
}
//当抽屉处于完全打开时调用
@Override
public void onDrawerOpened(@NonNull View drawerView) {
}
//当抽屉处于完全关闭时调用
@Override
public void onDrawerClosed(@NonNull View drawerView) {
}
//抽屉滑动状态改变时调用
//状态值 STATE_IDLE:闲置、STATE_DRAGGING:拖拽、STATE_SETTLING:固定的
@Override
public void onDrawerStateChanged(int newState) { }
}
});
下面贴出项目代码:
MainActivity.java
package com.example.mydemo;
import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import androidx.drawerlayout.widget.DrawerLayout;
import android.os.Bundle;
import android.view.DragEvent;
import android.view.View;
import android.widget.Toast;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initDrawerLayout();
}
private void initDrawerLayout() {
DrawerLayout drawerLayout = findViewById(R.id.drawer_layout);
drawerLayout.addDrawerListener(new DrawerLayout.DrawerListener() {
//当抽屉位置发生变化时调用
@Override
public void onDrawerSlide(@NonNull View drawerView, float slideOffset) {
Toast.makeText(getApplicationContext(),"当抽屉位置发生变化时调用",Toast.LENGTH_SHORT).show();
}
//当抽屉处于完全打开时调用
@Override
public void onDrawerOpened(@NonNull View drawerView) {
Toast.makeText(getApplicationContext(),"当抽屉处于完全打开时调用",Toast.LENGTH_SHORT).show();
}
//当抽屉处于完全关闭时调用
@Override
public void onDrawerClosed(@NonNull View drawerView) {
Toast.makeText(getApplicationContext(),"当抽屉处于完全关闭时调用",Toast.LENGTH_SHORT).show();
}
//抽屉滑动状态改变时调用
//状态值 STATE_IDLE:闲置、STATE_DRAGGING:拖拽、STATE_SETTLING:固定的
@Override
public void onDrawerStateChanged(int newState) {
switch (newState){
case DrawerLayout.STATE_IDLE:
Toast.makeText(getApplicationContext(),"STATE_IDLE:闲置",Toast.LENGTH_SHORT).show();
break;
case DrawerLayout.STATE_DRAGGING:
Toast.makeText(getApplicationContext(),"STATE_DRAGGING:拖拽",Toast.LENGTH_SHORT).show();
break;
case DrawerLayout.STATE_SETTLING:
Toast.makeText(getApplicationContext(),"STATE_SETTLING:固定的",Toast.LENGTH_SHORT).show();
break;
default:
break;
}
}
});
}
}
链接:百度网盘下载提取码:hu5i