Gprinter Android SDK V1.0 使用说明

Gprinter Android SDK旨在佳博用户更快速,更高效的在Android平台下开发和使用佳博打印机。如果您在使用SDK中碰到问题,或者发现BUG,请随时联系我,发送邮箱到[email protected]

一、下载GprinterSDK 

GprinterSDK可在佳博打印机官网下载http://www.gainscha.cn/cn/download.aspx?current=down或点击GprinterSDK,即可下载。

一、将gprinter.jar导入到工程

在eclipse中,将gprinter.jar拷贝到工程的libs文件夹下,。

二、建立与打印机的通信

1、 获取设备的对象

GpDevice mDevice = new GpDevice();

2、注册接收数据回调函数(此接口是用来接收数据的)

mDevice.registerCallback(this);

3、打开蓝牙、USB、网口

蓝牙通信

a、需要获取蓝牙操作权限,在AndroidManifest.xml中,加入以下代码

<uses-permission android:name="android.permission.BLUETOOTH_ADMIN" />
<uses-permission android:name="android.permission.BLUETOOTH" />  

b、调用蓝牙打开API

mDevice.openBluetoothPort(Context context,String addr)

context 为上下文,addr 为蓝牙地址。例如蓝牙地址为"98:D3:31:40:27:D7",则调用

mDevice.openBluetoothPort(MainActivity.this,"98:D3:31:40:27:D7");

USB通信

a、需要获取USB操作权限,在AndroidManifest.xml中,加入以下代码

<uses-feature android:name="android.hardware.usb.host" />

b、注册USB设备插入和拔出广播,在AndroidManifest.xml中,加入以下代码

 <intent-filter>
     <action android:name="android.hardware.usb.action.USB_DEVICE_ATTACHED" />
 </intent-filter>
 <intent-filter>
      <action android:name="android.hardware.usb.action.USB_DEVICE_DETACHED" />
 </intent-filter>
 <meta-data
      android:name="android.hardware.usb.action.USB_DEVICE_ATTACHED"
      android:resource="@xml/device_filter" />
 <meta-data
      android:name="android.hardware.usb.action.USB_DEVICE_DETACHED"
      android:resource="@xml/device_filter" />    

c、device_filter.xml为USB设备过滤文件,里面存储USB设备的PID和VID号,只有匹配的设备USB插入,才能产生USB插入或拔出广播,device_filter.xml需放在res/xml 文件夹下,文件格式如下,例如Gp2120TL标签打印机VID 为26728 PID为1280

<?xml version="1.0" encoding="utf-8"?><resources>   
    <usb-device vendor-id="26728" product-id="1280" />
</resources>

d、旧版的Android SDK中是不支持USBhost的,最小SDK版本为 12,所以需加入

android:minSdkVersion="12"

e、调用USB端口打开API

mDevice.openBluetoothPort(MainActivity.this);

网口通信

a、需要获取网络操作权限,在AndroidManifest.xml中,加入以下代码

<uses-permission android:name="android.permission.INTERNET" />

b、调用网口API

例如佳博网络打印机的初始IP为192.168.123.100  打印端口为9100

mDevice.openEthernetPort(“192.168.123.100”, 9100)

4、关闭蓝牙、USB、网口

调用关闭端口API

mDevice.closePort();

5、发送数据

立即发送数据API

mDevice.sendDataImmediately(Vector<Byte> data)

将发送数据放在发送缓冲区

mDevice.sendData(Vector<Byte> data)

三、TSC和ESC命令编辑

佳博打印机兼容两种行业命令标准,5890XIII、58130IVC等票据打印机兼容ESC/POS指令集;

2120T、2120TL等系列标签打印机兼容TSC指令集;

2120TF则是同时兼容ESC和TSC,模式切换需拨动拨位开关

1、TSC命令调用模板如下,Gprinter SDK中的JavaDoc文件中有TSCCommand API的调用说明

TscCommand tsc = new TscCommand(60,30,0);//设置标签尺寸宽度、高度、间隙
tsc.addReference(0, 0); //设置原点坐标
tsc.addSpeed(SPEED.SPEED1DIV5);//设置打印速度
tsc.addDensity(DENSITY.DNESITY0);//设置打印浓度
tsc.addDirection(DIRECTION.BACKWARD);//设置打印方向
tsc.addCls();//清除打印缓冲区
tsc.addSound(2, 100);
tsc.addText(20,20,FONTTYPE.FONT_TAIWAN,ROTATION.ROTATON_0,FONTMUL.MUL_1,FONTMUL.MUL_1,"Hello Gprinter");//绘制文字
tsc.add1DBarcode(20, 50, BARCODETYPE.CODE128, 100, READABEL.EANBEL, ROTATION.ROTATION_180, "12345");//绘制一维条码
tsc.addPrint(1,1);//加入打印标签命令
Vector<Byte> Command = new Vector<Byte>(4096, 1024);
Command = tsc.getCommand();//获取上面编辑的打印命令
mDevice.sendDataImmediately(Command);  //发送命令     

2、ESC命令调用模板如下,Gprinter SDK中的JavaDoc文件中有ESCCommand API的调用说明

EscCommand esc = new EscCommand();
esc.addTurnEmphasizedModeOnOrOff(EscCommand.ENABLE.ON);//加粗模式有效 esc.addText("Hello World\n");//打印文字 esc.addUPCA("123456789012");//打印UPCA条码 esc.addCODE128("Gprinter");//打印CODE128条码 Vector<Byte> Command = new Vector<Byte>(4096, 1024); Command = esc.getCommand();//获得编辑的命令数据 mDevice.sendDataImmediately(Command);// 发送命令

 在Eclipse下建立好Android工程后调用Gprinter.jar文件,只需按上述步骤操作,您就可以自由编辑您想要的标签了

 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。