Android小记:Camara录制视频的调用

本文解决了一款Android应用在魅族手机上录制视频时异常退出的问题,通过调整代码中控制分辨率显示的部分,避免了与真实设备测试分辨率不一致导致的错误。同时,提供了解决MediaRecorder异常停止的方法,确保应用稳定运行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.Log日志1:

07-27 15:29:49.824: E/AndroidRuntime(10146): FATAL EXCEPTION: main
07-27 15:29:49.824: E/AndroidRuntime(10146): Process: com.sxit, PID: 10146
07-27 15:29:49.824: E/AndroidRuntime(10146): java.lang.RuntimeException: stop failed.
07-27 15:29:49.824: E/AndroidRuntime(10146): 	at android.media.MediaRecorder.stop(Native Method)
07-27 15:29:49.824: E/AndroidRuntime(10146): 	at com.sxit.personalcenter.ui.RecordAC.stopRecordVideo(RecordAC.java:319)
07-27 15:29:49.824: E/AndroidRuntime(10146): 	at com.sxit.personalcenter.ui.RecordAC.recordVideo(RecordAC.java:235)
07-27 15:29:49.824: E/AndroidRuntime(10146): 	at com.sxit.personalcenter.ui.RecordAC.onClick(RecordAC.java:163)
07-27 15:29:49.824: E/AndroidRuntime(10146): 	at android.view.View.performClick(View.java:4460)
07-27 15:29:49.824: E/AndroidRuntime(10146): 	at android.view.View$PerformClick.run(View.java:18860)
07-27 15:29:49.824: E/AndroidRuntime(10146): 	at android.os.Handler.handleCallback(Handler.java:733)
07-27 15:29:49.824: E/AndroidRuntime(10146): 	at android.os.Handler.dispatchMessage(Handler.java:95)
07-27 15:29:49.824: E/AndroidRuntime(10146): 	at android.os.Looper.loop(Looper.java:136)
07-27 15:29:49.824: E/AndroidRuntime(10146): 	at android.app.ActivityThread.main(ActivityThread.java:5114)
07-27 15:29:49.824: E/AndroidRuntime(10146): 	at java.lang.reflect.Method.invokeNative(Native Method)
07-27 15:29:49.824: E/AndroidRuntime(10146): 	at java.lang.reflect.Method.invoke(Method.java:515)
07-27 15:29:49.824: E/AndroidRuntime(10146): 	at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
07-27 15:29:49.824: E/AndroidRuntime(10146): 	at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:602)
07-27 15:29:49.824: E/AndroidRuntime(10146): 	at dalvik.system.NativeStart.main(Native Method)</span></strong>

两次连续点击录制按钮时的强制退出

解决方法:

原因:调用MediaRecorder的start()与stop()间隔不能小于1秒(有时候大于1秒也崩),否则程序必出现崩溃。

在stop()和start()方法中各自抛出异常.


2.Log日志2:

07-27 11:34:31.536: W/System.err(14706): java.lang.RuntimeException: setParameters failed
07-27 11:34:31.536: W/System.err(14706): at android.hardware.Camera.native_setParameters(Native Method)
07-27 11:34:31.536: W/System.err(14706): at android.hardware.Camera.setParameters(Camera.java:1707)
07-27 11:34:31.536: W/System.err(14706): at com.sxit.seekparttimejob.personalcenter.ui.RecordAC.deal(RecordAC.java:396)
07-27 11:34:31.536: W/System.err(14706): at com.sxit.seekparttimejob.personalcenter.ui.RecordAC.surfaceCreated(RecordAC.java:451)
07-27 11:34:31.536: W/System.err(14706): at android.view.SurfaceView.updateWindow(SurfaceView.java:572)
07-27 11:34:31.536: W/System.err(14706): at android.view.SurfaceView.access$000(SurfaceView.java:86)
07-27 11:34:31.536: W/System.err(14706): at android.view.SurfaceView$3.onPreDraw(SurfaceView.java:175)
07-27 11:34:31.536: W/System.err(14706): at android.view.ViewTreeObserver.dispatchOnPreDraw(ViewTreeObserver.java:847)
07-27 11:34:31.536: W/System.err(14706): at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:2228)
07-27 11:34:31.536: W/System.err(14706): at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1040)
07-27 11:34:31.536: W/System.err(14706): at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:6147)
07-27 11:34:31.536: W/System.err(14706): at android.view.Choreographer$CallbackRecord.run(Choreographer.java:761)
07-27 11:34:31.536: W/System.err(14706): at android.view.Choreographer.doCallbacks(Choreographer.java:574)
07-27 11:34:31.536: W/System.err(14706): at android.view.Choreographer.doFrame(Choreographer.java:544)
07-27 11:34:31.536: W/System.err(14706): at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:747)
07-27 11:34:31.536: W/System.err(14706): at android.os.Handler.handleCallback(Handler.java:733)
07-27 11:34:31.536: W/System.err(14706): at android.os.Handler.dispatchMessage(Handler.java:95)
07-27 11:34:31.536: W/System.err(14706): at android.os.Looper.loop(Looper.java:136)
07-27 11:34:31.536: W/System.err(14706): at android.app.ActivityThread.main(ActivityThread.java:5114)
07-27 11:34:31.536: W/System.err(14706): at java.lang.reflect.Method.invokeNative(Native Method)
07-27 11:34:31.536: W/System.err(14706): at java.lang.reflect.Method.invoke(Method.java:515)
07-27 11:34:31.536: W/System.err(14706): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
07-27 11:34:31.536: W/System.err(14706): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:602)
07-27 11:34:31.536: W/System.err(14706): at dalvik.system.NativeStart.main(Native Method)


在魅族手机中点击录制视频时异常退出;
解决方法:

这个错误是和调用相机摄像头相关的。

一.产生这个错误的原因主要在于代码控制分辨率的显示和真机测试分辨率不一样。

WindowManager wm = (WindowManager)getSystemService(Context.WINDOW_SERVICE);

Display display = wm.getDefaultDisplay();

Camera.Parameters parameters = camera.getParameters();//得到摄像头的参数

parameters.setPreviewSize(display.getWidth(),display.getHeight());注释掉这两句

parameters.setPictureSize(display.getHeight(),display.getWidth());注释掉这两句

二:有可能你的真机是属于定制机,或者深度开发过,对camera对了不少的改动。

camera.setParameters(parameters);//导致不能使用这个方法了,注释掉这一行吧。





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值