更新记录

3.8.4(2024-04-07)

  • 新增ESC 小票打印 同一行文字可以给不同的字设置不同大小。
  • 新增ESC 小票打印 可以对文字设置宽高比例。
  • 新增ESC 小票可以以绘图的方式排版

3.8.3(2024-01-03)

  • 新增 标签 可视化排板工具,可快速布置元素位置,加快排板布局方便调试。

3.8.2(2023-12-28)

  • 安卓端,新增支持 同时可以连接多台打印机,打印数据,和过去断开再切换连接,大大增加了使和的便利性, 同时连接多台打印机示例项目,在插件页面,重新导入示例项目获取。
查看更多

平台兼容性

Android Android CPU类型 iOS
适用版本区间:4.4 - 14.0 armeabi-v7a:未测试,arm64-v8a:未测试,x86:未测试 适用版本区间:9 - 17

原生插件通用使用流程:

  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原生插件配置”->”云端插件“列表中删除该插件重新选择


Android 和 IOS 佳博小票 / 标签 打印机插件,安卓端支持同时连接多台打印机,详细可参考示例项目

图片

提醒. IOS 版本需要设置蓝牙权限, 在配置文件 manifest.json 中 ios 项添加以下内容,如果没有添加,使用蓝牙时,否则会导致应用闪退。

 "ios" : {
                "privacyDescription" : {
                    "NSBluetoothPeripheralUsageDescription" : "是否允许获取蓝牙用于连续打印机?",
                    "NSBluetoothAlwaysUsageDescription" : "是否允许获取蓝牙用于连续打印机?"
                },
                "UIBackgroundModes" : [ "bluetooth-central" ]
 }

[小标样版]

图片

[自定义字体打印]

图片

1. 插件说明

一、实例化插件

const plug= uni.requireNativePlugin('Html5app-Gprinter'); 

2.本插件方法介绍

方法名称 说明
BluetoothPort 打开默认的蓝牙搜索框-连接打印机
connectIP 网关-端口连接打印机
SerialPort 串中-连接打印机
connectDevices 蓝牙 MAC 地址连接打印机
printer 打印小票 或 标签纸
state 查询连接状态
writePDFToEsc 打印pdf 文档,小票打印 仅支持android 端
writePDFToTsc 打印pdf 文档,标签打印 仅支持android 端
writeTSC 纯TSC 指令,只适用标签打印
writeCPCL 纯CPCL 指令,只适用面单标签打印
disconnect 断开打印机连接
pairedDevices 获取已配对的蓝牙设备,仅支持Android
searchDevices 搜索蓝牙设备
cancelSearch 取消搜索

一、打开蓝牙默认的搜索界面,搜索蓝牙打印机 ,setBackgroundColor:是蓝牙搜索界面头部背景颜色,默认为:蓝色 ,安卓有效.

plug.BluetoothPort({setBackgroundColor:"#2088d2"},result=>{

            result //返回值                
});

返回 JSON 格式 : {"code":"1","msg":"未连接"} 状态码

状态码 说明
0 已连接打印机,重新选择请先断开打印机
1 未连接
2 连接中,请稍等...
3 已连接
4 打印机连接失败,请检查打印机后再试

自动连接蓝牙打印机

  • 为了避免重复打开蓝牙搜索框, 在第一次连接蓝牙时,会返回一个 mac 参数,保存这个值,之后连接打印机时,不需要再打开蓝牙搜索框了,直接传 mac 这个值,就可以实现自动连接。
  • 可以在第一次连接失败时,实现重复自动连接打印机。
//连接打印机
plug.connectDevices({address:address},ret=>{

    console.log(JSON.stringify(ret));

});

二、网关端口连接打印机, 有些打印机不支持蓝牙的,可以usb 线连接电脑打印的,可以设置局域网端口打印,使用时手机wifi 连接和电脑同一段ip地址,例如:192.168.0.xxx

//端口网络连接

plug.connectIP({ip:"",port:""},result=>{    

});
  • 参数说明:ip => 局域网ip地址,port=> 端口 , 参数留空则打开默认的输入框,手动填写ip地址和端口

三、UBS 安卓端连接打印机

plug.connectUSB({setBackgroundColor:"#2088d2"},ret=>{   

});

图片

图片

3、查询打印器状态

plug.state({},result=>{

result //返回值    

});

返回 JSON 格式 :

{"code":1,"msg":"打印机已断开"} 
{"code":3,"msg":"打印机已连接"}

4、断开打印机

plug.disconnect({},result=>{});

返回 JSON 格式 :{"code":"1","msg":"打印机已断开"} ,这个代表已经断开。

图片

