1、最近由于公司VR 3D系统要做双Camera老化测试apk,同时老化4小时需要轮询切换二个摄像头,保证后面camera标定精度数据更准确。
2、一开始我尝试用之前方案移植过去然后同时打开双摄像头 突然发现花屏 如下图所示
3、于是一第一时间想到是不是分辨率不兼容或者硬件Camera问题 或者找驱动确认 驱动确认结果2D系统没有问题 ,于是我交叉验证换了一台机器 跟硬件结果还是花屏,因为之前也处理类似的case,于是我自己尝试修改固定的分辨率1280*720 (720P)代码如下(这里只是部门代码github上面也有很多camera源码以及骁龙相机源码 大家可以下载自行研究)
- private val mStateCallback2: CameraDevice.StateCallback =
- object : CameraDevice.StateCallback() {
- override fun onOpened(camera: CameraDevice) {
- Log.i(TAG, "StateCallback! onOpened 2")
- mCameraDevice2 = camera // 打开成功,保存代表相机的CameraDevice实例
- val surfaceTexture = mTextureView2!!.surfaceTexture
- surfaceTexture.setDefaultBufferSize(1280, 720) //3264X2448(800万)
- val surface = Surface(surfaceTexture)
- val previewList = ArrayList
() - previewList.add(surface)
- try {
- // 6.将TextureView的surface传递给CameraDevice
- mCameraDevice2!!.createCaptureSession(
- previewList,
- object : CameraCaptureSession.StateCallback() {
- override fun onConfigured(session: CameraCaptureSession) {
- try {
- val builder =
- mCameraDevice2!!.createCaptureRequest(CameraDevice.TEMPLATE_PREVIEW)
- builder.addTarget(surface) // 必须设置才能正常预览
- val captureRequest = builder.build()
- // 7.CameraCaptureSession与CaptureRequest绑定(这是最后一步,已可显示相机预览)
- session.setRepeatingRequest(captureRequest, null, null)
- mHandler.removeMessages(CAMERA_RELEASE)
- mHandler.sendEmptyMessageDelayed(CAMERA_RELEASE,delayTwoSeconds)
-
-
- } catch (e: CameraAccessException) {
- Log.e(
- TAG,
- "createCaptureRequest error = " + e.message
- )
- }
- }
-
- override fun onConfigureFailed(session: CameraCaptureSession) {
- Log.e(TAG, "onConfigureFailed")
- LogUtils.e("Camera2异常")
- Toast.makeText(requireContext(),"Camera2异常,请检查设备!", Toast.LENGTH_LONG).show()
- }
- },
- null
- )
- } catch (e: CameraAccessException) {
- Log.e(TAG, "createCaptureSession error = " + e.message)
- }
- }
-
- override fun onDisconnected(camera: CameraDevice) {
- Log.e(
- TAG,
- "StateCallback! onDisconnected camera.getId() = " + camera.id
- )
- releaseCamera()
- }
-
- override fun onError(camera: CameraDevice, error: Int) {
- Log.e(
- TAG,
- "StateCallback camera.getId() = " + camera.id + " , error = " + error)
- LogUtils.e("Camera2异常")
- Toast.makeText(requireContext(),"Camera2异常,请检查设备!", Toast.LENGTH_LONG).show()
- releaseCamera()
- }
- }
4、一开始花屏抓的logcat 错误如下
5、最后花屏问题解决了 同时为了确认 adb shell dumpsys media.camera 查看当前系统支持输出分辨率列表 如下图所示
6、安装一个骁龙相机源码 大多数分辨率都是支持的,所以再次确认花屏是分辨率问题导致。
7、大家如果实在没有办法可以先从大的分辨率 跟小的去试 这样可能验证更快一些,其他不啰嗦了。就是简单记录下自己踩的坑而已。
转载请注明出处,谢谢!
8 、总结:
1、camera 8.1 架构与Camx有很大差异
2、遇到问题学会交叉编译验证 尤其是这种花屏问题 首先想到硬件或者分辨率的问题(这个需要经验积累)
3、网上查资料以及adb shell dumpsys media.camera确定camera sensor是否正常挂载
4、多尝试 多修改