ViewPager2 +Fragment 制作短视频播放的坑、总结(Kotlin)

说明:个人使用ijkPlayer播放器(哔哩哔哩开源)、 注意点:默认不支持https格式在线视频、需要so库支持、 Ijk加载部分Https视频 前几秒会有播放过慢的情况。解决方案:https://blog.csdn.net/BirdEatBug/article/details/116665446?spm=1001.2014.3001.5501


实现步骤:1、继承 FragmentStateAdapter(activity/fragment) 、2、实现 getItemCount、createFragment()、getItemId()(为了刷新)。在createFragment()函数中返回Fragment对象。 以下为简单代码实例:

class VideoPagerAdapter(fragment: Fragment) : FragmentStateAdapter(fragment) {

    private val dataList = mutableListOf<VideoSelectFragment>()

    fun addData(newData: MutableList<VideoSelectFragment>) {
        if (newData.isNotEmpty()) {
            val oldSize = dataList.size
            dataList.addAll(newData)
            notifyItemRangeInserted(oldSize, dataList.size)
        }
    }

    fun addFirstData(newData: MutableList<VideoSelectFragment>) {
        if (newData.isNotEmpty()) {
            dataList.clear()
            dataList.addAll(newData)
            notifyDataSetChanged()
        }
    }

    fun getData() = dataList

    override fun getItemCount() = dataList.size

    override fun createFragment(position: Int): Fragment {
        return dataList[position]
    }

    override fun getItemId(position: Int): Long {
        return dataList[position].hashCode().toLong()
    }
}

坑总结:1、Fragment 嵌套Fragment 生命周期错乱。 原因FragmentStateAdapter(activity)传入错误参数、应改为FragmentStateAdapter(fragment);

2、ViewPager2 列表无法刷新问题。原因暂不知、需将getItemId() 的hashCode返回、作为唯一表示;参考如上代码、即可解决;

3、结合SmallRefreshLayout(第三方刷新库 用于滑动到顶部底部的判断、)下拉刷新时出现ViewPager2 不滚动底部问题,解决办法、等finishLoadMore()执行完毕后、延迟刷新ViewPager2。

 

其他信息补充:ViewPager2 可以设置离屏加载、类似于ViewPager的预加载、 使用:viewPager.offscreenPageLimit=100(在每次数据请求后、可以动态设置离屏加载数量,注意此为KT语法)


好的,这里是一个简单的示例代码,演示了如何使用ViewPager2Fragment来实现页面切换: 首先,在你的布局文件中添加ViewPager2: ```xml <androidx.viewpager2.widget.ViewPager2 android:id="@+id/view_pager" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 然后,在你的Activity或Fragment中,创建一个PagerAdapter,并将其设置给ViewPager2: ```kotlin class MyPagerAdapter(fragment: Fragment) : FragmentStateAdapter(fragment) { override fun getItemCount() = 3 override fun createFragment(position: Int): Fragment { return when (position) { 0 -> FragmentOne() 1 -> FragmentTwo() else -> FragmentThree() } } } // 在Activity或Fragmentview_pager.adapter = MyPagerAdapter(this) ``` 在这个示例中,PagerAdapter有三个页面,分别对应着FragmentOne、FragmentTwo和FragmentThree。你可以根据自己的需求,自定义PagerAdapter的实现。 最后,你需要在你的Fragment中实现具体的布局和逻辑: ```kotlin class FragmentOne : Fragment() { override fun onCreateView( inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle? ): View? { return inflater.inflate(R.layout.fragment_one, container, false) } override fun onViewCreated(view: View, savedInstanceState: Bundle?) { super.onViewCreated(view, savedInstanceState) // TODO: 在这里添加具体的逻辑 } } ``` 重复以上步骤,你就可以创建多个不同的Fragment,然后用ViewPager2来切换它们了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值