Scrollview和RecyclerView滑动冲突问题解决

1. NestedSrollview和Recycleview冲突解决:

NestedSrcollview:
android:fillViewport="true"  

RecycleView:       
android:layout_height="wrap_content"
android:nestedScrollingEnabled="false"

 

2. .Scrollview和横向RecyclerView滑动冲突问题解决
重写scrollview的onInterceptTouchEvent方法, 即可解决recyclerview横向滑动不畅的问题.

 

override fun onInterceptTouchEvent(e: MotionEvent): Boolean {
 
        var intercept = super.onInterceptTouchEvent(e)
 
        when (e.action) {
 
            MotionEvent.ACTION_DOWN -> {
                lastX = e.x
                lastY = e.y
            }
            MotionEvent.ACTION_MOVE -> {
                // 只要横向大于竖向,就拦截掉事件。
                // 部分机型点击事件(slopx==slopy==0),会触发MOVE事件。
                // 所以要加判断(slopX > 0 || sloy > 0)
                val slopX = Math.abs(e.x - lastX)
                val slopY = Math.abs(e.y - lastY)
                //  Log.log("slopX=" + slopX + ", slopY="  + slopY);
                if ((slopX > 0 || slopY > 0) && slopX <= slopY) {
                    requestDisallowInterceptTouchEvent(true)
                    intercept = true
                }else{
                    intercept = false
                }
 
            }
            MotionEvent.ACTION_UP -> intercept = false
        }
        return intercept
    } 

在Android中,当ScrollView嵌套RecyclerView时,由于两者都是滑动容器,可能会导致滑动冲突,即用户试图向上滚动ScrollView时,误触到了RecyclerView滑动,反之亦然。解决这个问题有几种常见方法: 1. **禁止RecyclerView滑动**:在ScrollView内部设置RecyclerView时,可以在RecyclerView上添加`setOnTouchListener`,并在触摸事件发生时检查是否在ScrollView的区域内,如果是,则阻止RecyclerView滑动。例如: ```java recyclerView.setOnTouchListener(new View.OnTouchListener() { @Override public boolean onTouch(View v, MotionEvent event) { if (event.getAction() == MotionEvent.ACTION_UP) { int y = (int) event.getY(); if (!scrollView.canScrollVertically(1) && y > scrollView.getBottom()) { // 防止RecyclerView滑动 return true; } } return false; } }); ``` 2. **使用NestedScrollView替换ScrollView**:在Android API Level 14及以上版本,可以使用NestedScrollView替换ScrollView,它内置了解决滑动冲突的逻辑。 3. **重写RecyclerView的onInterceptTouchEvent**:重写RecyclerView的`onInterceptTouchEvent`方法,在滑动开始时判断当前手指的位置是否在ScrollView内,如果不是则让RecyclerView正常滑动。 4. **使用SwipeRefreshLayout**:如果你希望在顶部有一个下拉刷新区域,可以考虑使用SwipeRefreshLayout包裹RecyclerView,这样就可以避免滑动冲突了。 5. **禁用头部或尾部Item的滑动**:针对可能导致冲突的头部或尾部固定布局,可以设置它们不响应触摸事件。 总之,关键在于理解用户意图,并在合适的时机切换滑动目标。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值