更新记录
1.0.0(2025-10-08)
平台兼容性
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
说明: 断开当前蓝牙连接。
返回值:
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()