我正在开发一个音频流应用程序,但是在几台设备上30秒后应用程序终止。用户可以在后台播放音频,但有时它会停止并终止应用。
这非常令人讨厌,很难追踪,因为它只会影响一些设备而不是所有时间。这是日志显示的内容:
V/MediaPlayer-JNI: release
V/MediaPlayer-JNI: setListener
disconnected
V/MediaPlayer-JNI: destructor
disconnected
W/MediaPlayer: mediaplayer went away with unhandled events
D/ContentValues: onDestroy
Application terminated.
看起来该应用程序很容易被操作系统杀死。
“媒体播放器因未处理的事件而离开”是音频文件未正确启动时的常见问题,但在这种情况下,30秒后流式传输时会出现错误。
这是我正在使用的代码:
public class SoundService extends Service implements MediaPlayer.OnPreparedListener, MediaPlayer.OnSeekCompleteListener, MediaPlayer.OnCompletionListener, MediaPlayer.OnBufferingUpdateListener, MediaPlayer.OnErrorListener {
public void onCreate() {
Log.i("Script", "onCreate");
if(player == null){
try {
Log.i("Script", "onCreate: Try");
player = new MediaPlayer();
player.setDataSource("enter url");
player.prepareAsync();
player.setOnBufferingUpdateListener(this);
player.setOnCompletionListener(this);
player.setOnErrorListener(this);
player.setOnPreparedListener(this);
player.setOnSeekCompleteListener(this);
}
catch (IllegalArgumentException e) { e.printStackTrace(); }
catch (SecurityException e) { e.printStackTrace(); }
catch (IllegalStateException e) { e.printStackTrace(); }
catch (IOException e) { e.printStackTrace(); }
}
else{
Log.i("Script", "onCreate: start");
player.start();
}
}
以下是听众:
@Override
public void onPrepared(MediaPlayer mp) {
Log.i("Script", "onPrepared()");
player.start();
}
public int onStartCommand(Intent intent, int flags, int startId) {
Log.i("Script", "onStartCommand");
return Service.START_NOT_STICKY;
}
有任何想法吗?谢谢!
确保使用startForeground通知启动服务中的媒体播放器。这应该保持服务,而不让操作系统杀死它。