我正在构建一个从外部服务器流式传输实时音频的应用程序。流式传输一段时间(通常为 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 测试了我的应用程序。