5、打印图片说明

  • 支持网络图片, 一般不建议使用网络图片,因为网络图片下载需时间,会导致延迟。
https://www.html5-app.com/gprinter.png
  • 本地图片,相对地址需要转为绝对路径
var filePath=plus.io.convertLocalFileSystemURL("_doc/06e43dddb107.png");
或者
var filePath=plus.io.convertLocalFileSystemURL("static/gprinter.png");

base64 图片打印 ,格式必须包含 data:image/png;base64 开头才可以识别到。



ESC 打印 pdf 小票文档 writePDFToEsc

let filePath=plus.io.convertLocalFileSystemURL("static/pdfFile.pdf");

plug.writePDFToEsc({filePath:filePath,width:400},ret=>{

});

TSC 打印 pdf 标签文档 writePDFToTsc

let filePath=plus.io.convertLocalFileSystemURL("static/pdfFile.pdf");

plug.writePDFToTsc({filePath:filePath,width:400},ret=>{

});

CPCL 打印 pdf 标签文档 writePDFToCpcl

let filePath=plus.io.convertLocalFileSystemURL("static/pdfFile.pdf");

plug.writePDFToCpcl({filePath:filePath,width:400},ret=>{

});

纯 TSC 指令打印 ,支持android 和 ios

  • 纯TSC 指令打印,需要对TSC 指令熟悉,可以使用更多指令方法,可以参考示例项目下的,TSC 指令文档说明。
  • 每一行指令 都要加上 \n 为结束,不要使用 \r\n ,结束只留 \n 就可以。
let tsc="SIZE 40 mm,15 mm \n GAP 2 mm,0 mm \n CLS\n TEXT 50,50,\"4\",0,1,1,\"DEMO FOR TEXT\" \n PRINT 1 \n";

plug.writeTSC({"tsc":tsc},ret=>{

});

纯 CPCL 指令打印 ,支持android 和 ios

  • 纯CPCL 指令打印,需要对CPCL 指令熟悉,可以使用更多指令方法,可以参考示例项目下的,CPCL 指令文档说明。
  • 每一行指令 都要加上 \n 为结束,不要使用 \r\n ,结束只留 \n 就可以。
    // 16进制字符串图片
    let img="0000000000000000000000000000000000000000000000000000000000000000000000000000003FFFFFFFFFFFFFFFFFFFFFFFFC3FFFFFFFFFFFFFFFFFFFFFFFFC3FFFFFFFFFFFFFFFFFFFFFFFFC3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000F80000000000000000000C3003FC0000000000000000800C3007FC0000000000000003800C3007000000000000000003800C300700630C0783939C0307E00C3007C07FBF1FC3FBBE0FCFF00C3007F07FFF1FE3FBFF1FEFF00C3001F871E790E3CBCF38E3800C30007C71C780F383873FF3800C30003E71C39FF383873FF3800C30001E71C39FF383873FE3800C30041E71C3B8F383873803800C30063C71C3BCF383873C63D00C3007FC71C39FF383871FE1F00C3003F071C38E7383870780F00C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3000000000000000000000000C3FFFFFFFFFFFFFFFFFFFFFFFFC3FFFFFFFFFFFFFFFFFFFFFFFFC3FFFFFFFFFFFFFFFFFFFFFFFFC000000000000000000000000000000000000000000000000000000000000000000000000000000";

    // CPCL 指令打印标签, 详细的CPCL 指令说明,参考CPCL 指令说明书
    let str="! 0 200 200 210 1 \n";
    str+="TEXT \"0\" 0 30 40 你好啊!中国 \n";
    str+="EG 13 104 50 80 "+img+" \n";
    str+="BARCODE 128 1 1 50 160 80 HORIZ \n";
    str+="TEXT 7 0 210 140 HORIZ \n";
    str+="BARCODE QR 160 160 M 2 U 6 \n";
    str+="MA,15233sdd \n"
    str+="ENDQR \n";
    str+="PRINT \n";
     console.log(str);
     plug.writeCPCL({"cpcl":str},function(e){
      console.log(JSON.stringify(e));
    });
  • CPCL 提供本地打印图片
 //打印本地图片
  let img=plus.io.convertLocalFileSystemURL("static/gprinter.png");

  let str="! 0 200 200 320 1 \n";
  str+="TEXT \"0\" 0 30 40 这是多张打印示例第一张 \n";
  str+="EG 100 60 80 "+img+" \n";   //例如 100代表图片宽度 60代表坐标x=60,  80代表坐标 y=80, 后面是本地图片路径
  str+="PRINT \n";
  • 多张不同的CPCL 标签打印, 把每一张的cpcl 标签再放进一个大的数组中。
   let datas=[];

   let str="! 0 200 200 320 1 \n";
   str+="TEXT \"0\" 0 30 40 这是多张打印示例第一张 \n";
   str+="EG 100 60 80 "+img+" \n";   //例如 100代表图片宽度 60代表坐标x=60,  80代表坐标 y=80, 后面是本地图片路径
   str+="PRINT \n";

   datas.push(str);

   str="! 0 200 200 320 1 \n";
   str+="TEXT \"0\" 0 30 40 这是多张打印示例第二张 \n";
   str+="EG 100 60 80 "+img+" \n";   //例如 100代表图片宽度 60代表坐标x=60,  80代表坐标 y=80, 后面是本地图片路径
   str+="PRINT \n";

   datas.push(str);

   plug.writeCPCL({"cpclList":datas},function(e){

   console.log(JSON.stringify(e));
   _this.tip=JSON.stringify(e);

   });

