ViewPager动态添加Fragment

ViewPager动态添加Fragment,在需要的时候才会去添加对应的Fragment。

首先创建Fragment 的适配器ViewPagerAdapter

class ViewPagerAdapter : FragmentStatePagerAdapter {
    private var fragments: MutableList<Fragment> = mutableListOf()
    private var context: Context

    constructor(context: Context, fm: FragmentManager, fragments: List<Fragment>) : super(fm) {
        this.context = context
        this.fragments.addAll(fragments)
        notifyDataSetChanged()
    }

    constructor(context: Context, fm: FragmentManager) : super(fm) {
        this.context = context
        notifyDataSetChanged()
    }
    constructor(context: Context, fm: FragmentManager,index:Int,fragment: Fragment) : super(fm) {
        this.context = context
        this.fragments.add(index,fragment)
        notifyDataSetChanged()
    }
    fun addFragment(context: Context,index:Int,fragment: Fragment){
        this.context = context
        this.fragments.add(index,fragment)
        notifyDataSetChanged()
    }

    override fun getItem(arg0: Int): Fragment {
        return fragments[arg0]
    }

    override fun getItemPosition(`object`: Any): Int {
        //注意:默认是PagerAdapter.POSITION_UNCHANGED,不会重新加载
        return PagerAdapter.POSITION_NONE
    }

    override fun getCount(): Int {
        return fragments.size
    }


}

然后是在页面布局中创建ViewPager

<androidx.viewpager.widget.ViewPager
                        android:layout_marginTop="@dimen/dp_10"
                        android:id="@+id/mViewPager"
                        style="@style/MatchAuto"/>

最后就是在代码中的调用

1.初始化ViewPagerAdapter

private val pageAdapter by lazy {
         ViewPagerAdapter(this@ConvertTextResultActivityAI2,supportFragmentManager,
             mutableListOf()
         )
     }

2.使用ViewPager

mViewPager.adapter = pageAdapter
        mViewPager.offscreenPageLimit = 3
        mViewPager.currentItem = 0
        mViewPager.isEnableScroll = true

3.在需要时添加Fragment

pageAdapter.addFragment(this,0,MyFragment())

直接像上面那样调用即可

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值