首页 > 其他分享 >GapWorker导致RecyclerView视频播放声音残留问题

GapWorker导致RecyclerView视频播放声音残留问题

时间:2022-11-09 23:32:54浏览次数:46  
标签:java GapWorker logStackTrace android 播放 RecyclerView xxxxx


场景描述

  • App 有两个tab,每一个都是Fragment,以FragmentA和FragmentB 代称.
  • 切到FragmentA 视频播放(在RecyclerViewA 内部),然后切到FragmentB 视频暂停.
  • 就在此刻,滑动FragmentB 的recyclerView B ,来自FragmentA的视频播放出声音,而且声音是下一条视频的声音。

这确实是一个非常奇怪的问题,不滑动不会出现视频播放声音,必须滑动一下才能出现声音。

解决思路

1.分析日志,查找播放业务相关的代码
2.增加logStackTrace(“xxx”)用来打印出调用的栈信息

辅助方法

该方法用来查看调用的层级关系,实现原理很简单,就是生成一个Throwable,然后打印stacktrace。



fun logStackTrace(tag: String) {
if (BuildConfig.DEBUG) {
Log.w("logStackTrace $tag", Throwable(tag))
}
}

问题日志

于是我们得到了如下的日志



W logStackTrace :
W logStackTrace : java.lang.Throwable:
W logStackTrace : at com.xxxxx.commonsdk.utils.ExtensionKt.logStackTrace(Extension.kt:99)
W logStackTrace : at com.xxxxx.xxxxx.xxx.video.DiscoveryVideoPlayer.setUp(DiscoveryVideoPlayer.java:786)
W logStackTrace : at com.shuyu.gsyvideoplayer.video.base.GSYVideoView.setUp(GSYVideoView.java:446)
W logStackTrace : at com.shuyu.gsyvideoplayer.video.base.GSYVideoControlView.setUp(GSYVideoControlView.java:541)
W logStackTrace : at com.xxxxx.xxxxx.xxx.ui.adapter.VideoFeedAdapter.initVideo(VideoFeedAdapter.java:211)
W logStackTrace : at com.xxxxx.xxxxx.xxx.ui.adapter.VideoFeedAdapter.onBindViewHolder(VideoFeedAdapter.java:127)
W logStackTrace : at com.xxxxx.xxxxx.xxx.ui.adapter.VideoFeedAdapter.onBindViewHolder(VideoFeedAdapter.java:34)
W logStackTrace : at android.support.v7.widget.RecyclerView$Adapter.onBindViewHolder(RecyclerView.java:6673)
W logStackTrace : at android.support.v7.widget.RecyclerView$Adapter.bindViewHolder(RecyclerView.java:6714)
W logStackTrace : at android.support.v7.widget.RecyclerView$Recycler.tryBindViewHolderByDeadline(RecyclerView.java:5647)
W logStackTrace : at android.support.v7.widget.RecyclerView$Recycler.tryGetViewHolderForPositionByDeadline(RecyclerView.java:5913)
W logStackTrace : at android.support.v7.widget.GapWorker.prefetchPositionWithDeadline(GapWorker.java:285)
W logStackTrace : at android.support.v7.widget.GapWorker.flushTaskWithDeadline(GapWorker.java:342)
W logStackTrace : at android.support.v7.widget.GapWorker.flushTasksWithDeadline(GapWorker.java:358)
W logStackTrace : at android.support.v7.widget.GapWorker.prefetch(GapWorker.java:365)
W logStackTrace : at android.support.v7.widget.GapWorker.run(GapWorker.java:396)
W logStackTrace : at android.os.Handler.handleCallback(Handler.java:891)
W logStackTrace : at android.os.Handler.dispatchMessage(Handler.java:102)
W logStackTrace : at android.os.Looper.loop(Looper.java:207)
W logStackTrace : at android.app.ActivityThread.main(ActivityThread.java:7470)
W logStackTrace : at java.lang.reflect.Method.invoke(Native Method)
W logStackTrace : at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:524)
W logStackTrace : at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:958)

问题症结

问题的症结就在GapWorker调用导致了RecyclerView的item预加载处理。

解决方法



yourLayoutManager.setItemPrefetchEnabled(false);

