关于ViewPager 嵌套ViewPager和flyco依赖冲突的解决办法

本文介绍如何解决ViewPager嵌套使用时的滑动监听控制及Fragment管理问题,并提供了一个具体的代码示例。同时讨论了如何避免第三方库与嵌套ViewPager之间的冲突。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先明确一点的是ViewPager是可以嵌套ViewPager的

最外层ViewPager控制主页面,简称为pOne

pOne的某一个子页面,或多个子页面嵌套的ViewPager ,简称为pSon

其实简单的嵌套,带来的问题主要是两点:

1.pOne与pSon的滑动监听控制

2.pOne与pSon的关联fragment的管理


解决办法也很简单:

1.在不做任何处理的情况下,在滑动页面时,只有当pSon滑动完所有页面,pOne才会继续滑动页面

如果想要只控制pSon的滑动,其实可以通过重写ViewPager,将pOne的滑动监听事件禁掉就可以了。

重写代码:

package com.hjk.shiny.weshop.overwrite;

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

/**
 * Created by Maibenben on 2017/12/7.
 */

public class CustomViewPager extends  ViewPager{

    //滑动开关控制常量
    private boolean enable=false;

    //重写构造
    public CustomViewPager(Context context){
        super(context);
    }
    //重写构造
    public CustomViewPager(Context context, AttributeSet attrs) {
        super(context, attrs);
    }


    //触碰事件
    @Override
    public boolean onTouchEvent(MotionEvent ev) {

        if(this.enable){
            //开关打开,事件不进行拦截
            return super.onTouchEvent(ev);
        }

        //默认拦截状态
        return false;
    }


    //拦截事件监听
    @Override
    public boolean onInterceptTouchEvent(MotionEvent ev) {

        if(this.enable){
            //开关打开,即处理拦截下来的touch事件
            return super.onInterceptTouchEvent(ev);
        }

        //默认状态不处理来接下来的事件
        return  false ;
    }



    //传递触摸事件
    @Override
    public boolean dispatchTouchEvent(MotionEvent ev) {

        //处理事件的分发,将拦截到的事件分发到viewpager下的子view中去
        //这个拦截了就没有后续事件发生了,到viewpager为止

        //可以拦
        if(this.enable){
            return super.dispatchTouchEvent(ev);
        }

        //一般都不拦的
        return super.dispatchTouchEvent(ev);
    }


    //留一个方法修改开关的开启关闭状态
    public boolean setViewPagerState(Boolean b){
        this.enable=b;

        return this.enable;
    }
}
注释很详细,就不多说了


2.关于fragment的管理。

由于pSon创建于pOne的fragment页面中,所以在获取自己的FragmentManager时,需要通过getChildFragmentManager()方法来获取,而不是像pOne在Activity中通过getSupportFragmentManager()或者getFragmentManager()来获取。通过FragmentPagerAdapter的继承子类适配器来适配pSon即可。




接下来再来谈一谈 依赖库 com.flyco.tablayout ,没用过或者不知道下载地址的话,可以通过这个链接去看看:

https://github.com/H07000223/FlycoTabLayout 

东西是好东西,可惜在ViewPager与ViewPager的嵌套过程中起了冲突,在pOne中嵌套使用FlycoTabLayout
会使得pSon与pOne的FragmentManager出现线程混乱的问题,最终结果即导致线程奔溃报错。

解决办法:
使pOne与pSon处于伪嵌套关系,即pOne与pSon实际处理平行关系,在两个视图交接处通过Gone和Visible的切换,
实现视觉嵌套效果。
代码很简单,就不贴了,稍后会贴出整个应用的框架代码,即拿即用,往里填内容即可。


介绍:一个基于RecyclerView实现的ViewPager,支持类似于gallary的fling操作。点击上面"下载源码" 按钮,可以下载完整的demo。其中recyclerview是android-support中的依赖项目,RecyclerViewPager是主项目。运行效果:使用说明:继承自 RecyclerView.自定义 fling factor.自定义 paging trigger.支持 水平个垂直方向.支持 FragmentViewPager (api 12 )gradlecompile('com.lsjwzh:recyclerviewpager:1.0.2')xml:java:final RecyclerViewPager mRecyclerView = (RecyclerViewPager) this.findViewById(R.id.recyclerViewPager); LinearLayoutManager layout = new LinearLayoutManager(this, LinearLayoutManager.HORIZONTAL,false);//LinearLayoutManager.HORIZONTAL 设置水平滚动 mRecyclerView.setLayoutManager(layout); //set adapter mRecyclerView.setAdapter(new MyRecyclerAdapter());static class MyRecyclerAdapter extends RecyclerView.Adapter { private List items = new ArrayList(); public MyRecyclerAdapter(){ //创建4个页面 for(int i = 1; i<5; i ){ items.add("页面" i); } } public static class ViewHolder extends RecyclerView.ViewHolder{ public ViewHolder(View itemView) { super(itemView); } } @Override public int getItemCount() { // TODO Auto-generated method stub return items.size(); } @Override public void onBindViewHolder(ViewHolder holder, int position) { String item = items.get(position); TextView msgTv = (TextView)holder.itemView.findViewById(R.id.msg); msgTv.setText(item); } @Override public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { if(inflate == null) inflate = (LayoutInflater) parent.getContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE); View v = (LinearLayout)(inflate.inflate(R.layout.item, null)); return new 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值