CameraX使用详解:从入门到实战
创作时间:
作者:
@小白创作中心
CameraX使用详解:从入门到实战
引用
CSDN
1.
https://m.blog.csdn.net/qq_22120623/article/details/144373875
在移动应用开发中,集成相机功能是一个常见的需求。Google推出的CameraX库为开发者提供了一种简化且强大的方式来实现相机功能。本文将详细介绍CameraX的使用,包括其核心功能、配置方法以及特别是实时分析的实现。
CameraX简介
CameraX是一个Jetpack库,基于Camera2 API,但提供了更高层次的抽象,简化了开发过程。其优势包括:
- 简化开发:通过简化的API接口,减少了与设备特定配置的直接交互。
- 向后兼容:支持Android 5.0(API级别21)及以上的设备。
- 强大的功能:支持图像捕获、视频录制、实时分析等。
- 自动适配:自动处理设备差异,确保一致的体验。
项目配置
在开始使用CameraX之前,需要进行项目配置。
添加依赖
在build.gradle文件中添加CameraX库的依赖项:
dependencies {
def camerax_version = "1.3.0-alpha06"
implementation "androidx.camera:camera-core:$camerax_version"
implementation "androidx.camera:camera-camera2:$camerax_version"
implementation "androidx.camera:camera-lifecycle:$camerax_version"
implementation "androidx.camera:camera-view:$camerax_version"
implementation "androidx.camera:camera-extensions:$camerax_version"
}
权限声明
在AndroidManifest.xml中声明必要的权限:
<uses-permission android:name="android.permission.CAMERA" />
<uses-permission android:name="android.permission.RECORD_AUDIO" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
在运行时请求相机权限是必要的,以确保应用能够访问设备的相机硬件。
CameraX基本用法
初始化相机
CameraX的核心组件是ProcessCameraProvider,它控制相机的生命周期和用例绑定。
private fun startCamera() {
val cameraProviderFuture = ProcessCameraProvider.getInstance(this)
cameraProviderFuture.addListener(Runnable {
val cameraProvider: ProcessCameraProvider = cameraProviderFuture.get()
val cameraSelector = CameraSelector.DEFAULT_BACK_CAMERA
val preview = Preview.Builder().build().also {
it.setSurfaceProvider(viewFinder.surfaceProvider)
}
try {
cameraProvider.unbindAll()
cameraProvider.bindToLifecycle(
this, cameraSelector, preview
)
} catch(exc: Exception) {
Log.e(TAG, "Use case binding failed", exc)
}
}, ContextCompat.getMainExecutor(this))
}
图像捕获
除了预览之外,CameraX还支持图像捕获,通过ImageCapture用例实现。
private fun takePhoto() {
val imageCapture = ImageCapture.Builder().build()
val photoFile = File(
outputDirectory,
SimpleDateFormat(FILENAME_FORMAT, Locale.US).format(System.currentTimeMillis()) + ".jpg"
)
val outputOptions = ImageCapture.OutputFileOptions.Builder(photoFile).build()
imageCapture.takePicture(
outputOptions, ContextCompat.getMainExecutor(this), object : ImageCapture.OnImageSavedCallback {
override fun onError(exc: ImageCaptureException) {
Log.e(TAG, "Photo capture failed: ${exc.message}", exc)
}
override fun onImageSaved(output: ImageCapture.OutputFileResults) {
val savedUri = Uri.fromFile(photoFile)
Log.d(TAG, "Photo capture succeeded: $savedUri")
}
}
)
}
实时分析的使用
实时分析是CameraX的一项强大功能,它允许开发者实时处理相机视频流,例如用于二维码扫描、面部识别或其他图像处理任务。通过ImageAnalysis用例实现。
设置实时分析
首先,创建一个ImageAnalysis实例,并设置其分析器:
private fun setupImageAnalysis() {
val imageAnalysis = ImageAnalysis.Builder()
.setBackpressureStrategy(ImageAnalysis.STRATEGY_KEEP_ONLY_LATEST)
.build()
imageAnalysis.setAnalyzer(ContextCompat.getMainExecutor(this), ImageAnalysis.Analyzer { imageProxy ->
processImage(imageProxy)
})
val cameraProvider = ProcessCameraProvider.getInstance(this).get()
val cameraSelector = CameraSelector.DEFAULT_BACK_CAMERA
try {
cameraProvider.unbindAll()
cameraProvider.bindToLifecycle(this, cameraSelector, imageAnalysis)
} catch (exc: Exception) {
Log.e(TAG, "Binding failed", exc)
}
}
处理图像
在processImage方法中,实现图像分析的具体逻辑:
private fun processImage(imageProxy: ImageProxy) {
// 获取图像数据
val mediaImage = imageProxy.image
if (mediaImage != null) {
// 在此处进行图像处理,例如使用ML Kit进行二维码扫描或面部识别
// val image = InputImage.fromMediaImage(mediaImage, imageProxy.imageInfo.rotationDegrees)
// 处理完成后关闭imageProxy
imageProxy.close()
}
}
在这个过程中,关键是要在处理完每一帧图像后调用imageProxy.close(),以释放资源并允许下一帧的处理。
高级功能
扩展功能
CameraX支持多种扩展功能,例如HDR、夜景模式等。这些功能可以通过camera-extensions库启用。
val hdrImageCapture = ImageCapture.Builder()
.setCaptureMode(ImageCapture.CAPTURE_MODE_MAXIMIZE_QUALITY)
.setHdrEnabled(true)
.build()
自定义UI
CameraX提供了默认的CameraView,但开发者可以完全自定义用户界面,以满足特定的设计需求。
<androidx.camera.view.PreviewView
android:id="@+id/viewFinder"
android:layout_width="match_parent"
android:layout_height="match_parent" />
热门推荐
抚仙湖:中国第九大淡水湖泊,你去过吗?
家庭聚会祝福语大集合,让你秒变祝福达人!
大年初二回娘家,这些祝福语让你倍有面儿
大年初二回娘家,温馨祝福提前送
春节回娘家:一个传承千年的孝道习俗
关于咳嗽,你了解多少?
兼职工作,如何有效规划你的职业?
零售业兼职:17岁学生的职场入门课
伟杰智能科技教你正确使用电动牙刷
声波电动牙刷 vs 手动牙刷:谁更能深层清洁?
拉萨必打卡酥油茶名店:仓姑寺&光明港琼
藏历新年必备:酥油茶的正确打开方式
文成公主与酥油茶:一段跨越千年的文化交融
酥油茶:藏族文化的独特符号
一打鸡蛋10美元!美国人快吃不起鸡蛋了
百姓福音到,鸡蛋价格下跌,究竟是什么原因?有什么影响?
红虫喂养观赏鱼(如何正确处理红虫)
重庆九曲河新建重光体育中心:6万平米运动空间即将亮相
从龟兹重光,看文明交流互鉴|2024读懂中国
癌症逐渐纳入慢病管理,专家:提高生存率需长期管理
曹勇主任:癌症=绝症?满足这3个条件,带瘤生存照样可以活的很好
1953年2角纸币真假怎么辩真 第二套人民币2角价格
求职路上的隐形翅膀:社交技巧与人脉资源的力量
大连全面启动2024年重点民生实事项目
古代官职辨析:太子太师与太子太傅的职责异同
古代皇子的官职兼职与政治角色
古代官职辨析:太子太师与太子太傅的职责异同
【健康科普】抗心律失常中成药——稳心颗粒小提示
牙刷头变形竟暗示口腔危机?
锁金村5号小区拆违行动:城市违建治理的有益探索