1、很多人看到这个日志第一感觉可能觉得哪里没有合理释放,于是带着这个思路去进行百度探索
2、一开始我去寻找 ImageReader.OnImageAvailableListener 这个问题
var afterBitmap: Bitmap? = null
/**监听拍照的图片 */
private val imageAvailableListener =
ImageReader.OnImageAvailableListener { reader ->
try {
// ThreadPoolManager.getInstance().execute {
// 获取捕获的照片数据
val image = reader.acquireNextImage()
val buffer = image.planes[0].buffer
val data = ByteArray(buffer.remaining())
buffer[data]
// val bitmapByteArray = BitmapUtil.compressInSampleSize(data, 800, 480)
// afterBitmap =
// BitmapFactory.decodeByteArray(bitmapByteArray, 0, bitmapByteArray.size)
//显示图片
val options =
BitmapFactory.Options()
options.inSampleSize = 2
val bitmap =
BitmapFactory.decodeByteArray(data, 0, data.size, options)
requireActivity().runOnUiThread(){
iv5.isVisible = true
iv5.setImageBitmap(bitmap)// iv.setImageBitmap(adjustTakePhotoRotation(bitmap,0))
showButton(fail = true, pass = true)
}
image.close()//不关闭不能连拍
} catch (e: Exception) {
}
}
3、后面网上去寻找因为 Camera2最大连拍限制是2 网上很多数包括Google相机源码 需要单独开个线程去处理图片的逻辑 ,然后ui在主线程去处理,最后尝试一波在平板以及自己手机连续点击拍照还是出现crash 日志内容java.lang.IllegalStateException: CameraDevice was already closed
4、我于是陷入困境 然后去原生骁龙相机去找答案 很多人都是在触摸onTouch事件里面去处理连拍的逻辑 然后看到生命周期。
5、于是又尝试修改 是不是哪里没有完全释放掉那 就直接从报错信息上排查吧,加多点日志,看下哪个地方有把camera device关掉没 ,另一方面就是看下完整日志,看下有系统这块有没其它异常
分析日志,是在拍照完成后,这时应该是请求预览,然后发现camera device关闭了
这时候把所有cameradevice释放地方加上日志
6、惊喜出现了 onPause里面 这个打印已经可以知道前面异常的原因了。就是onpause的时候释放了camera.device,拍照回调里面又去请求了预览。
7、解决方案在 报错是在拍照完成的oncapturecompled里面,然后去恢复预览出问题的,所以应该在拍照完成的回调里面加 要是觉的其它地方也可能有问题,就都加下 比如拍照/预览功能
8、然后再连续点击拍照暂时没有出现crash
其他camera2具体问题 具体分析,到这里基本流程结束了。转载请注明出处,谢谢!