标签:NPU tca 软件 android 管理类 和我 eve height nullable
公司的设备以前接入的都是串口的扫码头,优点是直接通过串口读取流里面的数据就OK了,缺点是你需要知道每一款扫码器的型号以获取波特率及Android设备的串口地址。因为现在usb扫码器越来越方便且即插即用,不需要额外供电以及价格便宜等特点,公司以后开发的设备都打算采用usb扫码器。所以我开始尝试接入usb扫码器,下面就是我在接入时的方法以及遇到的一些问题。
dispatchKeyEvent(KeyEvent event)
,它就是用来处理我们键盘的输入事件的,如果我们拦截该方法,把它交给我们自己去处理,这样我们就可以不通过Edittext从而获取到扫码头传过来的数据了。import android.view.KeyEvent;
public class ScanKeyManager {
private StringBuilder mResult;
public OnScanValueListener mListener;
private boolean mCaps;
public interface OnScanValueListener {
void onScanValue(String value);
}
public ScanKeyManager(OnScanValueListener listener) {
this.mListener = listener;
this.mResult = new StringBuilder();
}
/**
* 扫码设备事件解析
*/
public void analysisKeyEvent(KeyEvent event) {
int keyCode = event.getKeyCode();
checkLetterStatus(event);
if (event.getAction() == KeyEvent.ACTION_DOWN) {
char aChar = getInputCode(mCaps, event.getKeyCode());
if (aChar != 0) {
mResult.append(aChar);
}
if (keyCode == KeyEvent.KEYCODE_ENTER) {
if (mListener != null) {
mListener.onScanValue(mResult.toString());
}
mResult.delete(0, mResult.length());
}
}
}
/**
* 判断大小写
*/
private void checkLetterStatus(KeyEvent event) {
int keyCode = event.getKeyCode();
if (keyCode == KeyEvent.KEYCODE_SHIFT_RIGHT || keyCode == KeyEvent.KEYCODE_SHIFT_LEFT) {
mCaps = event.getAction() == KeyEvent.ACTION_DOWN;
}
}
/**
* 将keyCode转为char
*
* @param caps 是不是大写
* @param keyCode 按键
* @return 按键对应的char
*/
private char getInputCode(boolean caps, int keyCode) {
if (keyCode >= KeyEvent.KEYCODE_A && keyCode <= KeyEvent.KEYCODE_Z) {
return (char) ((caps ? ‘A‘ : ‘a‘) + keyCode - KeyEvent.KEYCODE_A);
} else {
return keyValue(caps, keyCode);
}
}
/**
* 按键对应的char表
*/
private char keyValue(boolean caps, int keyCode) {
switch (keyCode) {
case KeyEvent.KEYCODE_0:
return caps ? ‘)‘ : ‘0‘;
case KeyEvent.KEYCODE_1:
return caps