Error處理: android.media.MediaRecorder.start(Native Method) 報錯:start failed: -19

來源:互聯網
上載者:User

標籤:time   解決方案   targe   loop   format   mat   exception   key   tor   

spydroid-android測試在android4.0系統上報錯 [html] view plain copy 
  1. start failed: -19  

而且也發現,在使用MediaRecorder進行視頻錄製,調用start()方法時報錯,發生spydroid-android測試在android4.0系統上同樣的錯誤,具體錯誤如下:

 

[html] view plain copy 
  1. 01-06 14:04:07.790: V/MediaRecorder(13280): prepare  
  2. 01-06 14:04:07.790: V/IMediaRecorder(13280): prepare  
  3. 01-06 14:04:07.800: V/MediaRecorder(13280): start  
  4. 01-06 14:04:07.800: V/IMediaRecorder(13280): start  
  5. 01-06 14:04:08.190: E/MediaRecorder(13280): start failed: -19  
  6. 01-06 14:04:08.190: W/System.err(13280): java.lang.RuntimeException: start failed.  
  7. 01-06 14:04:08.200: W/System.err(13280):    at android.media.MediaRecorder.start(Native Method)  
  8. 01-06 14:04:08.200: W/System.err(13280):    at com.yousee.videocapturedemo.VideoCapturePlus$2.onClick(VideoCapturePlus.java:145)  
  9. 01-06 14:04:08.200: W/System.err(13280):    at android.view.View.performClick(View.java:3515)  
  10. 01-06 14:04:08.200: W/System.err(13280):    at android.view.View$PerformClick.run(View.java:14144)  
  11. 01-06 14:04:08.200: W/System.err(13280):    at android.os.Handler.handleCallback(Handler.java:605)  
  12. 01-06 14:04:08.200: W/System.err(13280):    at android.os.Handler.dispatchMessage(Handler.java:92)  
  13. 01-06 14:04:08.200: W/System.err(13280):    at android.os.Looper.loop(Looper.java:148)  
  14. 01-06 14:04:08.200: W/System.err(13280):    at android.app.ActivityThread.main(ActivityThread.java:4503)  
  15. 01-06 14:04:08.200: W/System.err(13280):    at java.lang.reflect.Method.invokeNative(Native Method)  
  16. 01-06 14:04:08.200: W/System.err(13280):    at java.lang.reflect.Method.invoke(Method.java:511)  
  17. 01-06 14:04:08.200: W/System.err(13280):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:830)  
  18. 01-06 14:04:08.200: W/System.err(13280):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)  
  19. 01-06 14:04:08.200: W/System.err(13280):    at dalvik.system.NativeStart.main(Native Method)  


 

 

 

MediaRecorder 初始化和設定代碼如下:

 

 

[java] view plain copy 
  1.    .....  
  2.        mMediaRecorder=new MediaRecorder();    
  3.        //設定視頻源    
  4.        mMediaRecorder.setVideoSource(MediaRecorder.VideoSource.DEFAULT);    
  5.        //設定音頻源    
  6.        mMediaRecorder.setAudioSource(MediaRecorder.AudioSource.DEFAULT);    
  7.        //設定檔案輸出格式    
  8.        mMediaRecorder.setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP);    
  9.        //設定視頻編碼方式    
  10.        mMediaRecorder.setVideoEncoder(MediaRecorder.VideoEncoder.H264);    
  11.        //設定音頻編碼方式    
  12.        mMediaRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.DEFAULT);    
  13.        //設定視頻高和寬,注意文檔的說明:    
  14.        //Must be called after setVideoSource().    
  15.        //Call this after setOutFormat() but before prepare().    
  16.        //設定錄製的視訊框架率,注意文檔的說明:    
  17.        //Must be called after setVideoSource().    
  18.        //Call this after setOutFormat() but before prepare().    
  19.        mMediaRecorder.setVideoFrameRate(20);    
  20.        //設定預覽畫面    
  21.        mMediaRecorder.setPreviewDisplay(mSurfaceHolder.getSurface());    
  22.        //設定輸出路徑    
  23.        mMediaRecorder.setOutputFile    
  24.        (Environment.getExternalStorageDirectory()+File.separator+System.currentTimeMillis()+".mp4");    
  25. .....  
  26. mediaRecorder.prepare();  
  27. mediaRecorder.start();  
  28. .....  
[java] view plain copy 
  1.   

 

相同的程式在Android2.3平台上正常運行,在Android4.0上報錯。

解決方案:

注釋掉設定視訊框架率的語句。//mMediaRecorder.setVideoFrameRate(mQuality.framerate);

 

將setVideoFrameRate去掉之後,如果還出現該錯誤,可將

mMediaRecorder.setVideoSize(videoWidth, videoHeight);也注釋掉

原因:

      視頻的幀率和視頻大小是需要硬體支援的,如果設定的幀率和視頻大小,如果硬體不支援就會出現錯誤。

參考:

          http://stackoverflow.com/questions/11249642/mediarecorder-start-failed-19

 

Error處理: android.media.MediaRecorder.start(Native Method) 報錯:start failed: -19

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.