仿微信二维码极速扫描(MLKit及CameraX初体验),安卓消息分发机制

本文介绍了如何在Android应用中使用MLKit和CameraX实现快速的二维码扫描功能。首先,通过添加相关依赖来支持CameraX和生命周期管理。接着,详细讲解了如何配置CameraX预览、开启相机预览以及绑定生命周期。然后,利用ImageAnalysis和QRCodeAnalyser解析图片中的二维码。最后,展示了如何处理和关闭解析结果。

}

<application …>

CameraX的支持当然也要一并加上

// 版本号
def camerax_version = “1.0.0-rc03”
// 对camera 及 camera2的支持,可自行选择
implementation “androidx.camera:camera-core:cameraxversion"implementation"androidx.camera:camera−camera2:{camerax_version}" implementation "androidx.camera:camera-camera2:cameraxversion"implementation"androidx.camera:cameracamera2:{camerax_version}”

项目使用的是基于jetpack lifecycle的框架,所以加上lifecycle的支持

implementation “androidx.camera:camera-lifecycle:${camerax_version}”

预览用到了camerax自带的预览控件

implementation “androidx.camera:camera-view:1.0.0-alpha22”

接下来就是具体的代码实现了 首先,用到了相机及相册,自然需要添加相应的权限申请

ActivityCompat.requestPermissions(this, arrayOf(Manifest.permission.CAMERA,Manifest.permission.WRITE_EXTERNAL_STORAGE),REQUEST_PERMISSION)

先来看看扫码界面的实现,主要包含了预览的PreviewView及用于绘制扫码线条及扫码结果的ScanOverlay

<androidx.camera.view.PreviewView
android:id="@+id/previewView"
android:layout_width=“match_parent”
android:layout_height=“match_parent”
/>
<com.hsmedia.mlkitdemo.ScanOverlay
android:id="@+id/overlay"
android:layout_width=“match_parent”
android:layout_height=“0dp”
app:layout_constraintTop_toBottomOf="@id/iv_exit"
app:layout_constraintBottom_toTopOf="@id/tv_tips"
android:layout_marginBottom=“20dp”
android:layout_marginTop=“20dp”
/>

接下来看一下如何开启CameraX的预览

CameraX自带了检测相机是否可用的监听,可以在相机可用之后,再进行后续操作

cameraProviderFuture = ProcessCameraProvider.getInstance(this)
cameraProviderFuture.addListener(Runnable {
val cameraProvider = cameraProviderFuture.get()
bindScan(cameraProvider, overlay.width,overlay.height)
}, ContextCompat.getMainExecutor(this@BarcodeScanningActivity))

并且,CameraX绑定生命周期控件后,可以根据生命周期,自行释放相机,妈妈再也不用担心忘记关相机啦

val preview : Preview = Preview.Builder().build()

//绑定预览
preview.setSurfaceProvider(previewView.surfaceProvider)

//使用后置相机
val cameraSelector : CameraSelector = CameraSelector.Builder()
.requireLensFacing(CameraSelector.LENS_FACING_BACK)
.build()
//将相机绑定到当前控件的生命周期
camera = cameraProvider.bindToLifecycle(this as LifecycleOwner, cameraSelector, imageAnalysis, preview)

这样,就可以开启预览啦,可以注意到,代码中绑定到生命周期的时候,使用了一个imageAnalysis的useCases,而这,就是用于图片扫描的组件了

//配置图片扫描
val imageAnalysis = ImageAnalysis.Builder()
.setTargetResolution(Size(width, height))
.setBackpressureStrategy(ImageAnalysis.STRATEGY_KEEP_ONLY_LATEST)
.build()

光这样还不行,还需要为图片扫描配置解析扫码内容的解析器QRCodeAnalyser,说了这么多,终于要用到MLKit的二维码解析了 来看一下QRCodeAnalyser的具体实现

@SuppressLint(“UnsafeExperimentalUsageError”)
override fun analyze(imageProxy: ImageProxy) {
val mediaImage = imageProxy.image ?: kotlin.run {
imageProxy.close()
return
}
val image = InputImage.fromMediaImage(mediaImage, imageProxy.imageInfo.rotationDegrees)
detector.process(image)
.addOnSuccessListener { barCodes ->
if (barCodes.size > 0){
listener.invoke(barCodes[0],imag
eProxy.width,imageProxy.height)
//接收到结果后,就关闭解析
detector.close()
}
}
.addOnFailureListener { Log.d(TAG, “Error: ${it.message}”) }
.addOnCompleteListener { imageProxy.close() }

}

这个类主要实现了ImageAnalysis.Analyzer,并实现了analyze解析方法,其中imageProxy就是CameraX传递过来的图片扫描内容了 其主要内容,就是根据传递过来的图片扫描内容,使用detector进行解析,而这个detector又是怎么来的呢

//配置当前扫码格式
private val options = BarcodeScannerOptions.Builder()
.setBarcodeFormats(
Barcode.FORMAT_QR_CODE,
Barcode.FORMAT_AZTEC
)
.build()
//获取解析器
private val detector = BarcodeScanning.getClient(options)

这里的BarcodeScanning就是MLKit提供的二维码解析组件了
ORMAT_AZTEC
)
.build()
//获取解析器
private val detector = BarcodeScanning.getClient(options)

这里的BarcodeScanning就是MLKit提供的二维码解析组件了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值