2011-12-11 2 views
0

Android 미디어 플레이어 스트리밍 응용 프로그램을 개발 중입니다. 나는 다음과 같은 예외가 :미디어 플레이어 예외 발생

12-11 11:12:06.298: INFO/StagefrightPlayer(34): setDataSource('10.0.2.2\a.mp3') 
12-11 11:12:06.308: DEBUG/mp(618): starting 
12-11 11:12:06.308: ERROR/MediaPlayer(618): start called in state 4 
12-11 11:12:06.308: ERROR/MediaPlayer(618): error (-38, 0) 
12-11 11:12:06.328: ERROR/MediaPlayer(618): error (1, -2147483648) 
12-11 11:12:06.328: ERROR/MediaPlayer(618): Error (-38,0) 
12-11 11:12:06.409: ERROR/MediaPlayer(618): Error (1,-2147483648) 
 String url = "10.0.2.2\\a.mp3"; // your URL here 
     MediaPlayer mediaPlayer = new MediaPlayer(); 
     mediaPlayer.setAudioStreamType(AudioManager.STREAM_MUSIC); 
     try { 
      mediaPlayer.setDataSource(url); 
     } catch (IllegalArgumentException e) { 
      // TODO Auto-generated catch block 
      e.printStackTrace(); 
     } catch (IllegalStateException e) { 
      // TODO Auto-generated catch block 
      e.printStackTrace(); 
     } catch (IOException e) { 
      // TODO Auto-generated catch block 
      e.printStackTrace(); 
     } 
     try { 
      mediaPlayer.prepareAsync(); 
     } catch (IllegalStateException e) { 
      // TODO Auto-generated catch block 
      e.printStackTrace(); 
     } 
     Log.d("mp","starting"); 
     mediaPlayer.start(); 

mediaPlayer.prepare를 사용하여 나는 다음과 같은 오류 메시지가 얻을 :

12-11 12:08:42.367: ERROR/MediaPlayer(980): error (1, -2147483648) 
12-11 12:08:42.367: WARN/System.err(980): java.io.IOException: Prepare failed.: status=0x1 
12-11 12:08:42.378: WARN/System.err(980):  at android.media.MediaPlayer.prepare(Native Method) 
12-11 12:08:42.378: WARN/System.err(980):  at mobiledo.pjct.Voicesms.onCreate(Voicesms.java:52) 
12-11 12:08:42.387: WARN/System.err(980):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
12-11 12:08:42.387: WARN/System.err(980):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611) 
12-11 12:08:42.387: WARN/System.err(980):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663) 
12-11 12:08:42.387: WARN/System.err(980):  at android.app.ActivityThread.access$1500(ActivityThread.java:117) 
12-11 12:08:42.387: WARN/System.err(980):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931) 
12-11 12:08:42.387: WARN/System.err(980): at android.os.Handler.dispatchMessage(Handler.java:99) 
12-11 12:08:42.418: WARN/System.err(980):  at android.os.Looper.loop(Looper.java:123) 
12-11 12:08:42.418: WARN/System.err(980):  at android.app.ActivityThread.main(ActivityThread.java:3683) 
12-11 12:08:42.418: WARN/System.err(980):  at java.lang.reflect.Method.invokeNative(Native Method) 
12-11 12:08:42.418: WARN/System.err(980):  at java.lang.reflect.Method.invoke(Method.java:507) 
12-11 12:08:42.418: WARN/System.err(980):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839) 
12-11 12:08:42.418: WARN/System.err(980):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597) 
12-11 12:08:42.418: WARN/System.err(980):  at dalvik.system.NativeStart.main(Native Method)    

답변

3

당신은 비동기 적으로 MediaPlayer를 인스턴스를 준비하지만 직후 start 전화를 MediaPlayer가 준비되지 않았기 때문에 예외가 발생합니다. 당신은 등록해야 OnPreparedListener이 청취자 전화 start()에 (당신이 prepareAsync를 호출하기 전에) :

.prepareAsync() 이동 상태가 아닌 준비 상태를 준비하는 플레이어를 호출
mediaPlayer.setOnPreparedListener(new OnPreparedListener(){ 
    public void onPrepared(MediaPlayer mp) { 
     mp.start(); 
    } 
}); 
mediaPlayer.prepareAsync(); 
+0

오류 – sajith

+0

에게 12월 12일에서 11일까지 보여주는 작동하지 호출하는 OnPreparedListener 등록 : 05 : 33.027을 : 정보/StagefrightPlayer (34) : setDataSource ('10 .0.2.2 \ a.mp3을 ') 12-11 12 : 05 : 33.047 : 오류/MediaPlayer (867) : 오류 (1, -2147483648) 12-11 12 : 05 : 33.127 : ERROR/MediaPlayer (867) : 오류 (1, -2147483648) – sajith

+0

@sajith - 전체 오류를 게시하십시오. 또한,'mediaPlayer.start()'에 대한 호출을 제거 했습니까? – MByD

1

. 그러니 대신 .prepare 전화하거나 구현하고 start()