android - MediaPlayer 在 release() 后崩溃; .. LogCat中没有 'Caused by',我可以调试吗?

标签 android debugging logcat android-mediaplayer illegalstateexception

基本上,当我点击一个按钮时,它会播放声音,它是一个音板。我遇到的主要问题是当我第一次使用 release(); 播放音频时,当我再次播放声音时,它只会让应用程序崩溃。我在 OnCompletion 方法中尝试了多种组合,改变了它们,没有任何改变。无论我输入什么代码,当我输入 release(); 时,它都会崩溃。这是我的代码;

    public class MyClass extends Activity{

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.list_view);
        this.setVolumeControlStream(AudioManager.STREAM_MUSIC);

        final MediaPlayer mpB1 = MediaPlayer.create(this, R.raw.s101);
        final MediaPlayer mpB2 = MediaPlayer.create(this, R.raw.s102);
            <etc>


        Button b1 = (Button) findViewById(R.id.sound101);
        b1.setOnClickListener(new View.OnClickListener() {

            public void onClick(View v) {
                // TODO Auto-generated method stub
                mpB1.start();
                mpB1.setOnCompletionListener(new OnCompletionListener() {

                    public void onCompletion(MediaPlayer mpB1) {
                        // TODO Auto-generated method stub
                        onPause();
                        onStop();
                        mpB1.release();

                    }

                });
            }
        });

        Button b2 = (Button) findViewById(R.id.sound102);
        b2.setOnClickListener(new View.OnClickListener() {

            public void onClick(View v) {
                // TODO Auto-generated method stub
                mpB2.start();
                mpB2.setOnCompletionListener(new OnCompletionListener() {

                    public void onCompletion(MediaPlayer mp) {
                        // TODO Auto-generated method stub
                        onPause();
                        onStop();
                        mpB2.release();
                    }

                });
            }
        });
                    <etc, you get the idea.. soundboard>

这是我的 LogCat;

    01-01 02:58:53.218: E/AndroidRuntime(682): FATAL EXCEPTION: main
    01-01 02:58:53.218: E/AndroidRuntime(682): java.lang.IllegalStateException
    01-01 02:58:53.218: E/AndroidRuntime(682):  at android.media.MediaPlayer._start(Native Method)
    01-01 02:58:53.218: E/AndroidRuntime(682):  at android.media.MediaPlayer.start(MediaPlayer.java:819)
    01-01 02:58:53.218: E/AndroidRuntime(682):  at 'com.package'$1.onClick('Class'.java:73)
    01-01 02:58:53.218: E/AndroidRuntime(682):  at android.view.View.performClick(View.java:2485)
    01-01 02:58:53.218: E/AndroidRuntime(682):  at android.view.View$PerformClick.run(View.java:9080)
    01-01 02:58:53.218: E/AndroidRuntime(682):  at android.os.Handler.handleCallback(Handler.java:587)
    01-01 02:58:53.218: E/AndroidRuntime(682):  at android.os.Handler.dispatchMessage(Handler.java:92)
    01-01 02:58:53.218: E/AndroidRuntime(682):  at android.os.Looper.loop(Looper.java:123)
    01-01 02:58:53.218: E/AndroidRuntime(682):  at android.app.ActivityThread.main(ActivityThread.java:3683)
    01-01 02:58:53.218: E/AndroidRuntime(682):  at java.lang.reflect.Method.invokeNative(Native Method)
    01-01 02:58:53.218: E/AndroidRuntime(682):  at java.lang.reflect.Method.invoke(Method.java:507)
    01-01 02:58:53.218: E/AndroidRuntime(682):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
    01-01 02:58:53.218: E/AndroidRuntime(682):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
    01-01 02:58:53.218: E/AndroidRuntime(682):  at dalvik.system.NativeStart.main(Native Method)

就是这样。谁能猜出问题所在?我试图调试这个问题,弄乱了 IllegalStateException。我不知道怎么办。

最佳答案

我认为这些行:

onPause();
onStop();

正在调用您的 Activity 暂停和停止方法。我不知道这是否是您的目标。通过调用这些方法,您将结束您的应用程序(将其从 Activity 堆栈的顶部移除)。您可能会收到错误,因为您正在尝试在已经结束后做某事。

如果您的目标是在媒体完成时退出 Activity ,那么让您的完成监听器看起来像这样:

                public void onCompletion(MediaPlayer mp) {
                    // TODO Auto-generated method stub
                    mpB2.release();
                    YourActivity.this.finish();
                }

或者,您可以只在此处调用 finish(),然后覆盖您的 Activity onStop() 方法,并在其中包含 release() 调用。

关于android - MediaPlayer 在 release() 后崩溃; .. LogCat中没有 'Caused by',我可以调试吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8691664/

相关文章:

android - 将 Logcat 从 Android 应用程序保存到 txt 文件

Android logcat 错误 TundConnector 和 NetlinkEvent

android - 如何以简单的方式将 Activity 导航到 React Native 中的另一个 Activity?

java - 在没有root的情况下阻止主页按钮

java - 无法创建编辑文本对象

python - 在Python(pyrasite)中检查线程中的局部变量?

jquery - html 文本输入被阻止。仅可通过右键单击使用

java - "Cannot attach empty file"- 将内存中的图像共享到 Gmail 时

debugging - 将 Trace32 与 Qualcomm FFA 结合使用

android logcat 记录聊天模块行过期消息