android中scrollview嵌套HorizontalScrollView导致横向滑动卡顿现象解决

   

        分类:             Android开发技巧点滴                   2673人阅读     评论(0)     收藏     举报    

也许会有人遇到,在这里说下解决方法。方便以后有人纠结这个问题。

开发中经验会遇到滑动里面嵌入滑动的问题,但是这种情况下触摸事件就会发生冲突。导致滑动非常卡,甚至出现程序停止响应。这种情况下我们一般需要重写view。下面给出重新scrollview的方法

?
  1. public class CustomScrollView extends ScrollView {   
  2.     private GestureDetector mGestureDetector;   
  3.     View.OnTouchListener mGestureListener;   
  4.     
  5.     public CustomScrollView(Context context, AttributeSet attrs) {   
  6.         super(context, attrs);   
  7.         mGestureDetector = new GestureDetector(new YScrollDetector());   
  8.         setFadingEdgeLength(0);   
  9.     }   
  10.     
  11.     @Override  
  12.     public boolean onInterceptTouchEvent(MotionEvent ev) {   
  13.         return super.onInterceptTouchEvent(ev) && mGestureDetector.onTouchEvent(ev);   
  14.     }   
  15.     
  16.     // Return false if we're scrolling in the x direction     
  17.     class YScrollDetector extends SimpleOnGestureListener {   
  18.         @Override  
  19.         public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) {   
  20.             if(Math.abs(distanceY) > Math.abs(distanceX)) {   
  21.                 return true;   
  22.             }   
  23.             return false;   
  24.         }   
  25.     }   
  26. }  
public class CustomScrollView extends ScrollView { 
    private GestureDetector mGestureDetector; 
    View.OnTouchListener mGestureListener; 
  
    public CustomScrollView(Context context, AttributeSet attrs) { 
        super(context, attrs); 
        mGestureDetector = new GestureDetector(new YScrollDetector()); 
        setFadingEdgeLength(0); 
    } 
  
    @Override
    public boolean onInterceptTouchEvent(MotionEvent ev) { 
        return super.onInterceptTouchEvent(ev) && mGestureDetector.onTouchEvent(ev); 
    } 
  
    // Return false if we're scrolling in the x direction   
    class YScrollDetector extends SimpleOnGestureListener { 
        @Override
        public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) { 
            if(Math.abs(distanceY) > Math.abs(distanceX)) { 
                return true; 
            } 
            return false; 
        } 
    } 
}


使用的时候使用这个自定义的控件就可以了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值