安卓媒体录制器准备失败-17

4
我正在尝试使用Android的MediaRecorder捕获视频并进行编码。但是当我调用准备方法时,出现了“准备失败”的错误提示。
-17
java.io.IOException: prepare failed.

以下是我的代码:

mediaRecorder = new MediaRecorder();
mediaRecorder.setVideoSource(MediaRecorder.VideoSource.CAMERA);
mediaRecorder.setOutputFormat(MediaRecorder.OutputFormat.MPEG_4);
mediaRecorder.setOutputFile("/sdcard/test.mp4");
mediaRecorder.setVideoFrameRate(20);
mediaRecorder.setVideoSize(176, 144);
mediaRecorder.setVideoEncoder(MediaRecorder.VideoEncoder.H264);
mediaRecorder.setPreviewDisplay(surfaceHolder.getSurface());
mediaRecorder.prepare();

当我将VideoEncoder设置为H263并将Outputformat设置为THREE_GPP时,我不会收到此异常。

以下是完整的堆栈跟踪信息。

E/mm-camera 7x-vfe(   68): Received VFE start ACK!!! This is a user preview start.

D/QualcommCameraHardware(   68): startPreview X
E/AuthorDriver(   68): Command 13 completed with error -17
E/MediaRecorder( 6406): prepare failed: -17
W/System.err( 6406): java.io.IOException: prepare failed.
W/System.err( 6406):    at android.media.MediaRecorder._prepare(Native Method)
W/System.err( 6406):    at android.media.MediaRecorder.prepare(MediaRecorder.java:509)
W/System.err( 6406):    at org.video.VideoStreamSender.prepare(VideoStreamSender.java:50)
W/System.err( 6406):    at org.video.VideoPreview.surfaceCreated(VideoPreview.java:50)
W/System.err( 6406):    at android.view.SurfaceView.updateWindow(SurfaceView.java:540)
W/System.err( 6406):    at android.view.SurfaceView.dispatchDraw(SurfaceView.java:339)
W/System.err( 6406):    at android.view.ViewGroup.drawChild(ViewGroup.java:1646)
W/System.err( 6406):    at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1375)
W/System.err( 6406):    at android.view.ViewGroup.drawChild(ViewGroup.java:1646)
W/System.err( 6406):    at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1375)
W/System.err( 6406):    at android.view.View.draw(View.java:6742)
W/System.err( 6406):    at android.widget.FrameLayout.draw(FrameLayout.java:352)
W/System.err( 6406):    at android.view.ViewGroup.drawChild(ViewGroup.java:1648)
W/System.err( 6406):    at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1375)
W/System.err( 6406):    at android.view.ViewGroup.drawChild(ViewGroup.java:1646)
W/System.err( 6406):    at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1375)
W/System.err( 6406):    at android.view.View.draw(View.java:6742)
W/System.err( 6406):    at android.widget.FrameLayout.draw(FrameLayout.java:352)
W/System.err( 6406):    at com.android.internal.policy.impl.PhoneWindow$DecorView.draw(PhoneWindow.java:1872)
W/System.err( 6406):    at android.view.ViewRoot.draw(ViewRoot.java:1422)
W/System.err( 6406):    at android.view.ViewRoot.performTraversals(ViewRoot.java:1167)
W/System.err( 6406):    at android.view.ViewRoot.handleMessage(ViewRoot.java:1744)
W/System.err( 6406):    at android.os.Handler.dispatchMessage(Handler.java:99)
W/System.err( 6406):    at android.os.Looper.loop(Looper.java:143)
W/System.err( 6406):    at android.app.ActivityThread.main(ActivityThread.java:4914)
W/System.err( 6406):    at java.lang.reflect.Method.invokeNative(Native Method)
W/System.err( 6406):    at java.lang.reflect.Method.invoke(Method.java:521)
W/System.err( 6406):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
W/System.err( 6406):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
W/System.err( 6406):    at dalvik.system.NativeStart.main(Native Method)
I/CameraService(   68): [Camera KPI] 1st preview frame

你能否提供更大的堆栈跟踪信息,最好是通过编辑你的问题来实现? - pkk
1个回答

1
你尝试在设置源和格式之前将相机设置为媒体记录器了吗? 类似这样:
    mediaRecorder = new MediaRecorder();
    Camera camera = Camera.open();

(也许需要解锁相机)

    (camera.unlock();)

    mediaRecorder.setCamera(camera);
    mediaRecorder.setVideoSource(MediaRecorder.VideoSource.CAMERA);
    mediaRecorder.setOutputFormat(MediaRecorder.OutputFormat.MPEG_4);
    ...

在我的情况下它可行。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接