通过字节数组生成码图
基本概念
码图生成能力支持将字节数组转换为自定义格式的码图。
场景介绍
码图生成能力支持将字节数组转换为自定义格式的码图。
例如:调用码图生成能力,将字节数组转换成交通一卡通二维码使用。
约束与限制
- 码图生成能力支持Phone、Tablet、Wearable、2in1、TV(从5.1.0(18)版本开始支持Wearable、从5.1.1(19)版本开始支持2in1、TV)。
- 若Scan Kit识别某码图内容显示内容为乱码,则该码图的字节数组需要通过专门的解码器解析,例如地铁闸机。
业务流程

- 用户向应用发起生成码图请求后,传入需要生成的码图信息,包括码图的类型、宽高等。
- 应用通过调用Scan Kit的createBarcode接口启动码图生成能力。
- Scan Kit通过将字节数组转换为码图并返回给应用。
- 应用向用户返回生成码图结果。
接口说明
通过字节数组生成码图,以Promise形式生成码图。具体API说明详见接口文档。
| 接口名 | 接口描述 |
|---|---|
| createBarcode(content: ArrayBuffer, options: CreateOptions): Promise<image.PixelMap> | 码图生成接口,返回生成的码图,类型为image.PixelMap,可以使用Image组件渲染成图片。使用Promise异步回调。 |
开发步骤
码图生成根据传参内容直接生成所需码图,需要传入固定参数和可选参数。
为了方便开发者接入,我们提供了详细的样例工程供参考,推荐参考示例工程接入。
以下示例为调用码图生成能力的createBarcode接口实现码图生成。
-
导入码图生成接口模块,该模块提供了码图生成的参数和方法,导入方法如下。
// 导入码图生成需要的图片模块、错误码模块import { scanCore, generateBarcode } from '@kit.ScanKit';import { BusinessError } from '@kit.BasicServicesKit';import { image } from '@kit.ImageKit';import { hilog } from '@kit.PerformanceAnalysisKit';import { buffer } from '@kit.ArkTS'; -
调用码图生成能力的createBarcode接口实现码图生成。
-
通过Promise方式回调,获取生成的码图。
const TAG: string = 'Create barcode';@Entry@Componentstruct Index {@State pixelMap: image.PixelMap | undefined = undefinedbuild() {Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Center, justifyContent: FlexAlign.Center }) {Button('generateBarcode Promise').onClick(() => {this.pixelMap = undefined;let content: string ='0177C10DD10F7768600202312110000063458FD14112345678FFFFD381012610b746365409210201b66636540ad0200020000000000110e617003201000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000006645fbec664358ECF657CB40693c92da';let contentBuffer: ArrayBuffer = buffer.from(content, 'hex').buffer; // 将包含十六进制字符的字符串转换成ArrayBufferlet options: generateBarcode.CreateOptions = {scanType: scanCore.ScanType.QR_CODE,height: 400,width: 400}try {// 码图生成接口,成功返回PixelMap格式图片generateBarcode.createBarcode(contentBuffer, options).then((pixelMap: image.PixelMap) => {this.pixelMap = pixelMap;hilog.info(0x0001, TAG, 'Succeeded in creating barCode.');}).catch((err: BusinessError) => {hilog.error(0x0001, TAG, `Failed to createBarCode. Code: ${err.code}, message: ${err.message}`);})} catch (err) {hilog.error(0x0001, TAG,`Failed to createBarcode by Promise with options. Code: ${err.code}, message: ${err.message}`);}})// 获取生成码图后显示if (this.pixelMap) {Image(this.pixelMap).width(300).height(300).objectFit(ImageFit.Contain)}}.width('100%').height('100%')}}
-
模拟器开发
暂不支持模拟器开发,调用接口会返回错误信息“Emulator is not supported.”