Android——DrawerLayout(滑动菜单)简单使用(含源码下载)

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

发布了33 篇原创文章 · 获赞 11 · 访问量 9253

猜你喜欢

转载自blog.csdn.net/qq_43567345/article/details/104512661