android中viewPager双层嵌套问题,子viewpager无法滑动和滑动父级viewpager后子viewpager不显示内容

android中viewPager双层嵌套问题,子viewpager无法滑动和滑动父级viewpager后子viewpager不显示内容

1.解决滑动父级viewpager到第三页后,滑回第一页后,第一页的子viewpager不显示内容?

解决办法:只需要给父级viewpager设置这个属性即可解决,viewPager.setOffscreenPageLimit(4);

原因:viewpager在滑动时,一般保存3个页面,屏幕上显示的和左右两个,所以当你滑动父级viewpager到第三页时,第一页的viewpager已经被销毁,所以当你滑回第一页时,第一页的子viewpager则不显示内容。设置viewPager.setOffscreenPageLimit(4);属性即表示,当viewpager滑动时,保存4个页面,而不是3个页面。说明父级的viewpager第一个页面内容是保存的,不会被销毁,当再滑回时,正常显示内容。

  2.解决父级viewpager嵌套子viewpager后,子viewpager无法滑动?

解决办法:自定义子viewpager,将下面的这个类放到程序当中,然后布局文件使用这个自定义的viewpager即可解决。
----------------------------------------------------------------------------------------------------------------------------------
public class ChildViewPager extends ViewPager{ 
    /** 触摸时按下的点 **/ 
    PointF downP = new PointF(); 
    /** 触摸时当前的点 **/ 
    PointF curP = new PointF(); 
    OnSingleTouchListener onSingleTouchListener; 
  
    public ChildViewPager(Context context, AttributeSet attrs) { 
        super(context, attrs); 
        // TODO Auto-generated constructor stub 
    } 
  
    public ChildViewPager(Context context) { 
        super(context); 
        // TODO Auto-generated constructor stub 
    } 
  
    @Override 
    public boolean onInterceptTouchEvent(MotionEvent arg0) { 
        // TODO Auto-generated method stub 
        //当拦截触摸事件到达此位置的时候,返回true, 
        //说明将onTouch拦截在此控件,进而执行此控件的onTouchEvent 
        return true; 
    } 
  
    @Override 
    public boolean onTouchEvent(MotionEvent arg0) { 
        // TODO Auto-generated method stub 
        //每次进行onTouch事件都记录当前的按下的坐标 
        curP.x = arg0.getX(); 
        curP.y = arg0.getY(); 
  
        if(arg0.getAction() == MotionEvent.ACTION_DOWN){ 
            //记录按下时候的坐标 
            //切记不可用 downP = curP ,这样在改变curP的时候,downP也会改变 
            downP.x = arg0.getX(); 
            downP.y = arg0.getY(); 
            //此句代码是为了通知他的父ViewPager现在进行的是本控件的操作,不要对我的操作进行干扰 
            getParent().requestDisallowInterceptTouchEvent(true); 
        } 
  
        if(arg0.getAction() == MotionEvent.ACTION_MOVE){ 
            //此句代码是为了通知他的父ViewPager现在进行的是本控件的操作,不要对我的操作进行干扰 
            getParent().requestDisallowInterceptTouchEvent(true); 
        } 
  
        if(arg0.getAction() == MotionEvent.ACTION_UP){ 
            //在up时判断是否按下和松手的坐标为一个点 
            //如果是一个点,将执行点击事件,这是我自己写的点击事件,而不是onclick 
            if(downP.x==curP.x && downP.y==curP.y){ 
                onSingleTouch(); 
                return true; 
            } 
        } 
  
        return super.onTouchEvent(arg0); 
    } 
  
        /**
     * 单击
     */ 
    public void onSingleTouch() { 
        if (onSingleTouchListener!= null) { 
  
            onSingleTouchListener.onSingleTouch(); 
        } 
    } 
  
    /**
     * 创建点击事件接口
     * @author wanpg
     *
     */ 
    public interface OnSingleTouchListener { 
        public void onSingleTouch(); 
    } 
  
    public void setOnSingleTouchListener(OnSingleTouchListener onSingleTouchListener) { 
        this.onSingleTouchListener = onSingleTouchListener; 
    } 
  
}   
---------------------------------------------------------------------------------------------------------------------------------- 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值