ScrollView嵌套两个RecyclerView 导致滑动卡顿不流畅的原因

项目中在ScrollView内嵌套两个RecyclerView导致滑动卡顿。通过设置recyclerView.setNestedScrollingEnabled(false)或者自定义ScrollView来解决这个问题,以提升用户体验。

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

       项目中展示两个RecyclerView ,所以在 ScrollView下嵌套了两个,完成后发现界面滑动不流畅,还会出现卡顿的情况,严重影响了用户的使用。网上查询资料,经测试目前有两种方法解决:

1、recyclerView.setNestedScrollingEnabled(false);

简单粗暴,在代码下加入这行代码。

2、自定义ScrollView

public class ScrollView 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 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) {
                    return true;
                }
        }
        return super.onInterceptTouchEvent(e);
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值