主要通过重写 onInterceptTouchEvent 事件来解决,代码如下:

  1. package com.cm.android.pad.view.itemView;
  2. import android.content.Context;
  3. import android.util.AttributeSet;
  4. import android.util.DisplayMetrics;
  5. import android.util.Log;
  6. import android.view.MotionEvent;
  7. import android.view.VelocityTracker;
  8. import android.view.ViewConfiguration;
  9. import android.view.WindowManager;
  10. import android.widget.ScrollView;
  11. import android.widget.Scroller;
  12. public class MultiScroll extends ScrollView {
  13. private static final int ANIMATION_SCREEN_SET_DURATION_MILLIS = 500;
  14. // What fraction (1/x) of the screen the user must swipe to indicate a page change
  15. private static final int FRACTION_OF_SCREEN_WIDTH_FOR_SWIPE = 4;
  16. private static final int INVALID_SCREEN = -1;
  17. /*
  18. * Velocity of a swipe (in density-independent pixels per second) to force a swipe to the
  19. * next/previous screen. Adjusted into mDensityAdjustedSnapVelocity on init.
  20. */
  21. private static final int SNAP_VELOCITY_DIP_PER_SECOND = 600;
  22. // Argument to getVelocity for units to give pixels per second (1 = pixels per millisecond).
  23. private static final int VELOCITY_UNIT_PIXELS_PER_SECOND = 1000;
  24. private static final int TOUCH_STATE_REST = 0;
  25. private static final int TOUCH_STATE_HORIZONTAL_SCROLLING = 1;
  26. private static final int TOUCH_STATE_VERTICAL_SCROLLING = -1;
  27. private int mCurrentScreen;
  28. private int mDensityAdjustedSnapVelocity;
  29. private boolean mFirstLayout = true;
  30. private float mLastMotionX;
  31. private float mLastMotionY;
  32. //private OnScreenSwitchListener mOnScreenSwitchListener;
  33. private int mMaximumVelocity;
  34. private int mNextScreen = INVALID_SCREEN;
  35. private Scroller mScroller;
  36. private int mTouchSlop;
  37. private int mTouchState = TOUCH_STATE_REST;
  38. private VelocityTracker mVelocityTracker;
  39. private int mLastSeenLayoutWidth = -1;
  40. public MultiScroll(Context context) {
  41. super(context);
  42. init();
  43. }
  44. public MultiScroll(Context context, AttributeSet attrs, int defStyle) {
  45. super(context, attrs, defStyle);
  46. init();
  47. }
  48. public MultiScroll(Context context, AttributeSet attrs) {
  49. super(context, attrs);
  50. init();
  51. }
  52. private void init() {
  53. mScroller = new Scroller(getContext());
  54. // Calculate the density-dependent snap velocity in pixels
  55. DisplayMetrics displayMetrics = new DisplayMetrics();
  56. ((WindowManager) getContext().getSystemService(Context.WINDOW_SERVICE)).getDefaultDisplay()
  57. .getMetrics(displayMetrics);
  58. mDensityAdjustedSnapVelocity =
  59. (int) (displayMetrics.density * SNAP_VELOCITY_DIP_PER_SECOND);
  60. final ViewConfiguration configuration = ViewConfiguration.get(getContext());
  61. mTouchSlop = configuration.getScaledTouchSlop();
  62. mMaximumVelocity = configuration.getScaledMaximumFlingVelocity();
  63. }
  64. @Override
  65. public boolean onInterceptTouchEvent(final MotionEvent ev) {
  66. /*
  67. * By Yoni Samlan: Modified onInterceptTouchEvent based on standard ScrollView's
  68. * onIntercept. The logic is designed to support a nested vertically scrolling view inside
  69. * this one; once a scroll registers for X-wise scrolling, handle it in this view and don't
  70. * let the children, but once a scroll registers for y-wise scrolling, let the children
  71. * handle it exclusively.
  72. */
  73. final int action = ev.getAction();
  74. boolean intercept = false;
  75. switch (action) {
  76. case MotionEvent.ACTION_MOVE:
  77. /*
  78. * If we're in a horizontal scroll event, take it (intercept further events). But if
  79. * we're mid-vertical-scroll, don't even try; let the children deal with it. If we
  80. * haven't found a scroll event yet, check for one.
  81. */
  82. if (mTouchState == TOUCH_STATE_HORIZONTAL_SCROLLING) {
  83. // Let children handle the events for the duration of the scroll event.
  84. intercept = false;
  85. } else if (mTouchState == TOUCH_STATE_VERTICAL_SCROLLING) {
  86. /*
  87. * We've already started a horizontal scroll; set intercept to true so we can
  88. * take the remainder of all touch events in onTouchEvent.
  89. */
  90. intercept = true;
  91. } else { // We haven't picked up a scroll event yet; check for one.
  92. /*
  93. * If we detected a horizontal scroll event, start stealing touch events (mark
  94. * as scrolling). Otherwise, see if we had a vertical scroll event -- if so, let
  95. * the children handle it and don't look to intercept again until the motion is
  96. * done.
  97. */
  98. final float x = ev.getX();
  99. final int xDiff = (int) Math.abs(x - mLastMotionX);
  100. boolean xMoved = xDiff > mTouchSlop;
  101. final float y = ev.getY();
  102. final int yDiff = (int) Math.abs(y - mLastMotionY);
  103. boolean yMoved = yDiff > mTouchSlop;
  104. if (xMoved) {
  105. // Scroll if the user moved far enough along the X axis
  106. if(xDiff>=yDiff)
  107. mTouchState = TOUCH_STATE_HORIZONTAL_SCROLLING;
  108. mLastMotionX = x;
  109. }
  110. if (yMoved) {
  111. if(yDiff>xDiff)
  112. mTouchState = TOUCH_STATE_VERTICAL_SCROLLING;
  113. mLastMotionY = y;
  114. }
  115. }
  116. break;
  117. case MotionEvent.ACTION_CANCEL:
  118. case MotionEvent.ACTION_UP:
  119. // Release the drag.
  120. mTouchState = TOUCH_STATE_REST;
  121. intercept = false;
  122. break;
  123. case MotionEvent.ACTION_DOWN:
  124. /*
  125. * No motion yet, but register the coordinates so we can check for intercept at the
  126. * next MOVE event.
  127. */
  128. //Log.i("ViewPager-->", "Action_Down");
  129. mTouchState = TOUCH_STATE_REST;
  130. mLastMotionY = ev.getY();
  131. mLastMotionX = ev.getX();
  132. break;
  133. default:
  134. break;
  135. }
  136. Log.i("MultiScroll-->", intercept+"");
  137. return intercept;
  138. }
  139. }

