解决ViewPager和DrawerLayout滑动冲突

1. 问题描述

首先我做了一个Activity,Activity的布局中放了ViewPager,用于管理Fragment

效果如下图:

然后我想放一个DrawerLayout,在第一个Fragment的时候可以向右滑拉出个人信息。

这个时候我发现出问题了,因为ViewPager的优先级高于DrawerLayout,所以判定是ViewPager在滑动,导致DrawerLayout出不来。

同时,如果你在ToolBar中设置一个按钮,用来展开DrawerLayout,你会发现:当你想要收起抽屉布局的时候,ViewPager滑动了。

2. 解决思路

  1. 首先应该明确一点,这个DrawerLayout应该写在Activity中,而不是写在第一个Fragment中
  2. 在第一个页面时,禁止从左向右滑动
  3. 当抽屉拉开的时候,我们也要禁止ViewPager滑动

3. 解决方案

3.1 布局

3.2 自定义MyViewPager

kotlin 复制代码
class MyViewPager : ViewPager {
    var xDistance: Float = 0f
    var xLast: Float = 0f

    private var noScroll: Boolean = false

    constructor(context: Context?) : super(context!!)
    constructor(context: Context?, attrs: AttributeSet?) : super(context!!, attrs)

    /**
     * 禁止第一个fragment右滑
     */
    override fun onInterceptTouchEvent(ev: MotionEvent?): Boolean {
        if (noScroll) return false

        when(ev?.action){
            MotionEvent.ACTION_DOWN -> {
                xDistance = 0f
                xLast = ev.x
            }
            MotionEvent.ACTION_MOVE -> {
                val curX: Float = ev.x
                // 第一个fragment禁止右滑
                if (xLast-curX<0 && currentItem==0) return false
            }
        }

        return super.onInterceptTouchEvent(ev)
    }

    /**
     * 控制viewPager是否能滑动
     */
    fun setNoScroll(_noScroll: Boolean){
        noScroll = _noScroll
    }


    override fun onTouchEvent(ev: MotionEvent?): Boolean {
        if (noScroll) return false
        else return super.onTouchEvent(ev)
    }
}

3.3 设置Activity中的DrawerLayout

kotlin 复制代码
fun setDrawerLayout(){
    binding.userInfoView.setDrawerListener(object : DrawerLayout.DrawerListener{
        override fun onDrawerSlide(drawerView: View, slideOffset: Float) {}

        override fun onDrawerOpened(drawerView: View) {
            binding.viewPager.setNoScroll(true)
        }

        override fun onDrawerClosed(drawerView: View) {
            binding.viewPager.setNoScroll(false)
        }

        override fun onDrawerStateChanged(newState: Int) {}
    })
}
相关推荐
程序员陆业聪5 小时前
绕过Frida/Xposed的最后防线:SVC直接系统调用与Native反Hook实战
android
程序员陆业聪5 小时前
WebView与原生JS交互:JSBridge生产级实现与安全防护
android
我命由我123458 小时前
Android 开发问题:MlKitException: An internal error occurred during initialization.
android·java·java-ee·android jetpack·android-studio·androidx·android runtime
Meteors.9 小时前
Android自定义 View 三核心方法详解
android
2501_916007479 小时前
前端开发常用软件与工具全面指南
android·ios·小程序·https·uni-app·iphone·webview
赏金术士9 小时前
Android Tinker 热修复集成与使用指南 1.9.15.2
android·热修复·tinker
2603_9541383911 小时前
安卓误删文件先别慌!5个实用小技巧指南教你补救
android·智能手机
波诺波12 小时前
5-SOFA可变形的3D物体 5-elasticity.scn
android
2501_9159090613 小时前
iOS应用性能优化:十大策略提升用户体验与开发效率
android·ios·小程序·https·uni-app·iphone·webview
sun00770014 小时前
打通android全链路,网卡驱动, 内核 , 到上层hal, framework
android