2013-03-29 3 views
0

희망 사람 ...안드로이드를 MediaController 내가 <code>.mp3</code> 파일을 스트림 활동이 여기에 저를 도울 수

을 재개 한 후 getCurrentPosition에서 IllegalStateException이()를 발생시킵니다. 그것은 다음과 같다 : 이것은 내가 ("GSM 통화") 텔넷와 전화 통화를 시뮬레이션 할 때까지 잘 작동 및 오디오를 중단 할 것

public class PlayMediaActivity extends Activity implements OnPreparedListener, MediaController.MediaPlayerControl{ 
    private static final String TAG = "AudioPlayer"; 

    private MediaPlayer mediaPlayer; 
    private MediaController mediaController; 

    private Handler handler = new Handler(); 

    public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_play_media); 

    String title = this.getIntent().getStringExtra("Title"); 
    String URL = this.getIntent().getStringExtra("URL"); 

    this.setTitle(title); // Title on top of activity. 

    ((TextView)findViewById(R.id.now_playing_text)).setText(title); 

    mediaPlayer = new MediaPlayer(); 
    mediaPlayer.setOnPreparedListener(this); 

    mediaController = new MediaController(this); 

    try { 
     mediaPlayer.setDataSource(URL); 
     mediaPlayer.prepare(); 
     mediaPlayer.start(); 
    } catch (IOException e) { 
     Log.e(TAG, "Could not open file " + title + " for playback.", e); 
    } 

    } 

    @Override 
    protected void onStop() { 
     super.onStop(); 
     mediaController.hide(); 
     mediaPlayer.stop(); 
     mediaPlayer.release(); 
    } 

    @Override 
    public boolean onTouchEvent(MotionEvent event) { 
    //the MediaController will hide after 3 seconds - tap the screen to make it appear again 
    mediaController.show(); 
    return false; 
    } 

    //--MediaPlayerControl methods---------------------------------------------------- 
    public void start() { 
    mediaPlayer.start(); 
    } 

    public void pause() { 
    mediaPlayer.pause(); 
    } 

    public int getDuration() { 
    return mediaPlayer.getDuration(); 
    } 

    public int getCurrentPosition() { 
    return mediaPlayer.getCurrentPosition(); 
    } 

    public void seekTo(int i) { 
    mediaPlayer.seekTo(i); 
    } 

    public boolean isPlaying() { 
    return mediaPlayer.isPlaying(); 
    } 

    public int getBufferPercentage() { 
    return 0; 
    } 

    public boolean canPause() { 
    return true; 
    } 

    public boolean canSeekBackward() { 
    return true; 
    } 

    public boolean canSeekForward() { 
    return true; 
    } 
    //-------------------------------------------------------------------------------- 

    public void onPrepared(MediaPlayer mediaPlayer) { 
    Log.d(TAG, "onPrepared"); 
    mediaController.setMediaPlayer(this); 
    mediaController.setAnchorView(findViewById(R.id.main_audio_view)); 

    handler.post(new Runnable() { 
     public void run() { 
     mediaController.setEnabled(true); 
     mediaController.show(); 
     } 
    }); 
    } 


@Override 
public boolean onCreateOptionsMenu(Menu menu) { 
    // Inflate the menu; this adds items to the action bar if it is present. 
    getMenuInflater().inflate(R.menu.activity_play_media, menu); 
    return true; 
} 
} 

.

03-29 13:33:59.896: E/AndroidRuntime(1238): FATAL EXCEPTION: main 
03-29 13:33:59.896: E/AndroidRuntime(1238): java.lang.IllegalStateException 
03-29 13:33:59.896: E/AndroidRuntime(1238):  at android.media.MediaPlayer.getCurrentPosition(Native Method) 
03-29 13:33:59.896: E/AndroidRuntime(1238):  at com.lcboise.lifechurch.PlayMediaActivity.getCurrentPosition(PlayMediaActivity.java:79) 
03-29 13:33:59.896: E/AndroidRuntime(1238):  at android.widget.MediaController.setProgress(MediaController.java:381) 
03-29 13:33:59.896: E/AndroidRuntime(1238):  at android.widget.MediaController.show(MediaController.java:284) 
03-29 13:33:59.896: E/AndroidRuntime(1238):  at android.widget.MediaController.show(MediaController.java:249) 
03-29 13:33:59.896: E/AndroidRuntime(1238):  at com.lcboise.lifechurch.PlayMediaActivity.onTouchEvent(PlayMediaActivity.java:61) 
03-29 13:33:59.896: E/AndroidRuntime(1238):  at android.app.Activity.dispatchTouchEvent(Activity.java:2099) 
03-29 13:33:59.896: E/AndroidRuntime(1238):  at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:1675) 
03-29 13:33:59.896: E/AndroidRuntime(1238):  at android.view.ViewRoot.deliverPointerEvent(ViewRoot.java:2194) 
03-29 13:33:59.896: E/AndroidRuntime(1238):  at android.view.ViewRoot.handleMessage(ViewRoot.java:1878) 
03-29 13:33:59.896: E/AndroidRuntime(1238):  at android.os.Handler.dispatchMessage(Handler.java:99) 
03-29 13:33:59.896: E/AndroidRuntime(1238):  at android.os.Looper.loop(Looper.java:130) 
03-29 13:33:59.896: E/AndroidRuntime(1238):  at android.app.ActivityThread.main(ActivityThread.java:3683) 
03-29 13:33:59.896: E/AndroidRuntime(1238):  at java.lang.reflect.Method.invokeNative(Native Method) 
03-29 13:33:59.896: E/AndroidRuntime(1238):  at java.lang.reflect.Method.invoke(Method.java:507) 
03-29 13:33:59.896: E/AndroidRuntime(1238):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839) 
03-29 13:33:59.896: E/AndroidRuntime(1238):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597) 
03-29 13:33:59.896: E/AndroidRuntime(1238):  at dalvik.system.NativeStart.main(Native Method) 

