鸿蒙HarmonyOS应用开发:多码识别

2023-10-24 12:04

本文主要是介绍鸿蒙HarmonyOS应用开发:多码识别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

华为HMS Core的扫码接口更适用于简单的个人使用。在商业环境,如货架、医用试管、图书馆书架等,常常遇到复杂的多码扫描需求,这时需要专业的扫码SDK。尽管当前市场上的主流商业SDK尚未支持鸿蒙HarmonyOS,但我们仍可以通过HTTP请求来调用扫码服务,满足在鸿蒙系统上的多码扫描需求。

准备工作

  1. 申请一个Dynamsoft Barcode Reader免费试用序列号。

  2. 安装Node.js依赖包。

    npm install barcode4nodejs express body-parser
    

使用Node.js搭建扫码服务

启动一个Express服务,监听3000端口,代码如下:

const express = require('express');
const path = require('path');
const fs = require('fs');
const app = express();
const http = require('http');
const server = http.createServer(app);
const bodyParser = require('body-parser');app.use(express.static('public'));
app.use('/node_modules', express.static(__dirname + '/node_modules'));
app.use(bodyParser.json({ limit: '50mb' }));
app.use(bodyParser.urlencoded({ limit: '50mb', extended: true }));const port = process.env.PORT || 3000;server.listen(port, '0.0.0.0', () => {host = server.address().address;console.log(`Server running at http://0.0.0.0:${port}/`);
});

通过HTTP POST请求接收图片文件流:

app.post('/readbarcode', async (req, res) => {const data = req.body;let chunks = [];req.on('data', (chunk) => {chunks.push(chunk);});req.on('end', () => {let nodeBuffer = Buffer.concat(chunks);});
});

使用barcode4nodejs来实现服务端的扫码功能:

const dbr = require("barcode4nodejs")
dbr.initLicense("LICENSE-KEY")
dbr.decodeFileStreamAsync(nodeBuffer, nodeBuffer.length, dbr.formats.QRCode).then((results) => {let output = '';let index = 0;for (result of results) {output += index + ': ' + result['value'] + ' ';index += 1;}res.status(200).send(output);});

鸿蒙应用开发步骤

entry/src/main/module.json5文件中配置网络权限ohos.permission.INTERNET

{"module": {"name": "entry",..."abilities": [...],"requestPermissions": [{"name": "ohos.permission.INTERNET"}]}
}

在工程的rawfile目录中放入一张示例图片。

鸿蒙图片资源

程序启动的时候,我们把图片加载到内存中,用于显示以及后续的扫码请求。在entry/src/main/ets/pages/Index.ets中添加如下代码:

import http from '@ohos.net.http';
import image from '@ohos.multimedia.image';const context = getContext(this);
const resourceMgr = context.resourceManager;@Entry
@Component
struct Index {@State displayImage: any = undefined @State result: string = 'N/A'imageData: ArrayBuffer = undefinedhost: string = 'http://192.168.8.72:3000'text: string = 'https://devblogs.damingsoft.com/album/2023/10/multicode.jpg'onPageShow() {(async () => {const fileData = await resourceMgr.getRawFileContent('qrcode.jpg');this.imageData = fileData.buffer;const imageSource = image.createImageSource(this.imageData);imageSource.createPixelMap().then(pixelmap => {this.displayImage = pixelmap;});})();}build() {Scroll(this.scroller) {Column() {...Image(this.displayImage).width('100%').objectFit(ImageFit.Contain).margin({bottom: 5})Text(this.result).fontSize(16).textAlign(TextAlign.Start).fontWeight(FontWeight.Bold).backgroundColor(0xd2cab3)}.justifyContent(FlexAlign.Start).width('100%').height('100%').padding({left: 5, top: 5, right: 5, bottom: 5})}}
}

这里的host就是刚才启动的服务器地址。imageData是图片的二进制数据,displayImage是用于显示的PixelMap对象。result是扫码结果。

添加一个按钮来触发HTTP POST扫码请求:

