每次我从后堆栈中删除YouTubePlayerSupportFragment
时,都会在logcat中收到以下错误:
06-12 02:08:46.937 8805-8805/ D/GA_DEBUG: Event_category:VideoContent-Portrait-This artist uses unique methods to paint his pottery action:play label:youtube {&el=youtube, &ec=VideoContent-Portrait-This artist uses unique methods to paint his pottery, &t=event, &ea=play, &cd6=online}
06-12 02:08:46.945 10194-10194/? E/ActivityThread: Service com.google.android.youtube.api.service.YouTubeService has leaked IntentReceiver uds@5fa5135 that was originally registered here. Are you missing a call to unregisterReceiver()?
android.app.IntentReceiverLeaked: Service com.google.android.youtube.api.service.YouTubeService has leaked IntentReceiver uds@5fa5135 that was originally registered here. Are you missing a call to unregisterReceiver()?
at android.app.LoadedApk$ReceiverDispatcher.<init>(LoadedApk.java:946)
at android.app.LoadedApk.getReceiverDispatcher(LoadedApk.java:742)
at android.app.ContextImpl.registerReceiverInternal(ContextImpl.java:1188)
at android.app.ContextImpl.registerReceiver(ContextImpl.java:1168)
at android.app.ContextImpl.registerReceiver(ContextImpl.java:1162)
at android.content.ContextWrapper.registerReceiver(ContextWrapper.java:555)
at udq.<init>(SourceFile:21)
at udx.get(SourceFile:9)
at vkq.get(SourceFile:31)
at aces.get(SourceFile:10)
at hog.a(SourceFile:26)
at hpb.a(SourceFile:883)
at hnz.<init>(SourceFile:13)
at com.google.android.apps.youtube.embeddedplayer.service.service.jar.ApiPlayerService.<init>(SourceFile:60)
at com.google.android.apps.youtube.embeddedplayer.service.service.jar.ApiPlayerFactoryService$1.run(SourceFile:10)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:152)
at android.app.ActivityThread.main(ActivityThread.java:5497)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
06-12 02:08:46.968 10194-10194/? E/ActivityThread: Service com.google.android.youtube.api.service.YouTubeService has leaked IntentReceiver udp@a7bd896 that was originally registered here. Are you missing a call to unregisterReceiver()?
android.app.IntentReceiverLeaked: Service com.google.android.youtube.api.service.YouTubeService has leaked IntentReceiver udp@a7bd896 that was originally registered here. Are you missing a call to unregisterReceiver()?
at android.app.LoadedApk$ReceiverDispatcher.<init>(LoadedApk.java:946)
at android.app.LoadedApk.getReceiverDispatcher(LoadedApk.java:742)
at android.app.ContextImpl.registerReceiverInternal(ContextImpl.java:1188)
at android.app.ContextImpl.registerReceiver(ContextImpl.java:1168)
at android.app.ContextImpl.registerReceiver(ContextImpl.java:1162)
at android.content.ContextWrapper.registerReceiver(ContextWrapper.java:555)
at vki.<init>(SourceFile:53)
at vkq.get(SourceFile:32)
at aces.get(SourceFile:10)
at hog.a(SourceFile:26)
at hpb.a(SourceFile:883)
at hnz.<init>(SourceFile:13)
at com.google.android.apps.youtube.embeddedplayer.service.service.jar.ApiPlayerService.<init>(SourceFile:60)
at com.google.android.apps.youtube.embeddedplayer.service.service.jar.ApiPlayerFactoryService$1.run(SourceFile:10)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:152)
at android.app.ActivityThread.main(ActivityThread.java:5497)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
06-12 02:08:47.015 8805-8805/I/ResourcesManager: isUpToDate /data/app/com.google.android.youtube-1/base.apk: true
我做错了什么?在删除片段之前,我确实将所有资源设置为 null 并在播放器实例上调用release()
,但此日志仍然存在。
在尝试了多种方式在项目中使用 Youtube 播放器片段之后,我们在回收器视图中显示视频列表,每个视频都可以就地播放(当然一次一个(。
仅管理适当的生命周期(将片段从一个地方删除到另一个地方时调用发布(只有在您快速完成之前才能工作,如果您碰巧尝试同时播放 2 个视频,则会发生上述问题(即内部 YouTube SDK 会在消息队列中泄漏一些触摸事件(
因此,我们不是为每个视频替换 YouTube 片段,而是只创建一个片段实例并在应用程序中的所有位置重复使用它,如果活动生命周期事件(暂停/停止或保存的实例状态被调用(,那么我们发布片段并在恢复时再次创建 YouTube 片段的单个活动实例
这种方法实际上也解决了上述问题 https://issuetracker.google.com/issues/78370483