Android开发ScrollView上下左右滑动事件冲突整理一(根据事件)的更多相关文章

  1. Android开发之手势滑动(滑动手势监听)详解

    Android开发之手势滑动(滑动手势监听)详解 在Android应用中,经常需要手势滑动操作,比如上下滑动,或左右方向滑动,处理手势滑动通常有两种方法:一种是单独实现setOnTouchListen ...

  2. Android 自定义ScrollView的滑动监听事件

    项目结构: 1.LazyScrollView类(自定义ScrollView) package android.zhh.com.myapplicationscrollview; /** * Create ...

  3. Android开发之源码:多次点击事件的原理和实现

    多次点击事件 多次点击事件原理:最后一次点击事件与第一次点击事件的时间间隔是否小于某个时间,当小于的时候,就认为这是一个多次点击事件. Android源码实现效果: import android.ap ...

  4. android 开发 ScrollView 控件的一些api描述与自定义ScrollView接口回调方法

    1.正常使用ScrollView控件的一些api详解. package com.example.lenovo.mydemoapp.scrollViewDemo; import android.supp ...

  5. JS 事件冒泡整理 浏览器的事件流

    JavaScript与HTML的交互通过事件来实现.而浏览器的事件流是一个非常重要的概念.不去讨论那些古老的浏览器有事件捕获与事件冒泡的争议, 只需要知道在DOM2中规定的事件流包括了三个部分,事件捕 ...

  6. Android开发(十九)——ViewFlipper中的onClick事件和onFling事件冲突

    在onDown中设置this.flipper.setClickable(true); 然后在onFling方法中this.flipper.setClickable(false); ps: 其中setO ...

  7. Android监测手指上下左右滑动屏幕

    在开发android程序时,有时会需要监测手指滑动屏幕,当手指朝上下左右不同方向滑动时做出不同的响应,那怎么去实现呢? 利用Android提供的手势监测器就可以很方便的实现,直接上代码(已测试通过) ...

  8. android开发学习 ------- 自定义View 圆 ,其点击事件 及 确定当前view的层级关系

    我需要实现下面的效果:   参考文章:https://blog.csdn.net/halaoda/article/details/78177069 涉及的View事件分发机制 https://www. ...

  9. Android开发--ScrollView的应用

    1.简介 当内容无法全部显示时,需要采取滚动的方式获取其与内容.其中,ScrollView为垂直滚动控件,HorizontalScrollView为水平滚动控件. 2.构建

随机推荐

  1. 我的css reset

    @charset "utf-8"; /*reset*/ body,h1,h2,h3,h4,h5,h6,hr,p,blockquote,dl,dt,dd,ul,ol,li,pre,f ...

  2. [jQuery编程挑战]005 使用最短的代码生成元素的闪烁效果

    <!DOCTYPE html> <html lang="zh"> <head> <meta charset="utf-8&quo ...

  3. iscc2016-basic-明察秋毫

    查看源代码,找到maybe not flag : Jr1p0zr2VfPp 移位密码,注意判断字母大小写,并且数字无变化 s = "Jr1p0zr2VfPp" p = list(s ...

  4. TCP/IP 三次握手和四次握手

    三次握手建立连接: 第一次握手:客户端发送syn包(seq=x)到服务器,并进入SYN_SEND状态,等待服务器确认: 第二次握手:服务器收到syn包,必须确认客户的SYN(ack=x+1),同时自己 ...

  5. [BZOJ 3626] [LNOI2014] LCA 【树链剖分 + 离线 + 差分询问】

    题目链接: BZOJ - 3626 题目分析 考虑这样的等价问题,如果我们把一个点 x 到 Root 的路径上每个点的权值赋为 1 ,其余点的权值为 0,那么从 LCA(x, y) 的 Depth 就 ...

  6. Promise 让异步更优

    每个异步方法都返回一个Promise 更优雅. then方法 每一个Promise  都有一个叫then 的方法, 接受一对callback    被解决时调用,resolve, 被拒绝   reje ...

  7. Java NIO API详解

    在JDK 1.4以前,Java的IO操作集中在java.io这个包中,是基于流的同步(blocking)API.对于大多数应用来说,这样的API使用很方便,然而,一些对性能要求较高的应用,尤其是服务端 ...

  8. Inotify: 高效、实时的Linux文件系统事件监控框架

      Inotify: 高效.实时的Linux文件系统事件监控框架   概要 - 为什么需要监控文件系统? 在日常工作中,人们往往需要知道在某些文件(夹)上都有那些变化,比如:   通知配置文件的改变 ...

  9. 快速创建php server

    mkdir testmv test.html testphp -S localhost:8082http://localhost:8082/test.html

  10. wikioi3363支线剧情(挖个坑,不会做。。。)

    3363 支线剧情 题目描述 Description 宅男JYY非常喜欢玩RPG游戏,比如仙剑,轩辕剑等等.不过JYY喜欢的并不是战斗场景,而是类似电视剧一般的充满恩怨情仇的剧情.这些游戏往往都有很多 ...