ViewPager/ViewPager2 +Fragment 播放视频遇到的坑

博客围绕以SurfaceView为核心的播放器展开,指出上下滑动ViewPager/ViewPager2时,视频底部或顶部会出现上条视频画面的问题,原因是播放器宽高超出Fragment根布局。同时给出三种解决方案,包括在特定生命周期隐藏显示视频、调整视频大小、关闭ViewPager2预加载,总结认为设置缩略图最靠谱。

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

1、播放视频其核心无非就是SurfaceView or TextrueView、当我们的播放器是SurfaceView时就会出现诡异的问题、如果您用的是SurfaceView为核心的播放器、请继续往下看;


问题:上下滑动ViewPager/ViewPager2 当前视频底部或顶部有上条视频的画面;

原因:播放器(SurfaceView)的宽高超出了Fragment根布局的大小、 当进行上下滑动时、就会出现遮挡其他界面的问题、SurfaceView 是个特殊的View 其大小不受外界布局控制、这就时问题原因;

解决方案:

A、在Fragment onPause、onResume中对视频进行隐藏、显示、如在onPause中隐藏视频、在onResume 中显示视频、 会有黑屏/白屏(取决于视频背景设置)闪屏问题、解决办法只能用视频截图、或者视频缩略图、视频隐藏时展示、视频展示时隐藏

B、在Fragment onPause、onResume中对视频大小做出调整、如在onPause中设置视频大小、小于 Fragment根布局大小、 onResume时还原视频大小、不会出现黑屏、白屏问题、 但是如果视频原尺寸很大、会明显感觉视频缩放明显、体验很差;

C、关闭ViewPager2预加载、viewPager2.offscreenPageLimit=0、Viewpager 貌似无法关闭、默认缓存大小1、


总结:最靠谱的还是A、设置缩略图

在Android中,ViewPager2配合TabLayout以及Fragment一起使用,可以创建一个非常常见的滑动导航栏和片段切换界面。这是一个流行的组合,用于构建像新闻应用、图片画廊或设置菜单这样的用户界面。 1. **设置布局**: - 在XML布局文件中,添加一个`RecyclerView`作为View Pager,并将其id设为`view_pager`。 - 同时添加一个`TabLayout`,通常放置在顶部,用于显示各个选项卡,id例如设为`tab_layout`. 2. **初始化组件**: - 创建一个`TabLayoutMediator`实例,将TabLayout和ViewPager关联起来,动态管理标签和视图之间的对应关系。 ```java TabLayoutMediator mediator = new TabLayoutMediator(tabLayout, viewPager, viewPager::setAdapter); mediator.attach(); ``` 3. **创建FragmentPagerAdapter**: - 自定义一个`FragmentPagerAdapter`,它可以管理多个`Fragment`实例。 ```java class MyFragmentAdapter extends FragmentStateAdapter { //... @NonNull @Override public Fragment createFragment(int position) { return MyFragment.newInstance(position); // "MyFragment"是你自定义的Fragment类 } } ``` 4. **设置Adapter**: - 将`FragmentPagerAdapter`设置到`ViewPager`上。 ```java viewPager.setAdapter(new MyFragmentAdapter(getSupportFragmentManager())); ``` 5. **处理Tab点击事件**: - TabLayout有内置的监听器,可以在选中新的标签时更新对应的Fragment。 ```java tabLayout.addOnTabSelectedListener(new TabLayout.OnTabSelectedListener() { @Override public void onTabSelected(TabLayout.Tab tab) { viewPager.setCurrentItem(tab.getPosition()); } //其他方法... }); ```
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值