0

0

CameraX 与 ML Kit 实现 Java 版条码扫描的完整教程

花韻仙語

花韻仙語

发布时间:2026-02-20 18:30:23

|

323人浏览过

|

来源于php中文网

原创

CameraX 与 ML Kit 实现 Java 版条码扫描的完整教程

本文详解如何在 android java 项目中基于 camerax 和 google ml kit 实现高性能条码(含 qr 码)扫描,同时彻底解决 kotlin 标准库版本冲突(如 duplicate class kotlin.collections.jdk8.collectionsjdk8kt)这一常见构建错误。

本文详解如何在 android java 项目中基于 camerax 和 google ml kit 实现高性能条码(含 qr 码)扫描,同时彻底解决 kotlin 标准库版本冲突(如 duplicate class kotlin.collections.jdk8.collectionsjdk8kt)这一常见构建错误。

在 Android 开发中,使用 CameraX 替代传统 Camera2 API 可显著降低相机集成复杂度;而结合 Google ML Kit 的 Barcode Scanning SDK,则能提供跨平台、离线、高精度且持续更新的条码识别能力。值得注意的是,官方 CameraX 文档虽以 Kotlin 为主,但其 Java API 完全可用——所有用例均可通过标准 Java 8+ 语法无缝调用,无需 Kotlin 运行时依赖。

✅ 正确配置依赖(关键:避免 Kotlin 冲突)

上述 Duplicate class kotlin.collections.jdk8.CollectionsJDK8Kt 错误,本质是模块间 Kotlin 标准库版本不一致导致的重复类冲突(例如 kotlin-stdlib:1.8.0 与 kotlin-stdlib-jdk8:1.6.0 同时被拉入)。解决方案如下:

在 app/build.gradle 中显式统一 Kotlin 版本并排除冗余传递依赖

android {
    compileSdk 34

    // 确保启用 Java 8+ 特性支持(ML Kit 和 CameraX 所需)
    compileOptions {
        sourceCompatibility JavaVersion.VERSION_1_8
        targetCompatibility JavaVersion.VERSION_1_8
    }
}

dependencies {
    // ✅ CameraX 核心组件(Java 兼容)
    def camerax_version = "1.3.0"
    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:1.3.0" // 替代旧版 preview-view

    // ✅ ML Kit 条码扫描(轻量、离线、Java 友好)
    implementation 'com.google.mlkit:barcode-scanning:18.4.0'

    // ⚠️ 关键:强制统一 Kotlin 版本,防止间接引入多个 kotlin-stdlib-jdk8
    implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk8:1.9.20"
    // 并排除可能由其他库引入的旧版 jdk8 模块
    configurations.all {
        resolutionStrategy {
            force "org.jetbrains.kotlin:kotlin-stdlib-jdk8:1.9.20"
            force "org.jetbrains.kotlin:kotlin-stdlib:1.9.20"
        }
    }
}

? 提示:kotlin-stdlib-jdk8 在 Kotlin 1.8+ 已被合并进主 kotlin-stdlib,因此推荐直接使用 kotlin-stdlib:1.9.20 并移除对 -jdk8 的单独引用,避免版本分裂。

IBM Watson
IBM Watson

IBM Watson文字转语音

下载

立即学习Java免费学习笔记(深入)”;

? Java 中实现 CameraX + ML Kit 扫描流程(核心代码)

以下为 Activity 中关键 Java 实现逻辑(无 Kotlin 依赖):

// 1. 声明视图与分析器
PreviewView previewView;
ImageAnalysis imageAnalysis;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_scanner);
    previewView = findViewById(R.id.previewView);

    startCamera();
}

private void startCamera() {
    ListenableFuture<ProcessCameraProvider> cameraProviderFuture =
            ProcessCameraProvider.getInstance(this);

    cameraProviderFuture.addListener(() -> {
        try {
            ProcessCameraProvider cameraProvider = cameraProviderFuture.get();
            bindPreview(cameraProvider);
        } catch (ExecutionException | InterruptedException e) {
            Log.e("CameraX", "Use case binding failed", e);
        }
    }, ContextCompat.getMainExecutor(this));
}

