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