Android高通 8.1 老化apk打开摄像头花屏问题

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<Surface>()
                    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、多尝试 多修改