ViewPager相互嵌套,里层ViewPager无法滑动的解决方法

ViewPager嵌套一个ViewPager典型的就是嵌套一个轮播图,但是在低版本的里层的ViewPager,是无法滑动的!

因为外层的ViewPager,会拦截触屏事件(TouchEvent)

通过重写里层控件的onTouchEvent方法,调用其父控件的requestDisallowInterceptTouchEvent()方法;使其父控件,不拦截触屏事件(TouchEvent),以此,便能达到里层的ViewPager,也能滑动的效果了。

package com.example.administrator.googleplay.views;

import android.content.Context;
import android.support.v4.view.ViewPager;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;

/**
 * 作者:Created by Kevin on 2016/2/1.
 * 邮箱:haowei0708@163.com
 * 描述:复写子ViewPager,解决在低版本下ViewPager嵌套的问题
 */
public class InnerViewPager extends ViewPager{

    private float startX;
    private float startY;

    public InnerViewPager(Context context) {
        super(context);
    }

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

    @Override
    public boolean onTouchEvent(MotionEvent ev) {
        switch (ev.getAction()){
            case MotionEvent.ACTION_DOWN:
                startX = ev.getRawX();
                startY = ev.getRawY();
                break;
            case MotionEvent.ACTION_MOVE:
                //判断是左右滑动还是上下滑动
                float endX = ev.getRawX();
                float endY = ev.getRawY();
                if (Math.abs(endX - startX) > Math.abs(endY - startY) ){
                    //如果是左右滑动,请求父控件不要拦截自己的
                    getParent().requestDisallowInterceptTouchEvent(true);
                }else {
                    //如果是上下滑动,拦截设置为false
                    getParent().requestDisallowInterceptTouchEvent(false);
                }


                break;
            case MotionEvent.ACTION_UP:
                break;
            default:
                break;
        }
        return super.onTouchEvent(ev);
    }
}

遇到的错误:
犯了一个低级错误,没有加这个构造方法,导致在xml文件中不能使用

public InnerViewPager(Context context, AttributeSet attrs) {
        super(context, attrs);
    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值