zoukankan      html  css  js  c++  java
  • Android滑动冲突解决

    (1).场景一:外部滑动方向跟内部滑动方向不一致,比如外部左右滑动,内部上下滑动
       ViewPager+Fragment配合使用,会有滑动冲突,但是ViewPager内部处理了这种滑动冲突
       如果采用的不是ViewPager而是ScrollView就必须手动处理滑动事件   
        
       上下滑动时,需要上一级view把消息传递进行,因此上一级view的onInterceptTouchEvent方法
    return false;左右滑动时需要上一级view执行它的onTouchEvent方法,因此它的onInterceptTouchEvent
    方法应该return true;
      
    代码如下:
       public boolean onInterceptTouchEvent(MotionEvent ev) {
            // TODO Auto-generated method stub
          boolean result=false;
          switch(ev.getAction()){
            case MotionEvent.ACTION_DOWN:
              //getX()表示以该控件的左上角为0点
              //getRawX()表示以屏幕的左上角为0点
                firstX=(int) ev.getX();
                firstY=(int) ev.getY();
                break;
            case MotionEvent.ACTION_MOVE:
                //手指在屏幕上水平移动的绝对值
                int disX=(int) Math.abs(ev.getX()-firstX);
                //手指在屏幕上竖直移动的绝对值
                int disY=(int) Math.abs(ev.getY()-firstY);
                if(disX>disY&&disX>10){
                    result=true;
                }
                break;
              case MotionEvent.ACTION_UP:
                break;
           }
             return result;
        }  
    (2).场景二:外部滑动方向跟内部滑动方向一致,内外两层同时上下或者左右滑动
        根据业务需求来判断
       
    (3).场景三:上面两种场景的嵌套
     
    (4).滑动冲突的解决方式: 
         a.外部解决法:父容器对事件判断是否拦截
         b.内部解决法:父容器不拦截任何事件,任何的事件都传递给子元素,如果子元素需要此事件就消耗掉,否则就由父容器进行处理。
       对于底层的View来说,有一种方法可以阻止父层的View截获touch事件,就是调用getParent().requestDisallowInterceptTouchEvent(true);
       方法。一旦底层View收到touch的action后调用这个方法那么父层View就不会再调用onInterceptTouchEvent了,也无法截获以后的action。
       
       public boolean dispatchTouchEvent(MotionEvent event){
         switch(event.getAction()){
          case MotionEvent.ACTION_DOWN:
              //父控件就不会拦截ListView的滑动事件
              parent.requestDisallowInterceptTouchEvent(true);
              break;
          case MOtionEvent.ACTION_MOVE:
             if(父容器需要此类点击事件){
               parent.requestDisallowInterceptTouchEvent(false);
             }
             break;
          } 
          return super.dispatchTouchEvent(event);
       }
  • 相关阅读:
    谈谈分布式事务之一:SOA需要怎样的事务控制方式
    asp.net创建自定义排序用户界面
    在ASP.NET 2.0中操作数据:在GridView的页脚中显示统计信息
    Url重写技术的运用(转)
    ASP.NET 对 SqlDataSource 控件使用参数
    正则表达式分支条件与分组
    向DWR传递参数和返回参数(转)
    一位软件工程师的6年总结(转)
    ASP.NET 2.0数据教程之二十六::排序自定义分页数据
    Table控件使用示例
  • 原文地址:https://www.cnblogs.com/ganchuanpu/p/9376716.html
Copyright © 2011-2022 走看看