更新记录

1.0.2(2021-06-10)

发布插件


平台兼容性

Android Android CPU类型 iOS
适用版本区间:4.4 - 11.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原生插件配置”->”云端插件“列表中删除该插件重新选择


Uniapp示例代码

<template>
    <view>
        <view>
            <button @click="getversion()">getversion</button>
            <button @click="printText()">printText</button>
        </view>
        <text v-for="(item,index) in msglist">{{item}}\n</text>
    </view>
</template>
<script>
    const icodzz = uni.requireNativePlugin('zzzili-icodzz');
    export default {
        data() {
            return {
                msglist: []
            }
        },
        onLoad() {
            this.msglist.push('start test print')
        },
        methods: {
            getversion: function() {
                this.msglist.push(icodzz.getVersion());             
            },
            printText: function() {
                this.msglist.push(icodzz.initSDK());
                this.msglist.push('connectUSB'+icodzz.connectUSB());
                this.msglist.push('init'+icodzz.init());
                this.msglist.push('setEmphasizedMode'+icodzz.setEmphasizedMode(1));
                this.msglist.push('printString'+icodzz.printString("深圳研科\n深圳研科\n深圳研科\n深圳研科\n", 'gbk', true));               
                this.msglist.push('printQRCode'+icodzz.printQRCode("testqrcode", 200,false));           
                this.msglist.push('printFeed'+icodzz.printAndFeedLine(5));

            },
        }
    }
</script>
<style>
</style>

icod SDK 使用指南(来自于官方icod sdk文档)

一、添加权限:

    <uses-feature android:name="android.hardware.usb.host" />
    <!-- Allows applications to access information about networks -->
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <!-- Allows applications to change network connectivity state -->
    <uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" />
    <!-- Allows applications to enter Wi-Fi Multicast mode -->
    <uses-permission android:name="android.permission.WAKE_LOCK" />
    <!-- Internet permission -->
    <uses-permission android:name="android.permission.INTERNET" >
    </uses-permission>
    <!-- SDCard permission -->
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS" />
    <!-- Bluetooth permission -->
    <uses-permission android:name="android.permission.BLUETOOTH" />
    <uses-permission android:name="android.permission.BLUETOOTH_ADMIN" />

二、引用插件

const icodzz = uni.requireNativePlugin('zzzili-icodzz');

三、简单的初始化

icodzz.getVersion()//获取sdk版本
icodzz.initSDK()//初始化SDK

四、返回值声明

 0: 为成功
-1: 为失败 
-2: 参数错误 
-3: 为字符长度不支持
-4: 字符不支持(后面两个是用于条码打印的)

五、函数调用

1、连接打印机
   链接USB打印机:connectUSB();
   链接Bluetooth打印机:connectBluetooth();
   链接串口打印机:connectSerial(String filePathname, int baudRate, int flowControl);//device:串 baudRate:波特率 flowControl:是否开流控
   连接wifi打印机:connectWifi(String site, int port);//Site:ip地址 Port:端口号
   连接USBNative打印机:connectUSBNative();

2、关闭连接和释放资源
函数:disconnect()
参数: 无

3、写入指令 发送自定义指令
函数:sendOrder(byte[] cmd)
参数:     cmd - 指令数组

函数:sendOrder(byte[] cmd,int timeOut)
参数:     cmd - 指令数组
timeOut - 超时时间 单位ms

4、写入指令
函数:writeIO(byte[] writeBuffer,int offsetSize,int writeSize,int waitTime)
参数: writeBuffer - 指令字节数组
offsetSize - 偏移量,一般为0
writeSize - 数组大小
waitTime - 等待时间

5、读取指令
函数:readIO(byte[] readBuffer,int offsetSize,int readSize,int waitTime)
参数: readBuffer - 指令字节数组
offsetSize - 偏移量
readSize - 读取大小
waitTime - 等待时间

6、初始化
函数:init()
参数: 无
说明:这个指令 用于清空缓冲区和恢复默认值 一般在打印图片前或者后调用,避免打不全对后面数据的影响 可以跟 initAllPrinter方法一起用

7、完全初始化
函数:initAllPrinter(int n)
参数: n - 1.错误恢复从错误行开始打印 2.错误恢复和清除缓冲内容 

8、设置日志输出文件标志
函数:setOutput(boolean output)
参数: output - true.开启日志输出

