(我已经解决了,只需向下滚动直到编辑2)
我有一个应用程序,在打开时,循环播放背景音乐。我决定我可以更进一步,暂停bgm,当应用程序暂停并在恢复暂停时播放。它工作正常。
然而,我遇到的问题是当我退出应用程序时。它给出了错误:
10-07 22:50:04.535: E/AndroidRuntime(5852): java.lang.RuntimeException: Unable to pause activity {com.cs119.megamanstrikes/com.cs119.megamanstrikes.MainActivity}: java.lang.IllegalStateException
我的onCreate看起来像:
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
backgroundMusic = MediaPlayer.create(MainActivity.this, R.raw.mmbn_3);
backgroundMusic.setLooping(true);
backgroundMusic.start();
Button start = (Button) findViewById(R.id.Start);
Button highScore = (Button) findViewById(R.id.highScore);
Button quit = (Button) findViewById(R.id.quit);
start.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v){
startGame();
}
});
highScore.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v){
highScore();
}
});
quit.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v){
quit();
}
});
}
这些是onPause和onResume:
的覆盖@Override
public void onPause(){
super.onPause();
backgroundMusic.pause();
}
@Override
public void onResume(){
super.onResume();
backgroundMusic.start();
}
当用户点击退出按钮或后退按钮时:
@Override
public void onBackPressed(){
quit();
}
public void quit(){
quitDialog();
}
private void quitDialog() {
AlertDialog.Builder alertDialogBuilder = new AlertDialog.Builder(this);
// Set title.
alertDialogBuilder.setTitle("QUIT");
// Set dialog message.
alertDialogBuilder
.setMessage("Are you sure you want to quit?")
.setCancelable(false)
.setPositiveButton("Yes",
new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int id) {
//backgroundMusic.stop();
backgroundMusic.release();
finish();
}
})
.setNegativeButton("No", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int id) {
// if this button is clicked, resume teh gaem
//inputName();
}
});
// Create alert dialog.
AlertDialog alertDialog = alertDialogBuilder.create();
// Show it.
alertDialog.show();
}
点击“是”退出游戏后,应用会冻结并强行关闭。这是完整的LogCat错误
10-07 22:50:04.535: E/AndroidRuntime(5852): FATAL EXCEPTION: main
10-07 22:50:04.535: E/AndroidRuntime(5852): java.lang.RuntimeException: Unable to pause activity {com.cs119.megamanstrikescom.cs119.megamanstrikes.MainActivity}:java.lang.IllegalStateException
10-07 22:50:04.535: E/AndroidRuntime(5852): at android.app.ActivityThread.performPauseActivity(ActivityThread.java:2358)
10-07 22:50:04.535: E/AndroidRuntime(5852): at android.app.ActivityThread.performPauseActivity(ActivityThread.java:2315)
10-07 22:50:04.535: E/AndroidRuntime(5852): at android.app.ActivityThread.handlePauseActivity(ActivityThread.java:2295)
10-07 22:50:04.535: E/AndroidRuntime(5852): at android.app.ActivityThread.access$1700(ActivityThread.java:117)
10-07 22:50:04.535: E/AndroidRuntime(5852): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:946)
10-07 22:50:04.535: E/AndroidRuntime(5852): at android.os.Handler.dispatchMessage(Handler.java:99)
10-07 22:50:04.535: E/AndroidRuntime(5852): at android.os.Looper.loop(Looper.java:123)
10-07 22:50:04.535: E/AndroidRuntime(5852): at android.app.ActivityThread.main(ActivityThread.java:3691)
10-07 22:50:04.535: E/AndroidRuntime(5852): at java.lang.reflect.Method.invokeNative(Native Method)
10-07 22:50:04.535: E/AndroidRuntime(5852): at java.lang.reflect.Method.invoke(Method.java:507)
10-07 22:50:04.535: E/AndroidRuntime(5852): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:847)
10-07 22:50:04.535: E/AndroidRuntime(5852): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:605)
10-07 22:50:04.535: E/AndroidRuntime(5852): at dalvik.system.NativeStart.main(Native Method)
10-07 22:50:04.535: E/AndroidRuntime(5852): Caused by: java.lang.IllegalStateException
10-07 22:50:04.535: E/AndroidRuntime(5852): at android.media.MediaPlayer._pause(Native Method)
10-07 22:50:04.535: E/AndroidRuntime(5852): at android.media.MediaPlayer.pause(MediaPlayer.java:1001)
10-07 22:50:04.535: E/AndroidRuntime(5852): at com.cs119.megamanstrikes.MainActivity.onPause(MainActivity.java:163)
10-07 22:50:04.535: E/AndroidRuntime(5852): at android.app.Activity.performPause(Activity.java:3877)
10-07 22:50:04.535: E/AndroidRuntime(5852): at android.app.Instrumentation.callActivityOnPause(Instrumentation.java:1191)
10-07 22:50:04.535: E/AndroidRuntime(5852): at android.app.ActivityThread.performPauseActivity(ActivityThread.java:2345)
10-07 22:50:04.535: E/AndroidRuntime(5852): ... 12 more
我还尝试在onPause方法中执行backgroundMusic.stop();
而不是backgroundMusic.pause()
,但是,在恢复应用程序时,即使backgroundMusic.play()
存在,声音也不会播放onResume()方法。
我也注意到,无论我在onPause()和onResume()中放置什么,错误仍然存在,我尝试退出应用程序。
感谢您的帮助。
编辑1: 我将system.out行放在onPause和onResume覆盖中,以便我可以看到它何时被执行。在启动应用程序时,onResume执行并在关闭应用程序时执行onPause。我很困惑为什么会发生这种情况,因为onResume与onCreate不同。
编辑2: 好的,我已经解决了这个问题。问题主要来自退出按钮,因为它执行以下代码行:
backgroundMusic.stop();
backgroundMusic.release();
finish();
它以某种方式转到onPause方法并尝试执行backgroundMusic.pause()
。现在应用程序强制关闭,因为backgroundMusic已经被释放,无法完成命令backgroundMusic.pause()
。
我通过创建另一个全局变量解决了这个问题: boolean flag = false;
此标志检查是否已选择退出按钮以及用户是否要退出游戏。一旦用户想要退出游戏,它就会将标志设置为true。
flag = true;
backgroundMusic.stop();
backgroundMusic.release();
finish();
我将标志设置为true,以便当它从finish()转到onPause()方法时(关于Android的活动生命周期我可能是错的,但似乎onPause()在内部或之后执行finish()),这将执行:
@Override
public void onPause(){
super.onPause();
if(!flag){
if(backgroundMusic.isPlaying()){
backgroundMusic.pause();
}
}
}
这里,如果用户想要退出游戏,它只会执行super.onPause()。否则,如果游戏真的暂停(通过主页按钮或其他东西),那么旗帜仍然是假的,背景音乐将暂停。
我还修改了onResume()以保证安全:
@Override
public void onResume(){
super.onResume();
if(!backgroundMusic.isPlaying()){
backgroundMusic.start();
}
}
答案 0 :(得分:1)
根据Android文档:
“如果内部播放器引擎尚未初始化或已被释放,则为IllegalStateException。”
我会说首先要确保你已经初始化和/或没有释放播放器。
你需要在onPause()中释放播放器,除非你有一个非常特殊的要求来保持它。
另外,如果您为MediaPLayer使用静态全局变量,那可能就是问题所在。仔细检查它是如何初始化和释放的,特别是在类和类似的东西之间切换时。
如果你真的需要保存状态,那么你可以在onPause()和onResume()中使用getCurrentPosition()
方法保存轨道的当前位置,你可以使用seekTo (int msec)
方法并通过在你从getCUrrentPosition()获得的值中,这样你就可以在你离开的地方继续播放。