3

我正在构建一个从外部服务器流式传输实时音频的应用程序。流式传输一段时间(通常为 5-20 分钟)后,音频播放停止。首先我得到 703-MEDIA_INFO_NETWORK_BANDWIDTH(通常连同额外 = 0)然后 701-MEDIA_INFO_BUFFERING_START

但我从来没有得到702- MEDIA_INFO_BUFFERING_END 。我没有收到对 onCompletion 或 onError 的回调。

A small stack:

08-28 09:18:17.969: WARN/MediaPlayer(7100): info/warning (703, 0)

08-28 09:18:17.969: WARN/MediaPlayer(7100): info/warning (701, 0)

08-28 09:18:17.969: INFO/MediaPlayer(7100): Info (703,0)

08-28 09:18:17.979: INFO/MediaPlayer(7100): Info (701,0)

08-28 09:18:18.029: DEBUG/dalvikvm(7100): GC_CONCURRENT freed 1307K, 15% free 13198K/15376K, paused 5ms+3ms, total 28ms

08-28 09:18:19.411: DEBUG/dalvikvm(16310): GC_CONCURRENT freed 315K, 4% free 9909K/10264K, paused 7ms+6ms, total 69ms

08-28 09:18:20.992: DEBUG/audio_hw_primary(176): out_standby: enter: usecase(1: low-latency-playback)

08-28 09:18:21.082: DEBUG/audio_hw_primary(176): stop_output_stream: enter: usecase(1: low-latency-playback)

08-28 09:18:21.082: DEBUG/audio_hw_primary(176): disable_audio_route: reset mixer path: low-latency-playback

08-28 09:18:21.082: DEBUG/audio_hw_primary(176): disable_snd_device: snd_device(4: headphones)

08-28 09:18:21.102: DEBUG/audio_hw_primary(176): stop_output_stream: exit: status(0)

08-28 09:18:21.102: DEBUG/audio_hw_primary(176): out_standby: exit 

如您所见,audio_hw_primary 中发生了一些看起来很可疑的事情。我已经搜索过它是什么,但没有找到好的答案。

我的 MediaPlayer 在作为前台启动的服务中运行,我非常有信心我的实现遵循 google 的所有准则:http: //developer.android.com/guide/topics/media/mediaplayer.html

我已经在 Nexus 4 上使用 Android 4.1-4.3 测试了我的应用程序。

4

1 回答 1

0

http://developer.android.com/guide/topics/media/mediaplayer.html 您阅读了有关“使用唤醒锁”的信息。

为确保在 MediaPlayer 播放时 CPU 继续运行,请在初始化 MediaPlayer 时调用 setWakeMode() 方法。一旦你这样做了,MediaPlayer 会在播放时持有指定的锁,并在暂停或停止时释放锁:

mMediaPlayer = new MediaPlayer();
// ... other initialization here ...
mMediaPlayer.setWakeMode(getApplicationContext(), PowerManager.PARTIAL_WAKE_LOCK);

但是,在此示例中获取的唤醒锁仅保证 CPU 保持唤醒状态。如果您通过网络流式传输媒体并且使用 Wi-Fi,您可能还想持有一个 WifiLock,您必须手动获取和释放它。因此,当您开始使用远程 URL 准备 MediaPlayer 时,您应该创建并获取 Wi-Fi 锁。例如:

WifiLock wifiLock = ((WifiManager) getSystemService(Context.WIFI_SERVICE))
    .createWifiLock(WifiManager.WIFI_MODE_FULL, "mylock");

wifiLock.acquire();
于 2013-08-28T07:46:06.087 回答