码迷,mamicode.com
首页 > 其他好文 > 详细

我答同行问(续四)

时间:2015-03-13 09:23:40      阅读:123      评论:0      收藏:0      [点我收藏+]

标签:scrollview中嵌套viewpag   viewpager   scrollview   滑动失效   

    本片文章出自http://blog.csdn.net/andywuchuanlong,转载请说明出处,谢谢!

    我答同行问序列目录http://blog.csdn.net/andywuchuanlong/article/details/44194043

  5、为什么ScrollView中嵌套了ViewPager后,viewPager高度出现问题并且滑动失效?

   ScrollView是可以滑动的,而viewPager也是可以进行滑动的,虽然说两者嵌套不违反view的嵌套原则,但是Android系统里面可以滑动的组件里面是不可以嵌套可滑动的组件的,因为这样组件不好测量。

   下面讲述一下解决方案:

解决方法只需要在接近水平滚动时ScrollView不处理事件而交由其子View(即这里的ViewPager)处理即可,重写ScrollView的onInterceptTouchEvent函数

<span style="font-family:Courier New;font-size:14px;">public class VerticalScrollView extends ScrollView {
    private GestureDetector mGestureDetector;
    public VerticalScrollView(Context context, AttributeSet attrs){
        super(context, attrs);
        mGestureDetector = new GestureDetector(context, new ScrollDetector());
    }
    @Override
    public boolean onInterceptTouchEvent(MotionEvent ev) {
        return super.onInterceptTouchEvent(ev) && mGestureDetector.onTouchEvent(ev);
    }
    class ScrollDetector extends SimpleOnGestureListener {
        @Override
        public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) {
            return (Math.abs(distanceY) > Math.abs(distanceX));
        }
    }
}</span>
             对于高度的问题,可以使用下列解决方案:

                   1、设置ScrollView的fillViewPort为true
                  2、设置ViewPager的layout_height为一个固定高度,比如:100dip

我答同行问(续四)

标签:scrollview中嵌套viewpag   viewpager   scrollview   滑动失效   

原文地址:http://blog.csdn.net/andywuchuanlong/article/details/44236239

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!