Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 554|回复: 0

Android 高大上的侧滑菜单DrawerLayout,解决了不能全屏滑动的问题

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-6-8 16:13:20 | 显示全部楼层 |阅读模式

    DrawerLayout预览

    DrawerLayout主要功能就是 实现侧滑菜单效果的功能,并且可以通过增加一些设置来实现高大上的效果,那么就请看动态图:


     

    注意左上角那个图标,有木有很好玩,哈哈...

    接下来就介绍如何实现这一功能

    1. 在项目对应的build.gradle中添加依赖

        dependencies {
            ...//其他代码
            compile 'com.android.support:appcompat-v7:24.0.0'
            compile 'com.android.support:design:24.0.0'
               ...//其他代码
        }

    2. 添加ToolBar,创建toolbar.xml文件

        <?xml version="1.0" encoding="utf-8"?>
            <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
                xmlns:app="http://schemas.android.com/apk/res-auto"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content">
    
            <android.support.v7.widget.Toolbar
                android:id="@+id/toolbar"
                android:clipToPadding="true"
                android:fitsSystemWindows="true"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                app:title="资讯"
                app:titleTextColor="#fff">
            </android.support.v7.widget.Toolbar>
        </RelativeLayout>

    3. 在main.xml中添加DrawerLayout

        <?xml version="1.0" encoding="utf-8"?>
        <LinearLayout
            xmlns:android="http://schemas.android.com/apk/res/android"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:orientation="vertical">
    
            <!-- 添加ToolBar -->
            <include layout="@layout/toolbar"/>
    
            <!--添加DrawerLayout-->
            <android.support.v4.widget.DrawerLayout
                android:id="@+id/drawerlayout"
                android:layout_width="match_parent"
                android:layout_height="match_parent">
    
                <!-- 一般第一个位置的代表 主内容 -->
                <FrameLayout
                    android:id="@+id/main"
                    android:layout_width="match_parent"
                    android:layout_height="match_parent">
                </FrameLayout>
    
                <!-- 左侧菜单(设置layout_gravity 为left) -->
                <RelativeLayout
                    android:id="@+id/left"
                    android:layout_width="match_parent"
                    android:layout_height="match_parent"
                    android:layout_gravity="left">
                </RelativeLayout>
    
                <!-- 右侧菜单(设置layout_gravity 为right) -->
                <RelativeLayout
                    android:id="@+id/right"
                    android:layout_width="match_parent"
                    android:layout_height="match_parent"
                    android:layout_gravity="right">
                </RelativeLayout>
    
            </android.support.v4.widget.DrawerLayout>
        </LinearLayout>

    DrawerLayout一般分为三个部分 主内容,左侧菜单,右侧菜单
    每个部分的内容自行设置,我是采用Fragment方式设置内容,这里仅供参考

        //新建Fragment,具体内容我就不详细说了
        fragmentMain = new FragmentMain();
        //添加内容,比较简单的
        getSupportFragmentManager().beginTransaction().replace(R.id.main, fragmentMain).commit();

    到此为止已经初步实现了侧滑菜单的功能,来看一下效果


    DrawerLayout初效果.gif

    然后,就是给侧滑按钮添加效果了

    1. 在此之前要进行view的初始化

        mDrawerLayout = (DrawerLayout) findViewById(R.id.drawerlayout);
        toolbar = (Toolbar) this.findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);

    2. 通过ActionBarDrawerToggle来完成效果,操作很简单

        mToggle = new ActionBarDrawerToggle(HomeActivity.this, 
                                            mDrawerLayout, 
                                            toolbar, 
                                            R.string.open,
                                              R.string.close);
        mToggle.syncState();
        mDrawerLayout.addDrawerListener(mToggle);

    这样就结束了

    最后就是解决DrawerLayout不能全屏滑动的问题

    private void setDrawerLeftEdgeSize (Activity activity, DrawerLayout drawerLayout, float displayWidthPercentage) {
        if (activity == null || drawerLayout == null) return;
        try {
            // 找到 ViewDragHelper 并设置 Accessible 为true
            Field leftDraggerField =
                    drawerLayout.getClass().getDeclaredField("mLeftDragger");//Right
            leftDraggerField.setAccessible(true);
            ViewDragHelper leftDragger = (ViewDragHelper) leftDraggerField.get(drawerLayout);
    
            // 找到 edgeSizeField 并设置 Accessible 为true
            Field edgeSizeField = leftDragger.getClass().getDeclaredField("mEdgeSize");
            edgeSizeField.setAccessible(true);
            int edgeSize = edgeSizeField.getInt(leftDragger);
    
            // 设置新的边缘大小
            Point displaySize = new Point();
            activity.getWindowManager().getDefaultDisplay().getSize(displaySize);
            edgeSizeField.setInt(leftDragger, Math.max(edgeSize, (int) (displaySize.x *
                    displayWidthPercentage)));
        } catch (NoSuchFieldException e) {
        } catch (IllegalArgumentException e) {
        } catch (IllegalAccessException e) {
        }
    }

    直接调用这个方法即可!最后一个参数 传 1,即可实现全屏滑动。如果你想让右侧菜单也是全屏,只要将对应的 "mLeftDragger" 改为 "mRightDragger"。

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-1-11 21:02 , Processed in 0.057457 second(s), 27 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表