Android下的POS打印机调用的简单实现
本文基于GP58系列,它可以兼容ESC/POS指令集,对EPSON的打印机通用.
Android下的设备调试,如果设备提供了驱动,按照厂家的驱动调试即可;设备未提供驱动,只能按照通用的方法进行调试。这里采用的是调用USB接口来控制打印机输出。
1.首先获取USB管理器
publicUsbAdmin(Contextcontext){
mUsbManager=(UsbManager)context.getSystemService(Context.USB_SERVICE);
mPermissionIntent=PendingIntent.getBroadcast(context,0,newIntent(ACTION_USB_PERMISSION),0);
IntentFilterfilter=newIntentFilter(ACTION_USB_PERMISSION);
context.registerReceiver(mUsbReceiver,filter);
}
使用一个延迟意图来接收usb接入时的广播,当广播接收到时,说明有新的设备接入。
添加一个boardcastaction
privatestaticfinalStringACTION_USB_PERMISSION="com.android.example.USB_PERMISSION";
privatefinalBroadcastReceivermUsbReceiver=newBroadcastReceiver(){
publicvoidonReceive(Contextcontext,Intentintent){
Stringaction=intent.getAction();
if(ACTION_USB_PERMISSION.equals(action)){
synchronized(this){
UsbDevicedevice=(UsbDevice)intent.getParcelableExtra(UsbManager.EXTRA_DEVICE);
if(intent.getBooleanExtra(UsbManager.EXTRA_PERMISSION_GRANTED,false)){
if(device!=null){
setDevice(device);
}else{
Closeusb();
//mDevice=device;
}
}else{
Log.d(TAG,"permissiondeniedfordevice"+device);
}
}
}
}
};
取到usb设备的引用,android系统会询问你是否允许设备访问,默认为false;当允许了访问之后,会判断USB的引用是否为null,如果不为空则会调用setDevice来创建一个Connection,否则会关闭本次连接。
在setDevice中,我们可以获取设备的功能集(UsbInterface),也可以获取通信通道(UsbEndpoint),同时也创建了host与device的连接用来传输数据。
privatevoidsetDevice(UsbDevicedevice){
if(device!=null){
UsbInterfaceintf=null;
UsbEndpointep=null;
intInterfaceCount=device.getInterfaceCount();
intj;
mDevice=device;
for(j=0;j
2.在相关的类中新建一个UsbAdmin,调用openUsb,这里首先是走了上面的setDevice()方法,获取到了设备的引用,当连接通道建立时列出所有USB设备,当设备的引用不存在时同样列出所有的USB设备,并且都请求获取USB权限。
publicvoidopenUsb(){
if(mDevice!=null){
setDevice(mDevice);
if(mConnection==null){
HashMapdeviceList=mUsbManager.getDeviceList();
IteratordeviceIterator=deviceList.values().iterator();
while(deviceIterator.hasNext()){
UsbDevicedevice=deviceIterator.next();
mUsbManager.requestPermission(device,mPermissionIntent);
}
}
}else{
HashMapdeviceList=mUsbManager.getDeviceList();
IteratordeviceIterator=deviceList.values().iterator();
while(deviceIterator.hasNext()){
UsbDevicedevice=deviceIterator.next();
mUsbManager.requestPermission(device,mPermissionIntent);
}
}
}
3.当上面两部都走完了之后,我们就可以发送指令来控制已经建立连接的打印机了,这里我们使用的是标准的ESC/POS指令集,为硬件默认,贴出代码,这里的指令集采用的是十进制表示形式,也可以替换成十六进制。
publicclassprinterCmdUtils{
/**
*这些数据源自爱普生指令集,为POS机硬件默认
*/
publicstaticfinalbyteESC=27;//换码
publicstaticfinalbyteFS=28;//文本分隔符
publicstaticfinalbyteGS=29;//组分隔符
publicstaticfinalbyteDLE=16;//数据连接换码
publicstaticfinalbyteEOT=4;//传输结束
publicstaticfinalbyteENQ=5;//询问字符
publicstaticfinalbyteSP=32;//空格
publicstaticfinalbyteHT=9;//横向列表
publicstaticfinalbyteLF=10;//打印并换行(水平定位)
publicstaticfinalbyteCR=13;//归位键
publicstaticfinalbyteFF=12;//走纸控制(打印并回到标准模式(在页模式下))
publicstaticfinalbyteCAN=24;//作废(页模式下取消打印数据)
//------------------------打印机初始化-----------------------------
/**
*打印机初始化
*@return
*/
publicstaticbyte[]init_printer()
{
byte[]result=newbyte[2];
result[0]=ESC;
result[1]=64;
returnresult;
}
//------------------------换行-----------------------------
/**
*换行
*@paramlineNum要换几行
*@return
*/
publicstaticbyte[]nextLine(intlineNum)
{
byte[]result=newbyte[lineNum];
for(inti=0;i
4.在以上都完成之后,就可以把你需要的字符串转换成byte数组并调用sendCommand方法来进行打印了
@SuppressLint("NewApi")
publicbooleansendCommand(byte[]Content){
booleanResult;
synchronized(this){
intlen=-1;
if(mConnection!=null){
len=mConnection.bulkTransfer(mEndpointIntr,Content,Content.length,10000);
}
if(len<0){
Result=false;
Log.i(TAG,"发送失败!"+len);
}else{
Result=true;
Log.i(TAG,"发送"+len+"字节数据");
}
}
returnResult;
len=mConnection.bulkTransfer(mEndpointIntr,Content,Content.length,10000);
这一步仅仅加了同步锁,并未开启一个新的线程去处理,在本机上没有问题,但上面的USB通信机制的文章有提到要放到异步线程,这里需要注意。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。