7、获取已配对的蓝牙设备

 plug.pairedDevices(function(e){
    console.log(JSON.stringify(e));
    if(e.code=="0")
    {
        _this.data=e.list;
    }else
    {
      uni.showToast({title:"未有配对的设备",icon:"none"});
    }

 });
  • 返回一个数组
{"list":[{"address":"88:2D:53:26:DC:08","deviceName":"xiaodu-A1-4867"}],"code":0}

{"msg":"未有已配对的设备","code":1}

8、自定义 搜索蓝牙设备

        //搜索蓝牙设备
        plug.searchDevices(function(e){ 
            console.log(JSON.stringify(e));
            if(e.code=="0")
            {
                _this.data=e.list;
            }else
            {
              uni.showToast({title:e.msg,icon:"none"});
            }

        });
  • 返回一个数组
    {
    "list":
    [
    {"address":"88:2D:53:26:DC:08","deviceName":"xiaodu-A1-4867"},
    {"address":"54:19:C8:DF:55:82","deviceName":"vivo X9"}
    ],
    "msg":"搜索中",
    "code":"0"
    }

{"msg":"搜索结束","code":"2"}

9、取消搜索

//取消搜索
plug.cancelSearch();

10、打印小票

plug.printer({"ESC":data,"openbox":0,isArray:false},result=>{

    result //返回值    

 });
  • openbox => 是否开启钱箱,0. 不开启,1. 打印前开启,2. 打印后开启
  • isArray => 提交的打印数组是否是多个小票的数组,false 不是,单一张打印,true 是多张数组一起批量打印。

参数是一个 数组包含JSON 格式的 小票打印数据,

6. 小票制作格式说明

首先,先定义一个数组, var data=[]; //定义一个数组, 数组主要为了装每一行的内容 var line={}; //定义一个JSON,用来生成每一行的内容

一共包含 单行文字,单行文字并排,图片,条型号,二维码 这几行打印。

例如:要创建一行文字

    //制作小票格式, 
    var data=[];  //定义一个数组
    var line={};  //每添加一个,代表一行字

    1.要创建一行文字
    line.text="万达广场销售单";  // 内容
    line.center="center";  // 文字居中方式:center=> 居中,left=> 靠左 ,right=> 靠右
    line.font="max"; //文属性:max=> 特大加粗字, normal=> 默认普通字 ,bold=> 普通加粗字,underline=> 带下巴线的字,underline|bold=>带下巴线且加粗字
    line.bottom="2"; //底部行距离
    line.reversemode=1; // 是否反白 1 或 0
    line.rightspacing=10; //设置字符右间距
    line.zoom="2"; //字体放大等级 1~7。
    line.rotatin=1; // 文字90度旋转,0=>不变,1=> 90度旋转
    data.push(line); //每添加一个,代表一行字

    line={};
    line.text="简单的文字,这样就可以";
    line.center="left";
    line.font="normal";
    line.bottom="1";
    data.push(line);
    line={}; //添加新行时,清空一下

    2. 创建一个并排的文字表格式

    line={};
    line.title=["数量:1", "单价:305", "金额:305"];  // 并排一起
    line.left=[0, 30, 60]; // 第一个是0不用改,第二参考对应上面第二参数,距离第一个参数的距离
    line.center="left";  // 文字居中方式:center=> 居中,left=> 靠左 ,right=> 靠右
    line.font="normal"; //文属性:max=> 特大加粗字, normal=> 默认普通字 ,bold=> 普通加粗字,underline=> 带下巴线的字,underline|bold=>带下巴线且加粗字
    line.bottom="2"; //底部行距离
    data.push(line); //每添加一个,代表一行字

    3. 如果需要靠左显示,又 靠右边显示这样设置

    line={};
    line.title=["现金找零","4.90"];
    line.font="normal";
    line.pageWidth="--------------------------------";
    line.bottom="1";
    data.push(line);

    pageWidth参数是用来横量小票纸宽度

    4. 创建一个图片行

    //加入图片
    line={};
    line.image="http://www.html5-app.com/gprinter.png"; //支持本地图片和 网络图片地址,PNG 格式黑白Logo图片
    line.width="350"; //图片宽度,高度默认随宽度变化
    line.center="center"; 
    line.bottom="2";
    data.push(line);

    5.创建一个条型码

    //加入条型码
    line={};
    line.barcode="2019563352660"; // 数据编号
    line.type="CODE128"; //条型码类型:CODE128,CODE93,CODE39,UPCA,UPCE,EAN13,EAN8,ITF
    line.height="100"; // 条型码高度
    line.position="BELOW"; //条型号编号是否显示: BELOW => 显示在条型码下方,ABOVE=> 显示在条型码上方,NO_PRINT=> 不显示
    line.width="2"; //条型宽度,这里的宽指的是 条型码 竖条的宽度,不是整个条型码的宽度
    line.center="center";
    line.bottom="2";
    data.push(line);

    6. 创建二维码
    line={};
    line.qrcode="www.html5-app.com"; //内容
    line.size="10"; //二维码大小
    line.center="center";
    line.bottom="0";
    data.push(line);

