热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

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

这篇文章主要为大家详细介绍了Android中RecyclerView嵌套滑动冲突解决的代码片段,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

在纵向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滑动功能》

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


推荐阅读
author-avatar
山尖的霞1820_946
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有