android camera setParameters failed 类问题分析总结
2016-02-20 16:33
507 查看
在 monkey test 测试中出现了一例 RuntimeException ,即 setParameters failed.
LOG显示为:
09-01 18:47:17.348 15656 15675 E AndroidRuntime: FATAL EXCEPTION: Camera Handler Thread
09-01 18:47:17.348 15656 15675 E AndroidRuntime: Process: com.android.camera, PID: 15656
09-01 18:47:17.348 15656 15675 E AndroidRuntime: java.lang.RuntimeException: setParameters failed
09-01 18:47:17.348 15656 15675 E AndroidRuntime: at android.hardware.Camera.native_setParameters(Native Method)
09-01 18:47:17.348 15656 15675 E AndroidRuntime: at android.hardware.Camera.setParameters(Camera.java:1760)
09-01 18:47:17.348 15656 15675 E AndroidRuntime: at com.android.camera.CameraManager$CameraHandler.handleMessage(CameraManager.java:260)
09-01 18:47:17.348 15656 15675 E AndroidRuntime: at android.os.Handler.dispatchMessage(Handler.java:102)
09-01 18:47:17.348 15656 15675 E AndroidRuntime: at android.os.Looper.loop(Looper.java:136)
09-01 18:47:17.348 15656 15675 E AndroidRuntime: at android.os.HandlerThread.run(HandlerThread.java:61)
最终查到:
09-01 18:47:17.338 235 4175 E QCameraParameters: int32_t qcamera::QCameraParameters::setZoom(const qcamera::QCameraParameters&): invalid value -1 out of (0, 60)
setZoom 的值存在异常。
解决方案就是在 setZoom 的时候,先检查 mZoomValue 是否合法,如果不合法,则 return 掉。
后面在网上查了一下 camera setParameters failed 同类的错误,大部分都是因为 previewSize 或者 pictureSize 设置不合理(即底层不支持)造成的。
最终有网友给出的方法就是找到一个支持的尺寸再设下去。例如:
当然,这也不失为一种好的方法。我们碰到这类问题时,也可以将支持的 previewSize 或者 pictureSize 以log的形式打印出来看:
总结:
setParameters failed 错误肯定是某一个参数设置错了导致的。仔细查看该错误附近的log,总能找到导致问题发生的原凶!
参考: http://stackoverflow.com/questions/3890381/camera-setparameters-failed-in-android http://www.eoeandroid.com/thread-28137-2-1.html http://bbs.csdn.net/topics/370195903?page=1#post-396249333
转自: http://blog.csdn.net/fulinwsuafcie/article/details/39348869
LOG显示为:
09-01 18:47:17.348 15656 15675 E AndroidRuntime: FATAL EXCEPTION: Camera Handler Thread
09-01 18:47:17.348 15656 15675 E AndroidRuntime: Process: com.android.camera, PID: 15656
09-01 18:47:17.348 15656 15675 E AndroidRuntime: java.lang.RuntimeException: setParameters failed
09-01 18:47:17.348 15656 15675 E AndroidRuntime: at android.hardware.Camera.native_setParameters(Native Method)
09-01 18:47:17.348 15656 15675 E AndroidRuntime: at android.hardware.Camera.setParameters(Camera.java:1760)
09-01 18:47:17.348 15656 15675 E AndroidRuntime: at com.android.camera.CameraManager$CameraHandler.handleMessage(CameraManager.java:260)
09-01 18:47:17.348 15656 15675 E AndroidRuntime: at android.os.Handler.dispatchMessage(Handler.java:102)
09-01 18:47:17.348 15656 15675 E AndroidRuntime: at android.os.Looper.loop(Looper.java:136)
09-01 18:47:17.348 15656 15675 E AndroidRuntime: at android.os.HandlerThread.run(HandlerThread.java:61)
最终查到:
09-01 18:47:17.338 235 4175 E QCameraParameters: int32_t qcamera::QCameraParameters::setZoom(const qcamera::QCameraParameters&): invalid value -1 out of (0, 60)
setZoom 的值存在异常。
解决方案就是在 setZoom 的时候,先检查 mZoomValue 是否合法,如果不合法,则 return 掉。
后面在网上查了一下 camera setParameters failed 同类的错误,大部分都是因为 previewSize 或者 pictureSize 设置不合理(即底层不支持)造成的。
最终有网友给出的方法就是找到一个支持的尺寸再设下去。例如:
try { int PreviewWidth = 0; int PreviewHeight = 0; WindowManager wm = (WindowManager) getSystemService(Context.WINDOW_SERVICE);//获取窗口的管理器 Display display = wm.getDefaultDisplay();//获得窗口里面的屏幕 Camera.Parameters parameters = mCamera.getParameters(); // 选择合适的预览尺寸 List<Camera.Size> sizeList = parameters.getSupportedPreviewSizes(); // 如果sizeList只有一个我们也没有必要做什么了,因为就他一个别无选择 if (sizeList.size() > 1) { Iterator<Camera.Size> itor = sizeList.iterator(); while (itor.hasNext()) { Camera.Size cur = itor.next(); if (cur.width >= PreviewWidth && cur.height >= PreviewHeight) { PreviewWidth = cur.width; PreviewHeight = cur.height; break; } } } parameters.setPreviewSize(PreviewWidth, PreviewHeight); //获得摄像区域的大小 parameters.setPreviewFrameRate(3);//每秒3帧 每秒从摄像头里面获得3个画面 parameters.setPictureFormat(PixelFormat.JPEG);//设置照片输出的格式 parameters.set("jpeg-quality", 85);//设置照片质量 parameters.setPictureSize(PreviewWidth, PreviewHeight);//设置拍出来的屏幕大小 // mCamera.setParameters(parameters);//把上面的设置 赋给摄像头 mCamera.setPreviewDisplay(mySurfaceView.getHolder());//把摄像头获得画面显示在SurfaceView控件里面 mCamera.startPreview();//开始预览 mPreviewRunning = true; } catch (IOException e) { Log.e(TAG, e.toString()); }
当然,这也不失为一种好的方法。我们碰到这类问题时,也可以将支持的 previewSize 或者 pictureSize 以log的形式打印出来看:
//List<Size> pictureSizes = mCameraDevice.getCamera().getParameters().getSupportedPictureSizes(); List<Size> pictureSizes = mParameters.getSupportedPictureSizes(); int length = pictureSizes.size(); for (int i = 0; i < length; i++) { LOGD("SupportedPictureSizes : " + pictureSizes.get(i).width + "x" + pictureSizes.get(i).height); } //List<Size> previewSizes = mCameraDevice.getCamera().getParameters().getSupportedPreviewSizes(); List<Size> previewSizes = mParameters.getSupportedPreviewSizes(); length = previewSizes.size(); for (int i = 0; i < length; i++) { LOGD("SupportedPreviewSizes : " + previewSizes.get(i).width + "x" + previewSizes.get(i).height); }
总结:
setParameters failed 错误肯定是某一个参数设置错了导致的。仔细查看该错误附近的log,总能找到导致问题发生的原凶!
参考: http://stackoverflow.com/questions/3890381/camera-setparameters-failed-in-android http://www.eoeandroid.com/thread-28137-2-1.html http://bbs.csdn.net/topics/370195903?page=1#post-396249333
转自: http://blog.csdn.net/fulinwsuafcie/article/details/39348869
相关文章推荐
- PIPE和socketpair的区别
- 四、再谈PyTypeObject http://blog.csdn.net/debugm/article/details/8243496
- 自己生成非官方iPhone toolchain的头文件
- HDU 2476 String painter(区间dp)
- pcie干货系列之-TLP’s size/TLP fail/4K boundary/requs
- Codeforces 630A Again Twenty Five!
- saiku、mondrian前奏之——立方体、维度、Schema的基本概念
- saiku、mondrian前奏之——立方体、维度、Schema的基本概念
- [Locked] Paint House I & II
- 无线高清会议室终端之Airplay
- 分享自yebai445791253 《Verilog $random用法》
- trait中的属性类型
- SVM实用操作: svmtrain and svmclassify
- 【Mybatis】Parameter 'xxx' not found. Available parameters are [1, 0, param1, param2]
- CodeForces-630A. Again Twenty Five!【找规律】
- bzoj 3172 [Tjoi2013]单词(fail树,DP)
- 人工智能和机器学习领域的一些有趣的开源项目
- HDU 3487 Play with Chain
- 趣说游戏AI开发:曼哈顿街角的A*算法
- AIDL简单使用(通过它跨应用传递对象(数据))