Android开发:这可能是ViewPager2滑动冲突最全的处理方案,内外兼修

本文详细介绍了处理ViewPager2滑动冲突的内部拦截法,通过禁止外部ViewGroup拦截事件,确保内部View可以正确处理滑动。同时,提供了一种自定义布局ViewPager2Container的解决方案,以解决在特定场景下的滑动冲突问题。
摘要由CSDN通过智能技术生成

boolean intercepted = false;

int x = (int) event.getX();

int y = (int) event.getY();

switch (event.getAction()) {

case MotionEvent.ACTION_DOWN: {

intercepted = false;

break;

}

case MotionEvent.ACTION_MOVE: {

if (needIntercept) { // 这里根据需求判断是否需要拦截

intercepted = true;

} else {

intercepted = false;

}

break;

}

case MotionEvent.ACTION_UP: {

intercepted = false;

break;

}

default:

break;

}

mLastXIntercept = x;

mLastYIntercept = y;

return intercepted;

}

2. 内部拦截法

所谓的”内部拦截法“指的是对内部的View做文章,让内部View决定是不是拦截事件。但是现在就有问题了,你怎么知道外部的View是不是要拦截事件啊??如果外部View把事件拦截了,内部的View岂不是连西北风都喝不到了?

别着急,Google官方当然有考虑到这种情况。在ViewGroup中有一个叫requestDisallowInterceptTouchEvent的方法,这个方法接受一个boolean值,意思是是否要禁止ViewGroup拦截当前事件。如果是true的话那么该ViewGroup则无法对事件进行拦截。有了这个方法那我们就可以让内部View大显神通了。来看下内部拦截法的代码:

public boolean dispatchTouchEvent(MotionEvent event) {

int x = (int) event.getX();

int y = (int) event.getY();

switch (event.getAction()) {

case MotionEvent.ACTION_DOWN: {

// 禁止parent拦截down事件

parent.requestDisallowInterceptTouchEvent(true);

break;

}

case MotionEvent.ACTION_MOVE: {

int deltaX = x - mLastX;

int deltaY = y - mLastY;

if (disallowParentInterceptTouchEvent) { // 根据需求条件来决定是否让Parent View拦截事件。

parent.requestDisallowInterceptTouchEvent(false);

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值