private void bindPreview(ProcessCameraProvider cameraProvider) {
    Preview preview = new Preview.Builder().build();
    preview.setSurfaceProvider(previewView.getSurfaceProvider());

    // 2. 构建 BarcodeScanner(Java 调用完全等效)
    BarcodeScannerOptions options = new BarcodeScannerOptions.Builder()
            .setBarcodeFormats(
                    Barcode.FORMAT_QR_CODE,
                    Barcode.FORMAT_EAN_13,
                    Barcode.FORMAT_CODE_128)
            .build();
    BarcodeScanner scanner = BarcodeScanning.getClient(options);

    // 3. ImageAnalysis 用于逐帧处理
    imageAnalysis = new ImageAnalysis.Builder()
            .setBackpressureStrategy(ImageAnalysis.STRATEGY_KEEP_ONLY_LATEST)
            .build();

    imageAnalysis.setAnalyzer(ContextCompat.getMainExecutor(this), image -> {
        InputImage inputImage = InputImage.fromMediaImage(
                image.getImage(), image.getImageInfo().getRotationDegrees());

        scanner.process(inputImage)
                .addOnSuccessListener(barcodes -> {
                    for (Barcode barcode : barcodes) {
                        String rawValue = barcode.getRawValue();
                        if (!TextUtils.isEmpty(rawValue)) {
                            Log.d("Barcode", "Detected: " + rawValue);
                            // ✅ 在主线程更新 UI(如 Toast 或 TextView)
                            runOnUiThread(() -> showResult(rawValue));
                        }
                    }
                })
                .addOnFailureListener(e -> Log.w("Barcode", "Scan failed", e))
                .addOnCompleteListener(() -> image.close()); // 必须关闭,否则内存泄漏
    });

    try {
        cameraProvider.unbindAll();
        cameraProvider.bindToLifecycle(this, UseCaseGroup.Builder()
                .addUseCase(preview)
                .addUseCase(imageAnalysis)
                .build());
    } catch (Exception e) {
        Log.e("CameraX", "Bind failed", e);
    }
}

⚠️ 注意事项与最佳实践

  • 生命周期绑定:务必使用 bindToLifecycle(this, ...) 而非 bindToLifecycle(this, lifecycleOwner, ...),确保 CameraX 自动随 Activity 生命周期启停;
  • 资源释放:Image.close() 必须在 onComplete 或 onFailure 后调用,否则会导致预览卡顿或 OOM;
  • 旋转适配:InputImage.fromMediaImage(...) 需传入正确的 rotationDegrees(来自 imageInfo),否则横竖屏下识别率骤降;
  • 性能优化:设置 STRATEGY_KEEP_ONLY_LATEST 可防止分析队列积压;避免在 onSuccess 中执行耗时操作(如网络请求),应交由后台线程处理;
  • 权限声明:别忘了在 AndroidManifest.xml 中添加:
    <uses-permission android:name="android.permission.CAMERA" />
    <uses-feature android:name="android.hardware.camera" />

? 总结

CameraX 与 ML Kit 的组合在 Java 项目中完全可行且稳定。核心在于:
① 通过 resolutionStrategy.force 统一 Kotlin 标准库版本,根治 Duplicate class 冲突;
② 使用 ImageAnalysis + BarcodeScanner 构建低延迟、高准确率的扫描流水线;
③ 严格遵循资源管理规范(关闭 Image、绑定生命周期、处理旋转)。

如需进一步参考,推荐 LearnToDroid 的 QR 扫描实战教程 —— 全 Java 示例,步骤清晰,可直接复用。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Kotlin协程编程与Spring Boot集成实践
Kotlin协程编程与Spring Boot集成实践

本专题围绕 Kotlin 协程机制展开,深入讲解挂起函数、协程作用域、结构化并发与异常处理机制,并结合 Spring Boot 展示协程在后端开发中的实际应用。内容涵盖异步接口设计、数据库调用优化、线程资源管理以及性能调优策略,帮助开发者构建更加简洁高效的 Kotlin 后端服务架构。

114

2026.02.12

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1929

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2106

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1131

2024.11.28

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

666

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

22

2025.12.06

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

675

2023.08.10

android开发三大框架
android开发三大框架

android开发三大框架是XUtil框架、volley框架、ImageLoader框架。本专题为大家提供android开发三大框架相关的各种文章、以及下载和课程。

323

2023.08.14

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

796

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 3.7万人学习

C# 教程
C# 教程

共94课时 | 9.8万人学习

Java 教程
Java 教程

共578课时 | 69万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号