我开发了一个用户拍照的应用程序,然后将图像临时写入文件以检查网络连接,如果网络可用,则上传到服务器。
我一直在测试,它就像一种享受。但是,我开始在 LG Nexus 4 上进行测试,图像质量非常低。预览质量完美,但是当它上传并显示在应用程序中时,它的质量太低了,你甚至无法辨认出图像。
我在三星 s3 和 s4 上进行了测试,显示的图像非常完美。我在 onPictureTaken 方法中记录了字节数组的大小,与其他两个设备产生的值相比,它的大小非常低。
我在日志猫中注意到我得到了这个:
09-22 10:15:13.001 196-4548/? E/mm-camera﹕ sensor_load_chromatix: libchromatix_imx111_preview.so: 30
09-22 10:15:13.101 196-4548/? E/mm-camera﹕ vfe_ops_init: E
09-22 10:15:13.111 196-4548/? E/mm-camera﹕ vfe_legacy_stats_buffer_init: AEC_STATS_BUFNUM
09-22 10:15:13.111 196-4548/? E/mm-camera﹕ vfe_legacy_stats_buffer_init: AEC_STATS_BUFNUM
09-22 10:15:13.121 196-4548/? E/mm-camera﹕ mctl_init_stats_proc_info: snap_max_line_cnt =30096
09-22 10:15:13.131 174-174/? E/QCameraHWI﹕ android::status_t android::QCameraHardwareInterface::setPreviewWindow(preview_stream_ops_t*): mPreviewWindow = 0x0xb79ae9d8, mStreamDisplay = 0x0xb79a8448
09-22 10:15:13.131 174-174/? D/QCameraHWI﹕ android::status_t android::QCameraHardwareInterface::startPreview(): start preview now
09-22 10:15:13.131 174-174/? I/QCameraHWI﹕ android::status_t android::QCameraHardwareInterface::startPreview2():Setting ZSL mode
09-22 10:15:13.131 196-4548/? E/mm-camera﹕ config_proc_CAMERA_SET_INFORM_STARTPREVIEW
09-22 10:15:13.131 196-4548/? E/mm-camera﹕ config_update_stream_info Storing stream parameters for video inst 1 as : width = 640, height 480, format = 1 inst_handle = 810081 cid = 0
09-22 10:15:13.151 196-4548/? E/mm-camera﹕ config_update_stream_info Storing stream parameters for video inst 3 as : width = 640, height 480, format = 1 inst_handle = 830083 cid = 0
09-22 10:15:13.151 196-4548/? E/mm-camera﹕ config_update_stream_info Storing stream parameters for video inst 4 as : width = 512, height 384, format = 1 inst_handle = 840084 cid = 0
09-22 10:15:13.171 196-4548/? E/mm-camera﹕ config_decide_vfe_outputs: Ports Used 3, Op mode 1
09-22 10:15:13.171 196-4548/? E/mm-camera﹕ config_decide_vfe_outputs Current mode 0 Full size streaming : Disabled
09-22 10:15:13.171 196-4548/? E/mm-camera﹕ config_decide_vfe_outputs: Primary: 640x480, extra_pad: 0x0, Fmt: 1, Type: 1, Path: 1
09-22 10:15:13.171 196-4548/? E/mm-camera﹕ config_decide_vfe_outputs: Secondary: 640x480, extra_pad: 0x0, Fmt: 1, Type: 3, Path: 4
09-22 10:15:13.171 196-4548/? E/mm-camera﹕ config_update_inst_handles Updated the inst handles as 810081, 830083, 0, 0
09-22 10:15:13.312 196-4548/? E/mm-camera﹕ sensor_load_chromatix: libchromatix_imx111_zsl.so: 26
09-22 10:15:13.402 196-4548/? E/mm-camera﹕ camif_client_set_params: camif has associated with obj mask 0x1
09-22 10:15:13.402 196-4548/? E/mm-camera﹕ config_v2_CAMERA_START_common CAMIF_PARAMS_ADD_OBJ_ID failed -1
09-22 10:15:13.402 196-4548/? E/mm-camera﹕ vfe_operation_config: format 3
09-22 10:15:13.402 196-4548/? E/mm-camera﹕ vfe_operation_config:vfe_op_mode=5
09-22 10:15:13.402 196-4548/? E/mm-camera﹕ Invalid ASD Set Params Type
09-22 10:15:13.402 196-4548/? E/mm-camera﹕ vfe_set_bestshot: Bestshot mode not changed
所以我只是希望有人遇到过这个问题吗?或者有人会有任何关于它的信息,因为我不知道如何继续......
谢谢
编辑 为了尝试解决这个问题,我添加了以下代码:
Camera.Parameters parameters = camera.getParameters();
List<Camera.Size> supportedPreviewSizes = camera.getParameters().getSupportedPreviewSizes();
List<Camera.Size> supportedPictureSize = camera.getParameters().getSupportedPictureSizes();
Log.i("SUPPORTED SIZES: ", String.valueOf(supportedPreviewSizes.size()));
Log.i("SUPPORTED PICTURE SIZES: ", String.valueOf(supportedPictureSize.size()));
parameters.setPreviewSize(supportedPreviewSizes.get(0).width, supportedPreviewSizes.get(0).height);
parameters.setPictureSize(supportedPictureSize.get(1).width, supportedPictureSize.get(1).height);
正如我所认为的那样,正在使用不受支持的图片尺寸。