为什么会这样



/**
* Sets whether the LayoutManager should be queried for views outside of
* its viewport while the UI thread is idle between frames.
*
* <p>If enabled, the LayoutManager will be queried for items to inflate/bind in between
* view system traversals on devices running API 21 or greater. Default value is true.</p>
*
* <p>On platforms API level 21 and higher, the UI thread is idle between passing a frame
* to RenderThread and the starting up its next frame at the next VSync pulse. By
* prefetching out of window views in this time period, delays from inflation and view
* binding are much less likely to cause jank and stuttering during scrolls and flings.</p>
*
* <p>While prefetch is enabled, it will have the side effect of expanding the effective
* size of the View cache to hold prefetched views.</p>
*
* @param enabled <code>True</code> if items should be prefetched in between traversals.
*
* @see #isItemPrefetchEnabled()
*/

上述是​​setItemPrefetchEnabled​​的注释,item prefetch是一种用来减少滑动时卡顿的一种预加载方式。这种对于普通的RecyclerView的item没有问题,但是对于视频有声音的,就显得问题明显了。所以这里的解决方法就是关闭这个预取的设置。

以上。

标签:java,GapWorker,logStackTrace,android,播放,RecyclerView,xxxxx
From: https://blog.51cto.com/u_3987305/5838989

相关文章

  • 常用网页播放器代码
     我们在网页上看到的播放器无外乎WMP/RealOne/MacromediaFlashPlayer,其他的无非是面板不同,或者添加了其他控件,对于计算机上安装的一些播放器也都是编码和解码器的整合,其......
  • 34_音视频播放器_音视频同步
    目录简介实现音视频同步处理没有音频的播放更新界面播放的进度条处理切换音视频时还保留上一个视频的最后一帧画面简介音视频同步的实现可以有两种方式视频同步到音频......
  • 33_音视频播放器_画面显示
    目录一、简介二、视频解码2.1解码视频2.2调用解码视频方法三、像素格式转换3.1初始化3.2像素格式转换四、显示画面4.1定义信号4.2发送信号4.3定义槽函数4.4注册监......
  • 32_音视频播放器_SDL播放
    目录一、简介二、音频重采样2.1引入头文件2.2定义重采样相关属性2.3初始化重采样2.4重采样三、SDL播放四、停止功能五、处理读完音频包的情况六、实现调节音量七、实现......
  • 视频融合平台EasyCVR首路录像无法播放是什么原因?该如何解决?
    EasyCVR具备较强的视频能力,可支持海量设备接入、汇聚与管理、视频监控、视频录像、云存储、回放与检索、智能告警、平台级联等功能。平台可支持多协议接入,包括:国标GB/T2818......
  • 视频融合平台EasyCVR继承播放器,但是无法播放该如何解决?
    EasyCVR视频融合云平台基于云边端一体化架构,兼容性高、拓展性强,可支持多类型设备、多协议方式接入,包括国标GB/T28181、RTMP、RTSP/Onvif协议,以及厂家的私有协议,如:海康Ehome......
  • 30_音视频播放器_解封装
    目录一、简介二、读出文件三、初始化3.1读取文件3.2初始化音频信息和视频信息3.3初始化解码器四、实现视频时长一、简介我们使用QT+ffmpeg实现一个播放器,这里我们主要......
  • 【操作说明】全能型H.265播放器如何使用?
    本播放器集成了公司业务的接口,包含了实播,回放,云台控制和回放速度控制,截图和全屏功能可以根据type直接初始化接口地址如果是第三方业务对接,也可以单独配置接口地址正确使用......
  • 【适合小白教程】 喜马拉雅电台声音下载到电脑本地进行播放!
    前段时间有个需求,想把一个喜欢的主播喜马拉雅的声音下载到笔记本电脑上进行本地播放。不过有个问题,就是喜马拉雅软件并不支持直接下载声音文件到电脑本地,所以这就成了一个......
  • 融云 CDN 播放器 2.0 版本正式上线
    近期,融云自研CDN播放插件2.0版本正式上线。在原有版本支持融云内置CDN直播流播放的基础上,开放了相关API,满足开发者的多种业务需求。关注【融云全球互联网通信云】了......