9、实时状态传送
函数:getStatus()
参数: 无

10、打印字符串
函数:printString(String text)
参数: text?- 打印的字符串

函数:printString(String text,String charsetName,boolean isFeed)
参数: text?- 打印的字符串
charsetName - 字符集
isFeed - 是否 换行

11、打印光栅位图
函数:printRasterBitmap(Bitmap bitmap)
参数: bitmap- 位图

函数:printRasterBitmap(Bitmap bitmap, boolean toGray)
参数: bitmap- 位图
toGray - true 变灰

函数:printRasterBitmap(Bitmap bitmap,boolean toGray,int timeOut)
参数: bitmap- 位图
toGray - true 变灰    
timeOut - 超时时间

函数:printRasterBitmap(Bitmap bitmap,boolean toGray,int timeOut, boolean check)
参数: bitmap- 位图
toGray - true 变灰    
timeOut - 超时时间 
check - 是否需要检测 数据是否已经全部下发到打印机.解决第一张打印正常第二张乱码的问题.

函数:printRasterBitmap(Bitmap bitmap,boolean toGray,int timeOut,boolean isJini,boolean check)
参数: bitmap- 位图
toGray - true 变灰    
timeOut - 超时时间
isJini - 是否使用本地方法
check - 是否需要检测 数据是否已经全部下发到打印机.解决第一张打印正常第二张乱码的问题.

12、打印二维码
函数:printQRCode(String text,int modeSize,boolean isCut)
参数: text - 为二维码内容
modeSize - 设置条码大小(1FAIL6) 默认为6
isCut - 打印二维码后是否切纸

13、PDF条码打印
函数:printPDFCode(String text,int errorSize,int hSize,int vSize)
参数: text - 为PDF条码内容
errorSize - 纠错等级,可控制条码大小建议4-8
hSize - 宽度 0-30(建议0)
vSize - 高度 3-90(建议0)

14、打印并换行
函数:printFeed()
参数: 无

15、打印并退纸
函数:printBackFlow(int n)
参数: n - 退纸 n/144英寸

16、页模式下回标准模式
函数:printAndBackToStd()
参数: 无

17、实时打印机请求
函数:printerRequestsRealTime(int type)
参数: type - 1.从错误恢复并从错误出现的行开始重新开始打印
2.在清除接收和打印缓冲区后从错误恢复

18、选择打印模式
函数:setFontStyle(int type)
参数: type - 取值如下[0-255]
|位  |关/开|十六进制码|十进制码|功能|
|----|-----|---------|--------|----|
|0  |关    |00       |0       |字符字型A (12 × 24)。|
|0  |开    |01       |1       |字符字型B (9 × 17)。|
|1  |-     |    -       |-       |未定义|
|2  |-     |    -       |-       |未定义|
|3  |关    |00       |0       |解除加重模式|
|3  |开    |08       |8       |设置加重模式|
|4  |关    |00       |0       |解除倍高模式|
|4  |开    |10       |16      |设置倍高模式|
|5  |关    |00       |0       |解除倍宽模式|
|5  |开    |20       |32      |设置倍宽模式|
|6  |-     |-       |-       |未定义|
|7  |关    |00       |0       |解除下划线模式|
|7  |开    |80       |128     |设置下划线模式|

19、设置字符右间距
函数:setCharRightSpace (int n)
参数: n - n*0.125毫米 

20、设定 / 解除下划线
函数:setEnableUnderLine (int enable)
参数: enable -最低位有效:1为设定 0位解除

21、设置行间距
函数:setLineSpace (int n)
参数: n - n*0.125毫米 缺省值为30

22、设定/解除粗体打印
函数:setEmphasizedMode (int n)
参数: n -最低位有效:1为设定 0位解除

23、设置浓度
函数:setPrintColorSize (int n)
参数: n -仅支持1-4浓度 一般字体加重的浓度

24、设定/解除重叠打印
函数:setOverlapMode (int n)
参数: n -最低位有效:1为设定 0位解除

25、打印并进纸
函数:printAndFeedPaper (int n)
参数: n - n*0.125毫米