Button('Read Multi QR Codes').backgroundColor('#007DFF').margin(15).onClick(() => {if (!this.imageData) return;let url = this.host + '/readbarcode'let httpRequest = http.createHttp();httpRequest.on('headersReceive', (header) => {console.info('header: ' + JSON.stringify(header));})httpRequest.request(url,{method: http.RequestMethod.POST,header: {'Content-Type': 'application/octet-stream'},extraData: this.imageData,}, (err, data) => {if (!err) {try {this.result = data.result.toString()} catch (error) {console.error("Error parsing JSON:", error);}} else {console.info('error:' + JSON.stringify(err));httpRequest.off('headersReceive');httpRequest.destroy();}});})

Content-Type设置成application/octet-streamextraData设置成图片的二进制数据。

鸿蒙二维码识别

为了方便在模拟器里测试不同的图片,我们再创建一个输入框用来输入图片URL,然后通过HTTP GET请求来获取图片数据:

TextArea({placeholder: 'https://devblogs.damingsoft.com/album/2023/10/multicode.jpg',
}).placeholderFont({ size: 16, weight: 400 }).width(336).height(56).margin(20).fontSize(16).fontColor('#182431').backgroundColor('#FFFFFF').onChange((value: string) => {this.text = value})Button('Get an image').backgroundColor('#007DFF').margin(15).onClick(() => {let httpRequest = http.createHttp();httpRequest.on('headersReceive', (header) => {console.info('header: ' + JSON.stringify(header));})httpRequest.request(this.text,{method: http.RequestMethod.GET,}, (err, data) => {if (!err) {if (data.result instanceof ArrayBuffer) {this.imageData = data.result as ArrayBufferconst imageSource = image.createImageSource(this.imageData);imageSource.createPixelMap().then(pixelmap => {this.displayImage = pixelmap;});}} else {console.info('error:' + JSON.stringify(err));httpRequest.off('headersReceive');httpRequest.destroy();}});})

最后我们测试一张包含多个二维码的图片:

鸿蒙多码识别程序

源代码

https://gitee.com/yushulx/harmonyos-multi-barcode-qrcode-scan

这篇关于鸿蒙HarmonyOS应用开发:多码识别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/275046

相关文章

JavaScript中的isTrusted属性及其应用场景详解

《JavaScript中的isTrusted属性及其应用场景详解》在现代Web开发中,JavaScript是构建交互式应用的核心语言,随着前端技术的不断发展,开发者需要处理越来越多的复杂场景,例如事件... 目录引言一、问题背景二、isTrusted 属性的来源与作用1. isTrusted 的定义2. 为

Python调用另一个py文件并传递参数常见的方法及其应用场景

《Python调用另一个py文件并传递参数常见的方法及其应用场景》:本文主要介绍在Python中调用另一个py文件并传递参数的几种常见方法,包括使用import语句、exec函数、subproce... 目录前言1. 使用import语句1.1 基本用法1.2 导入特定函数1.3 处理文件路径2. 使用ex

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

将Python应用部署到生产环境的小技巧分享

《将Python应用部署到生产环境的小技巧分享》文章主要讲述了在将Python应用程序部署到生产环境之前,需要进行的准备工作和最佳实践,包括心态调整、代码审查、测试覆盖率提升、配置文件优化、日志记录完... 目录部署前夜:从开发到生产的心理准备与检查清单环境搭建:打造稳固的应用运行平台自动化流水线:让部署像

Linux中Curl参数详解实践应用

《Linux中Curl参数详解实践应用》在现代网络开发和运维工作中,curl命令是一个不可或缺的工具,它是一个利用URL语法在命令行下工作的文件传输工具,支持多种协议,如HTTP、HTTPS、FTP等... 目录引言一、基础请求参数1. -X 或 --request2. -d 或 --data3. -H 或

在Ubuntu上部署SpringBoot应用的操作步骤

《在Ubuntu上部署SpringBoot应用的操作步骤》随着云计算和容器化技术的普及,Linux服务器已成为部署Web应用程序的主流平台之一,Java作为一种跨平台的编程语言,具有广泛的应用场景,本... 目录一、部署准备二、安装 Java 环境1. 安装 JDK2. 验证 Java 安装三、安装 mys

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一