5、打印标签

plug.printer({"TSC":data},result=>{

    result //返回值    

 });

多标签打印

  把每一个 data 标签数组,再放进一个大的数据组中。

6. 标签纸制作格式说明

TSC 指令代表标签打印, ESC 指令代表 小票打印

1.打印标签格式, 首先,先确定使用的标签纸规格,是多大的。

//制作标签格式, var data=[]; //定义一个数组 var line={}; //每添加一个,代表一个元素

2.设置标签纸大小 ,必填写

//设置标签纸大小, 80mmx55mm 纸大小
line={};
line.width=80; //单位mm 
line.height=55; //单位mm
line.gap=3; //标签纸之间,间隙长度 mm 
//line.bline=0; //如果是黒标,设置这个,line.bline=0;line.gap=-1; 如果是间隔标签需要去掉
line.page=1; //打印几份
line.direction=0; , //上下反面打印,0=>正方向,1=> 反方向
line.x=0; //初始坐标 左距离 x 值
line.y=0; //初始坐标 顶部距离 y 值
data.push(line); //这个配置只需添加一个即可。

3. 添加文字

line={};
line.text="HTML5+混合APP开发社区";
line.rotation=0; // 角度:有四个值:0,90,180,270
line.x=150; //横坐标,用于定位
line.y=20; //纵坐标, 用于定位
line.xscal=1; //横向加大,用于加大字体 :取值:1-10.
line.yscal=1; //纵向加大, 用于加大字体:取值:1-10.
data.push(line); //每添加一个,代表一元素

4.添加图片

line={};
line.image="http://www.html5-app.com/gprinter.png";
line.x=20;  //横坐标
line.y=20; //纵坐标
line.width=120; // 图片大小
data.push(line);

5.添加条型码

line={};
line.barcode="2019563352660";
line.x=20; //横坐标
line.y=140; //纵坐标
line.type="CODE128"; //条型码类型
line.height=100; //条型码高度
line.width=2; 
line.readable=true; //是否显示文字在条型下方
line.rotation=0;  // 角度:有四个值:0,90,180,270
data.push(line);

 6.加入二维码

line={};
line.qrcode="www.html5-app.com";
line.x=320; //横坐标
line.y=140; //纵坐标
line.width=6; //二维码大小
line.rotation=0;  // 角度:有四个值:0,90,180,270 
data.push(line);

7.添加黑块

line={}; line.addBar={x:2,y:2,width:200,height:4}; //x 左距离,y 顶部距离,width 宽度,height 高度 data.push(line);

8.添加方框

line={}; line.addBox={x:10,y:15,xend:140,xend:50,thickness:2}; //x 左坐标,y 顶坐标,xend 结束x坐标,xend 结束y坐标, thickness 矩形线的厚度 data.push(line);

这里的布局采用的是绝对定位, 从左上角0,0 开始计算,通过坐标把文字或图片或条型码二维码,放到相应的位置上。

图片

扫一扫下载安卓DEMO 示例 体验

uniapp 原生插件如何使用,可以参考这个:https://ask.dcloud.net.cn/article/36106

详细使用参考示例demo ,可以在本页面右上角=》 HBuilderX 导入示例项目

隐私、权限声明

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

蓝牙

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

无,不涉及收集用户的任何数据。

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

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