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

本文详细探讨了ViewPager2的滑动冲突处理,解释了为什么ViewPager2没有默认处理冲突,并介绍了外部拦截法和内部拦截法。重点在于使用内部拦截法,通过自定义Layout解决冲突。代码示例展示了如何在外层布局中监听和处理滑动事件,确保ViewPager2在不同场景下正确拦截或允许事件传递。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

final int action = ev.getAction() & MotionEvent.ACTION_MASK;

if (action == MotionEvent.ACTION_CANCEL || act

《Android学习笔记总结+最新移动架构视频+大厂安卓面试真题+项目实战源码讲义》

开源分享完整内容戳这里

ion == MotionEvent.ACTION_UP) {

// 在事件取消或者抬起手指后重置状态

resetTouch();

return false;

}

switch (action) {

case MotionEvent.ACTION_MOVE: {

// 这里判断在水平方向上的滑动距离大于竖直方向的2倍,则认为是有效的切换页面的滑动

if (xDiff > mTouchSlop && xDiff * 0.5f > yDiff) {

mIsBeingDragged = true;

// 禁止Parent View拦截事件,即事件要能够传递到ViewPager

requestParentDisallowInterceptTouchEvent(true);

setScrollState(SCROLL_STATE_DRAGGING);

} else if (yDiff > mTouchSlop) {

mIsUnableToDrag = true;

}

break;

}

case MotionEvent.ACTION_DOWN: {

if (mScrollState == SCROLL_STATE_SETTLING

&& Math.abs(mScroller.getFinalX() - mScroller.getCurrX()) > mCloseEnough) {

// 在Down事件中禁止Parent View拦截事件,是为了事件序列能够传递到ViewPager

requestParentDisallowInterceptTouchEvent(true);

setScrollState(SCROLL_STATE_DRAGGING);

} else {

completeScroll(false);

mIsBeingDragged = false;

}

break;

}

case MotionEvent.ACTION_POINTER_UP:

onSecondaryPointerUp(ev);

break;

}

return mIsBeingDragged;

}

可以看到在ACTION_DOWN与ACTION_MOVE中根据一些判断条件调用了requestParentDisallowInterceptTouch

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值