Android用のJavaメディアプレーヤークラスを作成/ダウンロードしましたが、画面のタイムアウト時または手動でオフにするとき、再開時にmediaPlayer.isPlaying()
..
グーグルで調べたところ、これはおそらくメディアプレーヤーがエラー状態にあることがわかりました。その後、試してみtry {...} catch(IllegalStateException...
ましたが、追加しすぎて、制御不能な(そして成功せずに)大きな混乱が生じています。
次に、次のようなことを試しました:
mediaPlayer.setOnErrorListener(new OnErrorListener() {
public boolean onError(MediaPlayer mp, int what, int extra) {
mp.release();
return false;
}
しかし、まだ IllegalStateException エラーが発生しています。(編集:ところで、ここでは「IllegalStateExceptionsはOnErrorListener呼び出しをトリガーしない」と書かれています。これは正しいですか??)
だから、私の質問:
1) メディアプレーヤーをエラー状態にするスクリーン タイムアウトで何が起こっていますか? 2) どうすればこれを防ぐことができますか? 3) mediaPlayer.setOnErrorListener の中に何を入れる必要がありますか? 4) エラー リスナに何かミスがありましたか? どうにかして処理する必要がありますか?
申し訳ありません...初心者です。
編集:呼び出しを追加する必要があったため、クラス全体を次に示します。
package com.floritfoto.apps.ave;
import java.io.FileDescriptor;
import java.io.IOException;
import android.media.MediaPlayer;
import android.media.MediaPlayer.OnCompletionListener;
import android.media.MediaPlayer.OnErrorListener;
public class Music implements OnCompletionListener{
MediaPlayer mediaPlayer;
boolean isPrepared = false;
public Music(FileDescriptor fileDescriptor){
mediaPlayer = new MediaPlayer();
try{
mediaPlayer.setDataSource(fileDescriptor);
mediaPlayer.prepare();
isPrepared = true;
mediaPlayer.setOnCompletionListener(this);
mediaPlayer.setOnErrorListener(new OnErrorListener() {
public boolean onError(MediaPlayer mp, int what, int extra) {
mp.release();
return false;
}
});
} catch(Exception ex){
throw new RuntimeException("Couldn't load music, uh oh!");
}
}
public void onCompletion(MediaPlayer mediaPlayer) {
synchronized(this){
isPrepared = false;
}
}
public void play() {
if(mediaPlayer.isPlaying()){
return;
}
try{
synchronized(this){
if(!isPrepared){
mediaPlayer.prepare();
}
mediaPlayer.seekTo(0);
mediaPlayer.start();
}
} catch(IllegalStateException ex){
ex.printStackTrace();
} catch(IOException ex){
ex.printStackTrace();
}
}
public void stop() {
mediaPlayer.stop();
synchronized(this){
isPrepared = false;
}
}
public void switchTracks(){
mediaPlayer.seekTo(0);
mediaPlayer.pause();
}
public void pause() {
mediaPlayer.pause();
}
public boolean isPlaying() {
return mediaPlayer.isPlaying();
}
public boolean isLooping() {
return mediaPlayer.isLooping();
}
public void setLooping(boolean isLooping) {
mediaPlayer.setLooping(isLooping);
}
public void setVolume(float volumeLeft, float volumeRight) {
mediaPlayer.setVolume(volumeLeft, volumeRight);
}
public String getDuration() {
return String.valueOf((int)(mediaPlayer.getDuration()/1000));
}
public void dispose() {
if(mediaPlayer.isPlaying()){
stop();
}
mediaPlayer.release();
}
}
そして、これはエラーです:
E/AndroidRuntime(21110): FATAL EXCEPTION: main
E/AndroidRuntime(21110): java.lang.RuntimeException: Unable to pause activity {com.floritfoto.apps.ave/com.floritfoto.apps.ave.OpenBird}: java.lang.IllegalStateException
E/AndroidRuntime(21110): at android.app.ActivityThread.performPauseActivity(ActivityThread.java:2718)
E/AndroidRuntime(21110): at android.app.ActivityThread.performPauseActivity(ActivityThread.java:2674)
E/AndroidRuntime(21110): at android.app.ActivityThread.handlePauseActivity(ActivityThread.java:2652)
E/AndroidRuntime(21110): at android.app.ActivityThread.access$800(ActivityThread.java:127)
E/AndroidRuntime(21110): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1170)
E/AndroidRuntime(21110): at android.os.Handler.dispatchMessage(Handler.java:99)
E/AndroidRuntime(21110): at android.os.Looper.loop(Looper.java:137)
E/AndroidRuntime(21110): at android.app.ActivityThread.main(ActivityThread.java:4507)
E/AndroidRuntime(21110): at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime(21110): at java.lang.reflect.Method.invoke(Method.java:511)
E/AndroidRuntime(21110): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:980)
E/AndroidRuntime(21110): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:747)
E/AndroidRuntime(21110): at dalvik.system.NativeStart.main(Native Method)
E/AndroidRuntime(21110): Caused by: java.lang.IllegalStateException
E/AndroidRuntime(21110): at android.media.MediaPlayer.isPlaying(Native Method)
E/AndroidRuntime(21110): at com.floritfoto.apps.ave.Music.dispose(Music.java:101)
E/AndroidRuntime(21110): at com.floritfoto.apps.ave.OpenBird.onPause(OpenBird.java:211)
E/AndroidRuntime(21110): at android.app.Activity.performPause(Activity.java:4563)
E/AndroidRuntime(21110): at android.app.Instrumentation.callActivityOnPause(Instrumentation.java:1198)
E/AndroidRuntime(21110): at android.app.ActivityThread.performPauseActivity(ActivityThread.java:2705)
E/AndroidRuntime(21110): ... 12 more
W/ActivityManager( 1864): Force finishing activity r.intent.getComponent().flattenToShortString()