更新记录

1.1(2022-12-19)

完成芯烨多种打印机插件


平台兼容性

Android Android CPU类型 iOS
适用版本区间:5.0 - 10.0 armeabi-v7a:未测试,arm64-v8a:未测试,x86:未测试 ×

原生插件通用使用流程:

  1. 购买插件,选择该插件绑定的项目。
  2. 在HBuilderX里找到项目,在manifest的app原生插件配置中勾选模块,如需要填写参数则参考插件作者的文档添加。
  3. 根据插件作者的提供的文档开发代码,在代码中引用插件,调用插件功能。
  4. 打包自定义基座,选择插件,得到自定义基座,然后运行时选择自定义基座,进行log输出测试。
  5. 开发完毕后正式云打包

付费原生插件目前不支持离线打包。
Android 离线打包原生插件另见文档 https://nativesupport.dcloud.net.cn/NativePlugin/offline_package/android
iOS 离线打包原生插件另见文档 https://nativesupport.dcloud.net.cn/NativePlugin/offline_package/ios

注意事项:使用HBuilderX2.7.14以下版本,如果同一插件且同一appid下购买并绑定了多个包名,提交云打包界面提示包名绑定不一致时,需要在HBuilderX项目中manifest.json->“App原生插件配置”->”云端插件“列表中删除该插件重新选择


一、初始化插件对象

//打印机插件对象
var ZPrinter = uni.requireNativePlugin('ZPrinter');

//蓝牙插件对象
var ZPrinterBt = uni.requireNativePlugin('ZPrinter-Bt');

//票据POS58插件对象
var ZPrinterPos58 = uni.requireNativePlugin('ZPrinter-Pos58');

//票据POS80插件对象
var ZPrinterPos80 = uni.requireNativePlugin('ZPrinter-Pos80');

//76针式插件对象
var ZPrinterPos76 = uni.requireNativePlugin('ZPrinter-Pos76');

二、打印机插件接口

网络方式连接打印机

//网络方式连接打印机
var ip = "";//网络地址
ZPrinter.ConnectNetPort(ip, function(res){
    console.log(res);
    if (res.code == 200) {
        //连接成功
    } else {
        //连接失败
    }
});

蓝牙方式连接打印机

//蓝牙方式连接打印机
var address = "";//蓝牙地址
ZPrinter.ConnectBtPort(address, function(res){
    console.log(res);
    if (res.code == 200) {
        //连接成功
    } else {
        //连接失败
    }
});

获取打印机usb设备列表

//获取打印机usb设备列表
var usbDevList = ZPrinter.GetUsbPathNames();
console.log(usbDevList);

usb方式连接打印机

//usb方式连接打印机
var usbDevice = "";//usb设备名称,从上一步获取到
ZPrinter.ConnectUsbPort(usbDevice, function(res){
    console.log(res);
    if (res.code == 200) {
        //连接成功
    } else {
        //连接失败
    }
});

断开当前打印机连接

//断开当前打印机连接
ZPrinter.DisconnectCurrentPort(function(res){
    console.log(res);
    if (res.code == 200) {
        //成功
    } else{
        //失败
    }
});

发送自定义的指令集合

//发送自定义的指令集合
var processData = [
    [0x01, 0x02],
    [0x01, 0x02, 0x03]
];
ZPrinter.WriteSendData(processData,function(res){
    console.log(res);
    if (res.code == 200) {
        //成功
    } else {
        //失败
    }
});

隐私、权限声明

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

USB权限 蓝牙权限

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

插件不采集任何数据

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

使用中有什么不明白的地方,就向插件作者提问吧~ 我要提问