Я столкнулся с вашей проблемой, Скайлер.
Вы правы. В документации не указано недопустимых состояний для mediaPlayer.reset (), но это не первая неточность в документации.
Что я заметил, так это то, что в списке ДЕЙСТВИТЕЛЬНЫХ состояний не написано «Любой»; в нем перечислены все конкретные состояния, кроме двух: Подготовка и Конец.
Я экспериментировал, но не смог вызвать исключение IllegalStateException при моих попытках вызвать release (), пока MediaPlayer, как мы надеемся, находится в состоянии Preparing (с использованием prepareAsync ()). Я не гарантирую, что этого не произойдет, но я не смог этого сделать. В этом случае я увидел следующие сообщения журнала:
04-11 11:41:54.740: E/MediaPlayer(4930): error (1, -2147483648)
04-11 11:41:54.748: E/MediaPlayer(4930): Error (1,-2147483648)
Да, оба сообщения об ошибках появляются одно за другим - одно с «ошибкой» в нижнем регистре и одно с «ошибкой» в верхнем регистре, но исключение не выдается.
Однако, если я вызываю reset () после release (), я получаю ошибку:
04-11 11:45:05.232: E/AndroidRuntime(5046): FATAL EXCEPTION: main
04-11 11:45:05.232: E/AndroidRuntime(5046): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.android.helloandroid/com.android.helloandroid.HelloAndroidActivity}: java.lang.RuntimeException: java.lang.IllegalStateException
04-11 11:45:05.232: E/AndroidRuntime(5046): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1696)
04-11 11:45:05.232: E/AndroidRuntime(5046): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1716)
04-11 11:45:05.232: E/AndroidRuntime(5046): at android.app.ActivityThread.access$1500(ActivityThread.java:124)
04-11 11:45:05.232: E/AndroidRuntime(5046): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:968)
04-11 11:45:05.232: E/AndroidRuntime(5046): at android.os.Handler.dispatchMessage(Handler.java:99)
04-11 11:45:05.232: E/AndroidRuntime(5046): at android.os.Looper.loop(Looper.java:123)
04-11 11:45:05.232: E/AndroidRuntime(5046): at android.app.ActivityThread.main(ActivityThread.java:3806)
04-11 11:45:05.232: E/AndroidRuntime(5046): at java.lang.reflect.Method.invokeNative(Native Method)
04-11 11:45:05.232: E/AndroidRuntime(5046): at java.lang.reflect.Method.invoke(Method.java:507)
04-11 11:45:05.232: E/AndroidRuntime(5046): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
04-11 11:45:05.232: E/AndroidRuntime(5046): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
04-11 11:45:05.232: E/AndroidRuntime(5046): at dalvik.system.NativeStart.main(Native Method)
04-11 11:45:05.232: E/AndroidRuntime(5046): Caused by: java.lang.RuntimeException: java.lang.IllegalStateException
04-11 11:45:05.232: E/AndroidRuntime(5046): at com.android.helloandroid.HelloAndroidActivity.crashMediaPlayer(HelloAndroidActivity.java:423)
04-11 11:45:05.232: E/AndroidRuntime(5046): at com.android.helloandroid.HelloAndroidActivity.onCreate(HelloAndroidActivity.java:87)
04-11 11:45:05.232: E/AndroidRuntime(5046): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
04-11 11:45:05.232: E/AndroidRuntime(5046): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1660)
04-11 11:45:05.232: E/AndroidRuntime(5046): ... 11 more
04-11 11:45:05.232: E/AndroidRuntime(5046): Caused by: java.lang.IllegalStateException
04-11 11:45:05.232: E/AndroidRuntime(5046): at android.media.MediaPlayer._reset(Native Method)
04-11 11:45:05.232: E/AndroidRuntime(5046): at android.media.MediaPlayer.reset(MediaPlayer.java:1112)
04-11 11:45:05.232: E/AndroidRuntime(5046): at com.android.helloandroid.HelloAndroidActivity.crashMediaPlayer(HelloAndroidActivity.java:421)
04-11 11:45:05.232: E/AndroidRuntime(5046): ... 14 more
Так что предположение Современных Чернил было верным. MediaPlayer.reset () создает исключение IllegalStateException в состоянии «Конец» (которое возникает после вызова release ()).
В моем случае я обнаружил, что вызывал release () для onPause (), но ничего не сделал для повторной инициализации MediaPlayer в onResume (). Следовательно, он был в состоянии End, когда я вызвал reset ();
За http://developer.android.com/reference/android/media/MediaPlayer.html,
Как только объект MediaPlayer находится в состоянии End, он больше не может быть
используется, и нет никакого способа вернуть его в любое другое состояние.
Это означает, что вам нужно заново создать MediaPlayer, начиная с mediaPlayer = new MediaPlayer () или одного из методов mediaPlayer.onCreate (). Или будьте осторожны при вызове release ().