zoukankan      html  css  js  c++  java
  • ScrollView内嵌ViewPager导致ViewPager滑动困难问题

    转自:http://titanseason.iteye.com/blog/1858874

    解决方式:重写ScrollView,然后在xml中定义布局的时候,使用自定义的PagerScrollView而不是系统的ScrollView即可。重点在于重写父类的onInterceptTouchEvent方法

    import android.content.Context;  
    import android.util.AttributeSet;  
    import android.view.GestureDetector;  
    import android.view.GestureDetector.SimpleOnGestureListener;  
    import android.view.MotionEvent;  
    import android.widget.ScrollView;  

    public class PagerScrollView extends ScrollView {  

        private GestureDetector mGestureDetector;  

        public PagerScrollView(Context context, AttributeSet attrs, int defStyle) {  
            super(context, attrs, defStyle);  
            init();  
        }  

        public PagerScrollView(Context context) {  
            super(context);  
            init();  
        }  

        public PagerScrollView(Context context, AttributeSet attrs) {  
            super(context, attrs);  
            init();  
        }  

        private void init() {  
            mGestureDetector = new GestureDetector(getContext(),  
                    new YScrollDetector());  
            setFadingEdgeLength(0);  
        }  

        @Override  
        public boolean onInterceptTouchEvent(MotionEvent ev) {  
            return super.onInterceptTouchEvent(ev)  
                    && mGestureDetector.onTouchEvent(ev);  
        }  

        private 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;  
            }  
        }  

  • 相关阅读:
    唐李问对 简单飞扬
    【关键字】Javascript js 身份证号码 检测 规则 18位 15位 简单飞扬
    司马法 简单飞扬
    实现身份证的15位转18位 简单飞扬
    JAVA验证身份证号码 简单飞扬
    页面验证的类型 简单飞扬
    模拟MSN和QQ的上线提示效果 区别IE和FF浏览器 简单飞扬
    孙子兵法 简单飞扬
    吴子 简单飞扬
    C# WPF MVVM 实战 2.1
  • 原文地址:https://www.cnblogs.com/android-zcq/p/3182310.html
Copyright © 2011-2022 走看看