Исключение при воспроизведении аудио файла - PullRequest
1 голос
/ 17 января 2012

У меня есть массив со всеми идентификаторами ресурсов локальных ресурсов (аудиофайлы). Я пытаюсь воспроизвести все эти файлы один за другим. Для этого я играю следующий файл в событии setOnCompletionListener Media Player, как показано ниже: -

mMediaPlayer.setOnCompletionListener();

Полный код для непрерывного воспроизведения файлов приведен ниже: -

Код

private void playing(){
  MediaPlayer mMediaPlayer = new MediaPlayer();
  mMediaPlayer = MediaPlayer.create(this, Constants.mAudioIds[play]);  // next file will be played
  mMediaPlayer.start();
  mMediaPlayer.setOnCompletionListener(new OnCompletionListener(){
      @Override
     public void onCompletion(MediaPlayer mp) {
                // TODO Auto-generated method stub
        play +=1;
        playing();
     }

    });
}

Если я проигрываю все файлы по отдельности, они воспроизводятся идеально. Но, используя приведенный выше код, я получаю ошибку в MediaPlayer. Ниже приведена трассировка стека.

StackTrace

01-17 20:52:10.088: INFO/MediaPlayer(379): Info (1,44)
01-17 20:52:10.358: DEBUG/dalvikvm(215): GC freed 43 objects / 2096 bytes in 108ms
01-17 20:52:15.368: WARN/MediaPlayer(379): info/warning (1, 26)
01-17 20:52:15.410: ERROR/PlayerDriver(31): Command PLAYER_PREPARE completed with an error or info PVMFErrResource
01-17 20:52:15.419: ERROR/MediaPlayer(379): error (1, -17)
01-17 20:52:15.462: WARN/PlayerDriver(31): PVMFInfoErrorHandlingComplete
01-17 20:52:15.568: DEBUG/MediaPlayer(379): create failed:
01-17 20:52:15.568: DEBUG/MediaPlayer(379): java.io.IOException: Prepare failed.: status=0x1
01-17 20:52:15.568: DEBUG/MediaPlayer(379):     at android.media.MediaPlayer.prepare(Native Method)
01-17 20:52:15.568: DEBUG/MediaPlayer(379):     at android.media.MediaPlayer.create(MediaPlayer.java:644)
01-17 20:52:15.568: DEBUG/MediaPlayer(379):     at com.media.sample.ui.AutoPlay.playing(AutoPlay.java:162)
01-17 20:52:15.568: DEBUG/MediaPlayer(379):     at com.media.sample.ui.AutoPlay.access$0(AutoPlay.java:138)
01-17 20:52:15.568: DEBUG/MediaPlayer(379):     at com.media.sample.ui.AutoPlay$1.onCompletion(AutoPlay.java:171)
01-17 20:52:15.568: DEBUG/MediaPlayer(379):     at android.media.MediaPlayer$EventHandler.handleMessage(MediaPlayer.java:1157)
01-17 20:52:15.568: DEBUG/MediaPlayer(379):     at android.os.Handler.dispatchMessage(Handler.java:99)
01-17 20:52:15.568: DEBUG/MediaPlayer(379):     at android.os.Looper.loop(Looper.java:123)
01-17 20:52:15.568: DEBUG/MediaPlayer(379):     at android.app.ActivityThread.main(ActivityThread.java:4363)
01-17 20:52:15.568: DEBUG/MediaPlayer(379):     at java.lang.reflect.Method.invokeNative(Native Method)
01-17 20:52:15.568: DEBUG/MediaPlayer(379):     at java.lang.reflect.Method.invoke(Method.java:521)
01-17 20:52:15.568: DEBUG/MediaPlayer(379):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
01-17 20:52:15.568: DEBUG/MediaPlayer(379):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
01-17 20:52:15.568: DEBUG/MediaPlayer(379):     at dalvik.system.NativeStart.main(Native Method)

Кроме того, тот же код отлично работает на очень немногих устройствах (но на большинстве устройств + эмулятор), он дает выше исключение.

Пожалуйста, предоставьте какое-нибудь решение для того же.

Ответы [ 2 ]

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

Вам нужно позвонить prepareAsync () , например:

private void playing(){
  MediaPlayer mMediaPlayer = new MediaPlayer();
  mMediaPlayer = MediaPlayer.create(this, Constants.mAudioIds[play]);  
  mMediaPlayer.prepareAsync();

  mMediaPlayer.setOnCompletionListener(new OnCompletionListener(){
      @Override
     public void onCompletion(MediaPlayer mp) {
                // TODO Auto-generated method stub
        play +=1;
        playing();
     }

    });
}

 @Override
 public void onPrepared(MediaPlayer mp) {
  Log.d(TAG, "Stream is prepared");
  mp.start();
 }

Полный пример здесь .

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

Вам необходимо обратиться к диаграмме состояний и диаграмме, в которой указаны состояния, в которых может находиться медиаплеер, и какие методы можно вызывать в каком состоянии.http://developer.android.com/reference/android/media/MediaPlayer.html#Valid_and_Invalid_States

Медиаплеер может быть немного хитрым из-за этого.

...