ScrollView嵌套recycle滑动卡顿

本文介绍了一种解决Android中嵌套ScrollView与RecyclerView滑动卡顿的问题,通过自定义TopicScrollView组件并调整其TouchEvent处理逻辑,实现更流畅的滑动体验。同时提供了另一种方法,即设置RecyclerView的属性来避免滑动冲突。

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

package cn.benben.hoola.untils;

import android.content.Context;
import android.util.AttributeSet;
import android.util.Log;
import android.view.MotionEvent;
import android.view.ViewConfiguration;
import android.widget.ScrollView;

/**
 * Created by caojieting on 2018/10/13.
 *
 * 解决嵌套recycle滑动卡顿
 */

public class TopicScrollView  extends ScrollView {
  private int downX;
  private int downY;
  private int mTouchSlop;
  public TopicScrollView(Context context) {
    super(context);
    mTouchSlop= ViewConfiguration.get(context).getScaledTouchSlop();
  }


  public TopicScrollView(Context context, AttributeSet attrs) {
    super(context, attrs);
    mTouchSlop= ViewConfiguration.get(context).getScaledTouchSlop();
  }


  public TopicScrollView(Context context, AttributeSet attrs, int defStyleAttr) {
    super(context, attrs, defStyleAttr);
    mTouchSlop= ViewConfiguration.get(context).getScaledTouchSlop();
  }

  @Override
  public boolean onTouchEvent(MotionEvent ev) {
    int action = ev.getAction();
    switch (action) {
      case MotionEvent.ACTION_DOWN:
//        Log.e("eee","按下了");
        requestDisallowInterceptTouchEvent(true);
        break;
      case MotionEvent.ACTION_UP:
//        Log.e("eee","抬起了");
        requestDisallowInterceptTouchEvent(false);
        break;
      case MotionEvent.ACTION_CANCEL:
//        Log.e("eee","CANCEL取消了");
        requestDisallowInterceptTouchEvent(false);
        break;

    }
    return super.onTouchEvent(ev);
  }


  @Override
  public boolean onInterceptTouchEvent(MotionEvent e) {
    int action = e.getAction();
    switch (action) {
      case MotionEvent.ACTION_DOWN:
        downX = (int) e.getRawX();
        downY = (int) e.getRawY();
        break;
      case MotionEvent.ACTION_MOVE:
        int moveY = (int) e.getRawY();
        if (Math.abs(moveY - downY) > mTouchSlop) {
          requestDisallowInterceptTouchEvent(true);
          return true;
        }
    }
    return super.onInterceptTouchEvent(e);
  }
}


ps:另外一种方法
参考:https://blog.youkuaiyun.com/qq_40848783/article/details/80068735

ScrollView嵌套recycle滑动卡顿 //解决滑动冲突、滑动不流畅
 recyclerMagicView.setHasFixedSize(true);
recyclerMagicView.setNestedScrollingEnabled(false);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值