更新记录

1.0.0(2025-10-08)

  • 支持安卓、iOS蓝牙;
  • 添加常用指令接口;

平台兼容性

uni-app(4.75)

Vue2 Vue3 Chrome Safari app-vue app-nvue Android iOS 鸿蒙
- - - - - - 5.0 12 -
微信小程序 支付宝小程序 抖音小程序 百度小程序 快手小程序 京东小程序 鸿蒙元服务 QQ小程序 飞书小程序 快应用-华为 快应用-联盟
- - - - - - - - - - -

uni-app x(4.75)

Chrome Safari Android iOS 鸿蒙 微信小程序
- - 5.0 12 - -

欢迎使用 xl-hmA300 插件

🧾 汉印 HM-A300 系列蓝牙打印 SDK 接口说明文档

本文档详细介绍蓝牙打印 SDK 的 TypeScript 接口定义及说明,适用于调用蓝牙打印机进行标签打印、二维码、条码、图像及文本输出等操作。


📖 目录


🔌 蓝牙操作

1. 获取蓝牙状态

getBluetoothState(callback: BooleanBack): void

说明: 获取当前蓝牙开关状态。

参数名 类型 必填 说明
callback (ok: boolean) => void 蓝牙状态回调,true 表示开启,false 表示关闭

2. 扫描蓝牙

scanBlue(callback: BlueDeviceBack): void

扫描附近的蓝牙设备。

参数名 类型 必填 说明
callback (device: HBlueDevice) => void 每发现一个蓝牙设备都会回调一次

HBlueDevice 类型说明:

字段 类型 必填 说明
deviceId string 蓝牙设备唯一标识(Android: MAC 地址 / iOS: UUID)
name string 蓝牙设备名称
paired boolean 是否已配对,仅 Android 有效

3. 停止扫描蓝牙

stopScanBlue(): void

停止蓝牙扫描,无参数。


4. 连接蓝牙

connectBlue(deviceId: string, callback: NumberBack): void

连接指定蓝牙打印机。

参数名 类型 必填 说明
deviceId string 蓝牙设备 ID
callback (result: number) => void 连接结果回调

返回值:

数值 含义
0 连接成功
-1 连接超时
-2 蓝牙地址格式错误
-3 打印机与 SDK 不匹配(握手失败)

5. 断开连接

disconnect(): boolean

说明: 断开当前蓝牙连接。
返回值:

  • true:断开成功
  • false:断开失败

6. 获取打印机序列号

getSN(callback: StringBack): void
参数名 类型 必填 说明
callback (result: string) => void 返回打印机 SN 编号

🧾 打印机设置

7. 打印机自检

selfTest(): void

执行打印机自检页,无参数。


8. 设置打印区域高度

printAreaSize(p: AreaParam): void
参数名 类型 必填 说明
height number 标签最大高度(点)
qty number 打印的标签数量(最大值 1024)
offset string 整体横向偏移,默认 0

9. 设置标签宽度

pageWidth(width: number): void
参数名 类型 必填 说明
width number 标签宽度(单位:点)

10. 标签定位

form(): void

说明: 在调用 print() 前使用,仅在标签模式下有效。


11. 执行打印

print(): void

说明: 执行打印缓存区的内容。


12. 设置对齐方式

setAlign(p: AlignParam): void
参数名 类型 必填 说明
p "LEFT" | "CENTER" | "RIGHT" 对齐方式

13. 设置打印浓度

setContrast(p: number): void
参数名 类型 必填 说明
p number 打印浓度:0=默认,1=中,2=深,3=非常深

14. 设置打印速度

setSpeed(p: number): void
参数名 类型 必填 说明
p number 打印速度 0~5,数值越大越快

15. 设置字体放大倍数

setMag(p: MagParam): void
字段 类型 必填 说明
width number 字体宽度放大倍数(1~16)
height number 字体高度放大倍数(1~16)

16. 设置字体加粗

setBold(p: number): void
参数名 类型 必填 说明
p number 加粗系数 0~5,0 取消加粗

🖨 打印内容

17. 打印文本

text(p: TextParam): void
字段 类型 必填 说明
x number 起始横坐标(点)
y number 起始纵坐标(点)
font string 字体名称
content string 打印内容
rotation '0' '90' '180'

18. 打印图片

image(p: ImageParam): void
字段 类型 必填 说明
x number 起始横坐标
y number 起始纵坐标
base64 string 图片 Base64 数据
algorithm 'Threshold' |'DiffusionDithering' | 'AggregateDithering' 图片算法. 默认二值算法(Threshold)
compressType number 压缩类型 0=不压缩 1=整体 2=分包

19. 打印条码

barcode(p: BarcodeParam): void
字段 类型 必填 说明
x number 起始横坐标
y number 起始纵坐标
width number 窄条宽度
height number 条码高度
content string 条码内容
ratio string 宽条窄条比例
vertical boolean 是否纵向打印
type BarcodeType 条码类型(默认 128)
undertext boolean 是否显示下方文字
number string 字体类型(仅 undertext=true 有效)
size string 字体大小
offset string 条码与文字距离

20. 打印二维码

qrCode(p: QrcodeParam): void
字段 类型 必填 说明
x number 起始横坐标
y number 起始纵坐标
content string 二维码内容
vertical boolean 是否纵向打印
M string QR 类型(1=普通 2=扩展)
U string 模块单位大小(1~32,默认6)

21. 打印矩形/直线/反白框

box(p: BoxParam): void
line(p: BoxParam): void
inverseLine(p: BoxParam): void
字段 类型 必填 说明
x number 起点 X
y number 起点 Y
xend number 终点 X
yend number 终点 Y
thickness number 线条宽度

22.使用示例

connectBlue("XX:XX:XX:XX:XX:XX", (result) => {
  if (result === 0) {
    // 确保连接成功再进行后续操作
  } else {
      return;
  }
});

hPrinter.printAreaSize({
    height: 60 * 8,
    qty: 1
});
hPrinter.pageWidth(60 * 8)
hPrinter.text({
    x: 10,
    y: 10,
    font: '16',
    content: '小鸡炖蘑菇'
})
hPrinter.barcode({
    x: 150,
    y: 30,
    content: 'ABCDEFG',
    type: '128',
    width: 1,
    ratio: '1',
    height: 50,
});
hPrinter.qrCode({
    x: 10,
    y: 50,
    M: '2',
    U: '6',
    content: '123456'
})
hPrinter.image({
    x: 150,
    y: 120,
    base64: ''
})

// hPrinter.form() // 标签纸需要加
hPrinter.print()

隐私、权限声明

1. 本插件需要申请的系统权限列表:

安卓: <uses-permission android:name="android.permission.BLUETOOTH"/> <uses-permission android:name="android.permission.BLUETOOTH_ADMIN" /> <uses-permission android:name="android.permission.BLUETOOTH_CONNECT"/> <uses-permission android:name="android.permission.BLUETOOTH_SCAN"/> <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/> <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/> <uses-permission android:name="android.permission.BLUETOOTH_SCAN" /> iOS: <key>NSBluetoothAlwaysUsageDescription</key> <string>开启蓝牙</string> <key>NSBluetoothPeripheralUsageDescription</key> <string>蓝牙</string> <key>UIBackgroundModes</key> <array> <string>bluetooth-central</string> </array>

2. 本插件采集的数据、发送的服务器地址、以及数据用途说明:

3. 本插件是否包含广告,如包含需详细说明广告表达方式、展示频率: