gpt4 book ai didi

android - 有时 MediaPlayer prepareAsyc() 在按下电源之前不会调用 onPrepared()

转载 作者:塔克拉玛干 更新时间:2023-11-02 20:10:12 24 4
gpt4 key购买 nike

一段时间以来,我一直在尝试重现我的 QA 团队所说的“随机暂停错误”。今天在logcat on调试的时候重现了三遍。它间歇性地出现,并且只在网络不佳的情况下出现。

用户体验到音频暂停,直到他们触摸他们的手机(按下电源或轨迹球),它立即再次开始播放。这是因为我在 onPrepared 回调中调用了 start,而在这些情况下从不调用 start。这是我们最严重的错误。

我所知道的:

1) 这种情况在带有 2.2.1 的 Nexus One 上间歇性地发生(不确定它是否在其他设备上)

2) 我在设备屏幕关闭时从 PlaybackService 调用 prepareAsyc()。有时,永远不会调用 onPrepared(),所以我随后的 mediaplayer.start() 调用永远不会被触发。我可以通过网络嗅探器和正在发生缓冲的缓冲回调看到。

3) 如果我触摸设备电源或轨迹球来唤醒它,onPrepared() 会立即被调用(已经缓冲)并且我的回调开始播放。

以下是带有时间戳的日志,该问题出现了三次:

第一个例子(20 秒内没有回调,直到我按下电源按钮):

11-10 16:10:55.966 I/AwesomePlayer(   59): calling prefetcher->prepare()
11-10 16:11:15.511 D/KeyguardViewMediator( 94): wakeWhenReadyLocked(26)
11-10 16:11:15.511 D/KeyguardViewMediator( 94): handleWakeWhenReady(26)
11-10 16:11:15.511 D/KeyguardViewMediator( 94): pokeWakelock(5000)
11-10 16:11:15.511 I/power ( 94): *** set_screen_state 1
11-10 16:11:15.561 D/SurfaceFlinger( 94): Screen about to return, flinger = 0x1fe300
11-10 16:11:15.701 D/AK8973 ( 64): Compass Start
11-10 16:11:15.701 D/WifiService( 94): ACTION_SCREEN_ON
11-10 16:11:15.711 I/Prefetcher( 59): [0x602d80] cache below low water mark, filling cache.
11-10 16:11:15.821 I/AwesomePlayer( 59): prefetcher is done preparing
11-10 16:11:15.831 W/MogMediaPlayer.onPreparedListener( 2968): onPrepared, calling notifyPrepared()

另外两个例子(第一次是在我启动前 3 秒,接下来是 8 秒):

11-10 16:14:54.649 I/AwesomePlayer(   59): calling prefetcher->prepare()
11-10 16:14:57.500 D/KeyguardViewMediator( 94): wakeWhenReadyLocked(26)
11-10 16:14:57.500 D/KeyguardViewMediator( 94): handleWakeWhenReady(26)
11-10 16:14:57.500 D/KeyguardViewMediator( 94): pokeWakelock(5000)
11-10 16:14:57.500 I/power ( 94): *** set_screen_state 1
11-10 16:14:57.560 D/SurfaceFlinger( 94): Screen about to return, flinger = 0x1fe300
11-10 16:14:57.580 D/WifiStateTracker( 94): Reset connections and stopping DHCP
11-10 16:14:57.580 D/WifiService( 94): ACTION_SCREEN_ON
11-10 16:14:57.670 I/Prefetcher( 59): [0xa990] cache below low water mark, filling cache.
11-10 16:14:57.700 D/AK8973 ( 64): Compass Start
11-10 16:14:57.800 I/AwesomePlayer( 59): prefetcher is done preparing
11-10 16:14:57.800 W/MogMediaPlayer.onPreparedListener( 2968): onPrepared, calling notifyPrepared()



11-10 16:39:03.608 I/AwesomePlayer( 59): calling prefetcher->prepare()
11-10 16:39:11.506 D/KeyguardViewMediator( 94): wakeWhenReadyLocked(26)
11-10 16:39:11.506 D/KeyguardViewMediator( 94): handleWakeWhenReady(26)
11-10 16:39:11.506 D/KeyguardViewMediator( 94): pokeWakelock(5000)
11-10 16:39:11.506 I/power ( 94): *** set_screen_state 1
11-10 16:39:11.566 D/SurfaceFlinger( 94): Screen about to return, flinger = 0x1fe300
11-10 16:39:11.586 D/WifiStateTracker( 94): Reset connections and stopping DHCP
11-10 16:39:11.586 D/WifiService( 94): ACTION_SCREEN_ON
11-10 16:39:11.716 D/AK8973 ( 64): Compass Start
11-10 16:39:11.766 I/Prefetcher( 59): [0x59ac18] cache below low water mark, filling cache.
11-10 16:39:11.856 I/AwesomePlayer( 59): prefetcher is done preparing
11-10 16:39:11.946 W/MogMediaPlayer.onPreparedListener( 2968): onPrepared, calling notifyPrepared()

有人知道这个错误或如何解决它吗?

提前致谢,本

最佳答案

我在 Android 2.3.3、2.3.7 和 4.1.2 上遇到了非常相似的问题。对我来说,在正常工作一段时间后,MediaPlayer 随机拒绝加载。不同之处在于,对我来说,电源按钮也无济于事 - 什么都没有,根本就不会调用 onPrepared 。我正在播放来自 SD 卡而不是网络的文件,因此缓冲不是问题。当文件被频繁加载时,它会发生更多,但一般来说,这个错误很容易发生,足以影响我的所有用户。

你的问题似乎与我有关,但遗憾的是我也没有答案。我在这里发布这个以收集有关该问题的更多信息。我尝试使用 setDataSource、prepare、prepareAsync 以及立即开始加载指定文件的 MediaPlayer.create() 方法。我尝试重复使用相同的 mediaplyer(使用 mp.reset())并为每个要加载的新文件创建一个全新的媒体播放器(我停止并事先调用前一个播放器的 release()),但没有任何区别:如果用户开始更快地切换文件(但不过分 - 我希望任何媒体应用程序都能处理这个问题),每 5 个文件中将近 1 个文件无法指示失败或加载。

关于android - 有时 MediaPlayer prepareAsyc() 在按下电源之前不会调用 onPrepared(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4150907/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com