모든 아이디어는 내가 잘못 뭘하는지 : 내가 호출을 완료하고있어 후 내 응용 프로그램으로 다시 전환 할 때 그것은이 IllegalStateExceptiongetCurrentPosition()에서 발생? 중단되었을 때 저장해야하고 앱을 다시 시작할 때 복원해야하는 상태가 있습니까?

+0

이 오류를 해결할 수 있었습니까 ?? –

+0

예. 그것은 전화 통화 후 상태를 복원하는 것과 관련이있었습니다. 내 전체 솔루션을 답으로 게시하고 같은 문제가 발생하는 경우 필요한 모든 것을 사용할 수 있습니다. –

답변

0

여기에 완전히 작동하는 MediaPlayerMediaController 예가 있습니다. 전화 수신시 오디오를 일시 중지/다시 시작합니다. 누군가가 버그를 발견하면 알려주십시오.

import android.media.AudioManager; 
import android.media.MediaPlayer; 
import android.media.MediaPlayer.OnErrorListener; 
import android.media.MediaPlayer.OnPreparedListener; 
import android.os.Bundle; 
import android.app.Activity; 
import android.app.AlertDialog; 
import android.app.ProgressDialog; 
import android.content.DialogInterface; 
import android.telephony.PhoneStateListener; 
import android.telephony.TelephonyManager; 
import android.util.Log; 
import android.view.ContextThemeWrapper; 
import android.view.Menu; 
import android.view.MotionEvent; 
import android.widget.MediaController; 
import android.widget.TextView; 

public class PlayMediaActivity extends Activity implements OnPreparedListener, OnErrorListener, MediaController.MediaPlayerControl{ 
     private static final String TAG = "AudioPlayer"; 

     private MediaPlayer myMediaPlayer; 
     private MediaController mediaController; 

     private int seek_position = 0; 

     private boolean isPaused = false; // If the player was paused before being stopped. 

     private PhoneStateListener phoneStateListener = null; 

     ProgressDialog dialog = null; 

     public void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 

     setContentView(R.layout.activity_play_media); 

     String title = this.getIntent().getStringExtra("Title"); 
     String URL = this.getIntent().getStringExtra("URL"); 

     ((TextView)findViewById(R.id.now_playing_text)).setText(title); 

     // Register for phone events so we can pause/restart audio when a call happens. 
     phoneStateListener = new PhoneStateListener() { 
      @Override 
      public void onCallStateChanged(int state, String incomingNumber) { 
       if (state == TelephonyManager.CALL_STATE_RINGING) { 
        //Incoming call: Pause music 
        boolean s = isPaused; 
        pause(); 
        isPaused = s; // Want to restore the state before we paused for phone call. 
       } else if(state == TelephonyManager.CALL_STATE_IDLE) { 
        //Not in call: Play music 
        if(isPaused == true) { 
         pause(); 
        } 
        else { 
         if(!isPlaying()) { // Only start if it's not currently started. 
          start(); 
         } 
        } 
       } else if(state == TelephonyManager.CALL_STATE_OFFHOOK) { 
        //A call is dialing, active or on hold. Pause music 
        boolean s = isPaused; 
        pause(); 
        isPaused = s; // Want to restore the state before we paused for phone call. 
       } 
       super.onCallStateChanged(state, incomingNumber); 
      } 
     }; 

