欢迎来到代码驿站!

Android代码

当前位置:首页 > 移动开发 > Android代码

Android中RecyclerView嵌套滑动冲突解决的代码片段

时间:2020-10-22 22:34:21|栏目:Android代码|点击:

在纵向RecyclerView嵌套横向RecyclerView时,如果纵向RecyclerView有下拉刷新功能,那么内部的横向RecyclerView的横向滑动体验会很差.(只有纯横向滑动时,才能滑动内部的横向RecyclerView,否则滑动事件就会影响到下拉刷新),添加拦截判断.

public class MySwipeRefreshLayout extends SwipeRefreshLayout {

 private boolean mIsVpDragger;
 private final int mTouchSlop;
 private float startY;
 private float startX;

 public MySwipeRefreshLayout(Context context) {
 super(context);
 mTouchSlop = ViewConfiguration.get(context).getScaledTouchSlop();
 }

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


 @Override
 public boolean onInterceptTouchEvent(MotionEvent ev) {
 int action = ev.getAction();
 switch (action) {
  case MotionEvent.ACTION_DOWN:
  // 记录手指按下的位置
  startY = ev.getY();
  startX = ev.getX();
  // 初始化标记
  mIsVpDragger = false;
  break;
  case MotionEvent.ACTION_MOVE:
  // 如果viewpager正在拖拽中,那么不拦截它的事件,直接return false;
  if (mIsVpDragger) {
   return false;
  }

  // 获取当前手指位置
  float endY = ev.getY();
  float endX = ev.getX();
  float distanceX = Math.abs(endX - startX);
  float distanceY = Math.abs(endY - startY);
  // 如果X轴位移大于Y轴位移,那么将事件交给viewPager处理。
  if (distanceX > mTouchSlop && distanceX > distanceY) {
   mIsVpDragger = true;
   return false;
  }
  break;
  case MotionEvent.ACTION_UP:
  case MotionEvent.ACTION_CANCEL:
  // 初始化标记
  mIsVpDragger = false;
  break;
 }
 // 如果是Y轴位移大于X轴,事件交给swipeRefreshLayout处理。
 return super.onInterceptTouchEvent(ev);
 }
}

更多关于滑动功能的文章,请点击专题: 《Android滑动功能》

上一篇:Android BottomSheet实现可拉伸控件

栏    目:Android代码

下一篇:举例讲解Android应用中SimpleAdapter简单适配器的使用

本文标题:Android中RecyclerView嵌套滑动冲突解决的代码片段

本文地址:http://www.codeinn.net/misctech/14681.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有