並且也發現,在使用MediaRecorder進行視頻錄製,調用start()方法時報錯,發生
spydroid-android測試在android4.0系統上一樣的錯誤,具體錯誤以下:
- 01-06 14:04:07.790: V/MediaRecorder(13280): prepare
- 01-06 14:04:07.790: V/IMediaRecorder(13280): prepare
- 01-06 14:04:07.800: V/MediaRecorder(13280): start
- 01-06 14:04:07.800: V/IMediaRecorder(13280): start
- 01-06 14:04:08.190: E/MediaRecorder(13280): start failed: -19
- 01-06 14:04:08.190: W/System.err(13280): java.lang.RuntimeException: start failed.
- 01-06 14:04:08.200: W/System.err(13280): at android.media.MediaRecorder.start(Native Method)
- 01-06 14:04:08.200: W/System.err(13280): at com.yousee.videocapturedemo.VideoCapturePlus$2.onClick(VideoCapturePlus.java:145)
- 01-06 14:04:08.200: W/System.err(13280): at android.view.View.performClick(View.java:3515)
- 01-06 14:04:08.200: W/System.err(13280): at android.view.View$PerformClick.run(View.java:14144)
- 01-06 14:04:08.200: W/System.err(13280): at android.os.Handler.handleCallback(Handler.java:605)
- 01-06 14:04:08.200: W/System.err(13280): at android.os.Handler.dispatchMessage(Handler.java:92)
- 01-06 14:04:08.200: W/System.err(13280): at android.os.Looper.loop(Looper.java:148)
- 01-06 14:04:08.200: W/System.err(13280): at android.app.ActivityThread.main(ActivityThread.java:4503)
- 01-06 14:04:08.200: W/System.err(13280): at java.lang.reflect.Method.invokeNative(Native Method)
- 01-06 14:04:08.200: W/System.err(13280): at java.lang.reflect.Method.invoke(Method.java:511)
- 01-06 14:04:08.200: W/System.err(13280): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:830)
- 01-06 14:04:08.200: W/System.err(13280): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
- 01-06 14:04:08.200: W/System.err(13280): at dalvik.system.NativeStart.main(Native Method)
MediaRecorder 初始化和設置代碼以下:
- .....
- mMediaRecorder=new MediaRecorder();
-
- mMediaRecorder.setVideoSource(MediaRecorder.VideoSource.DEFAULT);
-
- mMediaRecorder.setAudioSource(MediaRecorder.AudioSource.DEFAULT);
-
- mMediaRecorder.setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP);
-
- mMediaRecorder.setVideoEncoder(MediaRecorder.VideoEncoder.H264);
-
- mMediaRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.DEFAULT);
-
-
-
-
-
-
- mMediaRecorder.setVideoFrameRate(20);
-
- mMediaRecorder.setPreviewDisplay(mSurfaceHolder.getSurface());
-
- mMediaRecorder.setOutputFile
- (Environment.getExternalStorageDirectory()+File.separator+System.currentTimeMillis()+".mp4");
- .....
- mediaRecorder.prepare();
- mediaRecorder.start();
- .....
相同的程序在Android2.3平臺上正常運行,在Android4.0上報錯。html
解決方法:java
註釋掉設置視頻幀率的語句。//mMediaRecorder.setVideoFrameRate(mQuality.framerate);android
將setVideoFrameRate去掉以後,若是還出現該錯誤,可將app
mMediaRecorder.setVideoSize(videoWidth, videoHeight);也註釋掉ide
緣由:oop
視頻的幀率和視頻大小是須要硬件支持的,若是設置的幀率和視頻大小,若是硬件不支持就會出現錯誤。測試
參考:this
http://stackoverflow.com/questions/11249642/mediarecorder-start-failed-19編碼