26、选择国际字符集
函数:setInterCharSet (int n)
参数: n –[0-13],默认为0
n   字符集
0   美国
1   法国
2   德国
3   英国
4   丹麦Ⅰ
5   瑞典
6   意大利
7   西班牙Ⅰ
8   日本
9   挪威
10  丹麦Ⅱ
11  西班牙Ⅱ
12  拉丁美洲
13  韩国

27、设置相对当前打印位置(nl+nh*256)*0.125
函数:setRelativePosition(int?nl, int?nh)
参数: nl - 0-255
nh - 0-255

28、在页模式,设置相对当前打印位置(nl+nh*256)*0.125
函数:setPageRelativePosition (int?nl, int?nh)
参数: nl - 0-255
nh - 0-255

29、全切
函数:fullCut ()
参数: 无

30、半切
函数:halfCut ()
参数: 无

31、选择对齐方式
函数:setAlignMode (int?type)
参数: type - 0为左对齐 ,1 为居中对齐,2 为右对齐

32、激活/禁止面板按键
函数:setEnablePanelButton (int?n)
参数: n -最低位有效:1禁止 0位激活

33、打印并进纸 n 行
函数:printAndFeedLine (int?n)
参数: n - n *设定的行间距

34、选择字符代码表
函数:setCharCodeTable (int?n)
参数: n – [0-5]、[16-19]、255
n   页
0   PC437[美国欧洲标准]
1   片假名
2   PC850[多语言]
3   PC860[葡萄牙语]
4   PC863[加拿大-法语]
5   PC865[北欧]
16  WPC1252
17  PC866[斯拉夫语 2]
18  PC852[拉丁语 2]
19  PC858[欧洲]
255 Space Page

35、将标记打印纸进纸到打印起始位置
函数:feedToStartPos ()
参数: 无

36、执行测试打印
函数:doTestPrint (int n, int m)
参数: n - 0 为 basic sheet; 1 2 为卷纸
m - 1 让打印机进入十六进制;2 打印机状态打印;3 卷纸模式打印

37、设定左侧空白量(nl +nh*256)*0.125毫米
函数:setLeftMargin (int nL, int nH)
参数: nL - 0-255
nH - 0-255

38、选择裁纸模式并裁纸
函数:cutPaper (int m, int n)
参数: m – 66 (保留一点不切)
n - 0

39、设置打印区域宽度
函数:setPrnAreaWidth (int nL, int nH)
参数: 宽度为 (nl +nh*256)*0.125毫米
82.5毫米纸宽型号 缺省值 nl=128,nh=2
79.5毫米纸宽型号 缺省值 nl=64,nh=2
60毫米纸宽型号缺省值 nl=192,nh=1
58毫米纸宽型号 缺省值 nl=176,nh=1

40、设置/解除平滑模式
函数:setEnableSmoothPrn ( int n)
参数: n – 最低位有效:1为设定 0位解除 

41、设置条形码高度
函数:setBarCodeHeight ( int n)
参数: n – [0-255],默认为162

42、设置条形码宽度
函数:setBarCodeWidth ( int n)
参数: n – [2-16] 我方打印机范围为2-6 通用的打印机 2-16 所以有些值不管用

43、打印条形码
函数:printBarCode (int m, int n, String barcode)
参数: m –使用条码系统类型
n –使用条码系统类型
barcode–字符串

44、设置颠倒
函数:setReverse(boolean reverse)
参数: reverse - true 设置颠倒 false 取消颠倒

45、设置 / 解除顺时针 90 ° 旋转
函数:setRotate(int n)
参数: n - 0,48 解除 1,49设置

46、发送十六进制的字符串
函数:hexMsg (String msg, boolean isHex)
参数: msg - 格式是##0a 23 0d##
isHex - true 数据是十六进制 false 是十进制

隐私、权限声明

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

<uses-feature android:name="android.hardware.usb.host" /> <!-- Allows applications to access information about networks --> <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> <!-- Allows applications to change network connectivity state --> <uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" /> <!-- Allows applications to enter Wi-Fi Multicast mode --> <uses-permission android:name="android.permission.WAKE_LOCK" /> <!-- Internet permission --> <uses-permission android:name="android.permission.INTERNET" > </uses-permission> <!-- SDCard permission --> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> <uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS" /> <!-- Bluetooth permission --> <uses-permission android:name="android.permission.BLUETOOTH" /> <uses-permission android:name="android.permission.BLUETOOTH_ADMIN" />

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

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

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