MediaPlayer вылетает после освобождения ();.. Нет 'Причины' в LogCat, я могу отладить? - PullRequest
1 голос
/ 01 января 2012

Обычно, когда я нажимаю кнопку, она воспроизводит звук, это деки. Основная проблема, с которой я сталкиваюсь, - когда я использую 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.Я не знаю как.

Ответы [ 3 ]

1 голос
/ 01 января 2012

Я думаю, что эти строки:

onPause();
onStop();

вызывают ваши методы приостановки и остановки активности. Я не знаю, если это ваша цель или нет. Вызывая эти методы, вы закрываете свое приложение (удаляя его из верхней части стека действий). Вы, вероятно, получаете сообщение об ошибке, потому что пытаетесь что-то сделать после того, как уже закончили.

Если ваша цель состоит в том, чтобы завершить свою деятельность после завершения мультимедиа, тогда слушатель завершения должен выглядеть следующим образом:

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

в качестве альтернативы вы можете просто вызвать метод finish (), а затем переопределить ваш метод onStop () и включить в него вызов release ().

0 голосов
/ 19 августа 2013

попробуйте ниже код: -

 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();
                    }

                });
            }
        });

вы должны удалить release () из слушателя.

0 голосов
/ 01 января 2012

Поскольку вы пытаетесь играть на деки, почему бы просто не использовать SoundPool?

...