     try {   
      myMediaPlayer = new MediaPlayer(); 
      myMediaPlayer.setOnPreparedListener(PlayMediaActivity.this); 
      myMediaPlayer.setOnErrorListener(PlayMediaActivity.this); 

      mediaController = new MediaController(PlayMediaActivity.this); 
      mediaController.setMediaPlayer(PlayMediaActivity.this); 
      mediaController.setAnchorView(findViewById(R.id.main_audio_view)); 
      mediaController.setEnabled(true); 

      // Inform the user that we are doing something (reading from the network). 
      ContextThemeWrapper cw = new ContextThemeWrapper(PlayMediaActivity.this, R.style.AlertDialogTheme); 
      dialog = ProgressDialog.show(cw, "", "Loading. Please wait...", true); 

      myMediaPlayer.setAudioStreamType(AudioManager.STREAM_MUSIC); 
      myMediaPlayer.setDataSource(URL); 

      myMediaPlayer.prepareAsync(); 
     } 
     catch (Exception e) 
     { 
      Log.e(TAG, "Could not open file " + title + " for playback.", e); 

      if(dialog != null) { 
       dialog.dismiss(); 
      } 

      ShowDialog("Unable to play audio. Try again later."); 
     } 
     } 

    private void ShowDialog(String message) { 
     // Alert the user something went wrong. 
     ContextThemeWrapper cw = new ContextThemeWrapper(PlayMediaActivity.this, R.style.AlertDialogTheme); 

     AlertDialog.Builder alertDialogBuilder = new AlertDialog.Builder(cw); 

     alertDialogBuilder.setTitle("Oops!"); 

     // set dialog message 
     alertDialogBuilder 
       .setMessage(message) 
       .setCancelable(true) // Allow back hardkey to dismiss 
       .setPositiveButton("OK",new DialogInterface.OnClickListener() { 
        public void onClick(DialogInterface dialog,int id) { 
         // if this button is clicked, close current activity 
         dialog.dismiss(); 
         PlayMediaActivity.this.finish(); 
        } 
        }); 

     alertDialogBuilder.setOnCancelListener(new DialogInterface.OnCancelListener() { // Catch back key press.   
      @Override 
      public void onCancel(DialogInterface dialog) { 
       //do whatever you want the back key to do 
       dialog.dismiss(); 
       PlayMediaActivity.this.finish(); 
      } 
     }); 

     // create alert dialog 
     AlertDialog alertDialog = alertDialogBuilder.create(); 

     // show it 
     alertDialog.show(); 
    } 

     @Override 
     protected void onStop() { // Activity becomes hidden. 
      super.onStop(); 
      mediaController.hide(); // So you don't get the "Leaked activity..." message. 

      if(this.isPaused == true) { 
       seek_position = myMediaPlayer.getCurrentPosition(); 
      } 
     } 

     @Override 
     protected void onDestroy() { 
      super.onDestroy(); 

      myMediaPlayer.stop(); 
      myMediaPlayer.release(); 
      myMediaPlayer = null; 

      // Unregister for phone state information as part of cleanup. 
      TelephonyManager mgr = (TelephonyManager) getSystemService(TELEPHONY_SERVICE); 
      if(mgr != null) { 
       mgr.listen(phoneStateListener, PhoneStateListener.LISTEN_NONE); 
      } 
     } 

     @Override 
     protected void onResume() { 
      super.onResume(); 

      if(this.isPaused == true) { // Restore the playback position if it was paused. 
       myMediaPlayer.seekTo(seek_position); 
      } 
     } 

     @Override 
     public boolean onTouchEvent(MotionEvent event) { 
     //the MediaController will hide after 3 seconds - tap the screen to make it appear again 
     mediaController.show(); 
     return false; 
     } 

     //--MediaPlayerControl methods---------------------------------------------------- 
     public void start() { 
      myMediaPlayer.start(); 

     this.isPaused = false; 
     } 

     public void pause() { 
      myMediaPlayer.pause(); 

     this.isPaused = true; 
     } 

     public int getDuration() { 
     return myMediaPlayer.getDuration(); 
     } 

     public int getCurrentPosition() { 
     return myMediaPlayer.getCurrentPosition(); 
     } 

     public void seekTo(int i) { 
     myMediaPlayer.seekTo(i); 
     } 

     public boolean isPlaying() { 
     return myMediaPlayer.isPlaying(); 
     } 

     public int getBufferPercentage() { 
     return 0; 
     } 

     public boolean canPause() { 
     return true; 
     } 

     public boolean canSeekBackward() { 
     return true; 
     } 

     public boolean canSeekForward() { 
     return true; 
     } 
     //-------------------------------------------------------------------------------- 

     public void onPrepared(MediaPlayer mediaPlayer) { 
      Log.d(TAG, "onPrepared"); 

      if(dialog != null) { 
       dialog.dismiss(); 
      } 

      // Show and play the media AFTER it's been prepared. 
      mediaController.show();  
      mediaPlayer.start(); 

      // Register for call state information AFTER we have started the media. This registration fires 
      // the IDLE event, which would try and start the media. This causes a error in the media player 
      // because we are "prepared" yet. 
      TelephonyManager mgr = (TelephonyManager) getSystemService(TELEPHONY_SERVICE); 
      if(mgr != null) { 
       mgr.listen(phoneStateListener, PhoneStateListener.LISTEN_CALL_STATE); 
      } 
     } 

     public boolean onError(MediaPlayer mp, int what, int extra) { 

      if(dialog != null) { 
      dialog.dismiss(); 
      } 

      ShowDialog("Unable to play audio. Try again later."); 

      return true; 
     } 

    @Override 
    public boolean onCreateOptionsMenu(Menu menu) { 
     // Inflate the menu; this adds items to the action bar if it is present. 
     getMenuInflater().inflate(R.menu.activity_play_media, menu); 
     return true; 
    } 

}