Commit 5de220cb by pye52

Merge branch 'develop' into test

parents dad41b72 3a5092d1
...@@ -15,3 +15,5 @@ ...@@ -15,3 +15,5 @@
/captures /captures
.externalNativeBuild .externalNativeBuild
.idea/codeStyles/Project.xml .idea/codeStyles/Project.xml
/.idea
/gradle
<component name="ProjectCodeStyleConfiguration">
<state>
<option name="USE_PER_PROJECT_SETTINGS" value="true" />
</state>
</component>
\ No newline at end of file
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="GradleSettings">
<option name="linkedExternalProjectsSettings">
<GradleProjectSettings>
<option name="testRunner" value="PLATFORM" />
<option name="distributionType" value="DEFAULT_WRAPPED" />
<option name="externalProjectPath" value="$PROJECT_DIR$" />
<option name="modules">
<set>
<option value="$PROJECT_DIR$" />
<option value="$PROJECT_DIR$/app" />
</set>
</option>
<option name="resolveModulePerSourceSet" value="false" />
</GradleProjectSettings>
</option>
</component>
</project>
\ No newline at end of file
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="VcsDirectoryMappings">
<mapping directory="" vcs="Git" />
</component>
</project>
\ No newline at end of file
No preview for this file type
package android_serialport_api;
import java.io.File;
import java.io.FileDescriptor;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.OutputStream;
/**
* Google官方代码
* 此类的作用为,JNI的调用,用来加载.so文件的
* 获取串口输入输出流
*/
public class SerialPort {
private FileDescriptor mFd;
private FileInputStream mFileInputStream;
private FileOutputStream mFileOutputStream;
static {
System.loadLibrary("serial_port");
}
public SerialPort(String devicePath, int baudRate, int flags) throws SecurityException {
this(new File(devicePath), baudRate, flags);
}
private SerialPort(File device, int baudRate, int flags) throws SecurityException {
if (!device.canRead() || !device.canWrite()) {
try {
Process su = Runtime.getRuntime().exec("/system/bin/su");
String cmd = "chmod 666 " + device.getAbsolutePath() + "\n" + "exit\n";
su.getOutputStream().write(cmd.getBytes());
if ((su.waitFor() != 0) || !device.canRead() || !device.canWrite()) {
throw new RuntimeException("没有串口权限");
}
} catch (Exception e) {
throw new RuntimeException("提权失败" + e.getMessage(), e);
}
}
mFd = open(device.getAbsolutePath(), baudRate, flags);
mFileInputStream = new FileInputStream(mFd);
mFileOutputStream = new FileOutputStream(mFd);
}
public InputStream getInputStream() {
return mFileInputStream;
}
public OutputStream getOutputStream() {
return mFileOutputStream;
}
private native static FileDescriptor open(String path, int baudrate, int flags);
public native void close();
}
package android_serialport_api;
import android.util.Log;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;
import java.io.LineNumberReader;
import java.util.Iterator;
import java.util.Vector;
/**
* Google官方代码
* 此类的作用为,寻找得到有效的串口的物理地址。
* 如果你本身就知道串口的地址如:ttyS1、ttyS2,那么这个类就可以不用了。
*
*/
public class SerialPortFinder {
public class Driver {
public Driver(String name, String root) {
mDriverName = name;
mDeviceRoot = root;
}
private String mDriverName;
private String mDeviceRoot;
Vector<File> mDevices = null;
public Vector<File> getDevices() {
if (mDevices == null) {
mDevices = new Vector<>();
File dev = new File("/dev");
File[] files = dev.listFiles();
int i;
for (i=0; i<files.length; i++) {
if (files[i].getAbsolutePath().startsWith(mDeviceRoot)) {
Log.d(TAG, "Found new device: " + files[i]);
mDevices.add(files[i]);
}
}
}
return mDevices;
}
public String getName() {
return mDriverName;
}
}
private static final String TAG = "SerialPort";
private Vector<Driver> mDrivers = null;
Vector<Driver> getDrivers() throws IOException {
if (mDrivers == null) {
mDrivers = new Vector<>();
LineNumberReader r = new LineNumberReader(new FileReader("/proc/tty/drivers"));
String l;
while((l = r.readLine()) != null) {
// Issue 3:
// Since driver name may contain spaces, we do not extract driver name with split()
String drivername = l.substring(0, 0x15).trim();
String[] w = l.split(" +");
if ((w.length >= 5) && (w[w.length-1].equals("serial"))) {
Log.d(TAG, "Found new driver " + drivername + " on " + w[w.length-4]);
mDrivers.add(new Driver(drivername, w[w.length-4]));
}
}
r.close();
}
return mDrivers;
}
public String[] getAllDevices() {
Vector<String> devices = new Vector<String>();
// Parse each driver
Iterator<Driver> itdriv;
try {
itdriv = getDrivers().iterator();
while(itdriv.hasNext()) {
Driver driver = itdriv.next();
Iterator<File> itdev = driver.getDevices().iterator();
while(itdev.hasNext()) {
String device = itdev.next().getName();
String value = String.format("%s (%s)", device, driver.getName());
devices.add(value);
}
}
} catch (IOException e) {
e.printStackTrace();
}
return devices.toArray(new String[devices.size()]);
}
public String[] getAllDevicesPath() {
Vector<String> devices = new Vector<String>();
// Parse each driver
Iterator<Driver> itdriv;
try {
itdriv = getDrivers().iterator();
while(itdriv.hasNext()) {
Driver driver = itdriv.next();
Iterator<File> itdev = driver.getDevices().iterator();
while(itdev.hasNext()) {
String device = itdev.next().getAbsolutePath();
devices.add(device);
}
}
} catch (IOException e) {
e.printStackTrace();
}
return devices.toArray(new String[devices.size()]);
}
}
package com.bgycc.smartcanteen.qrcode;
import java.io.InputStream;
import java.io.OutputStream;
public interface IQRCodeScan {
/**
* 获取输入流
*/
InputStream getInputStream();
/**
* 获取输出流
*/
OutputStream getOutputStream();
/**
* 关闭串口
*/
void close();
}
package com.bgycc.smartcanteen.qrcode;
import android.os.Build;
public class QRCodeScanFactory {
private static final String TPS = "TPS";
private static final String QUAD = "QUAD";
private static final String TPS_PORT = "/dev/ttyS0";
private static final String QUAD_PORT = "/dev/ttyS6";
public static IQRCodeScan create() throws Exception {
String model = Build.MODEL;
if (model.contains(TPS)) {
return new TPS(TPS_PORT);
} else if (model.contains(QUAD)) {
return new QUAD(QUAD_PORT);
} else {
throw new RuntimeException("不明设备型号: " + model);
}
}
}
package com.bgycc.smartcanteen.qrcode;
import java.io.InputStream;
import java.io.OutputStream;
import android_serialport_api.SerialPort;
public class QUAD implements IQRCodeScan {
private SerialPort serial;
public QUAD(String filePath) throws Exception {
serial = new SerialPort(filePath, 115200, 0);
}
@Override
public InputStream getInputStream() {
return serial.getInputStream();
}
@Override
public OutputStream getOutputStream() {
return serial.getOutputStream();
}
@Override
public void close() {
if (serial != null) {
serial.close();
}
}
}
package com.bgycc.smartcanteen.qrcode;
import com.telpo.tps550.api.serial.Serial;
import java.io.InputStream;
import java.io.OutputStream;
/**
* 天波580C串口读取
*/
public class TPS implements IQRCodeScan {
private Serial serial;
public TPS(String filePath) throws Exception {
serial = new Serial(filePath, 115200, 0);
}
@Override
public InputStream getInputStream() {
return serial.getInputStream();
}
@Override
public OutputStream getOutputStream() {
return serial.getOutputStream();
}
@Override
public void close() {
if (serial != null) {
serial.close();
}
}
}
...@@ -7,10 +7,11 @@ import com.bgycc.smartcanteen.action.*; ...@@ -7,10 +7,11 @@ import com.bgycc.smartcanteen.action.*;
import com.bgycc.smartcanteen.event.LogEvent; import com.bgycc.smartcanteen.event.LogEvent;
import com.bgycc.smartcanteen.event.QRCodeInvalidEvent; import com.bgycc.smartcanteen.event.QRCodeInvalidEvent;
import com.bgycc.smartcanteen.helper.TimerHelper; import com.bgycc.smartcanteen.helper.TimerHelper;
import com.bgycc.smartcanteen.qrcode.IQRCodeScan;
import com.bgycc.smartcanteen.qrcode.QRCodeScanFactory;
import com.bgycc.smartcanteen.server.websocket.MainWebSocket; import com.bgycc.smartcanteen.server.websocket.MainWebSocket;
import com.bgycc.smartcanteen.util.ByteUtil; import com.bgycc.smartcanteen.util.ByteUtil;
import com.blankj.utilcode.util.LogUtils; import com.blankj.utilcode.util.LogUtils;
import com.telpo.tps550.api.serial.Serial;
import org.greenrobot.eventbus.EventBus; import org.greenrobot.eventbus.EventBus;
import org.json.JSONObject; import org.json.JSONObject;
...@@ -36,7 +37,7 @@ public class QRCodeTask { ...@@ -36,7 +37,7 @@ public class QRCodeTask {
} }
private ScanAsyncTask mScanAsyncTask; private ScanAsyncTask mScanAsyncTask;
private Serial mSerial; private IQRCodeScan serial;
private long mTimerId = -1; private long mTimerId = -1;
private long mOfflineTimerId = -1; private long mOfflineTimerId = -1;
private long mOfflineUpdateDelay = 0; private long mOfflineUpdateDelay = 0;
...@@ -52,7 +53,7 @@ public class QRCodeTask { ...@@ -52,7 +53,7 @@ public class QRCodeTask {
if (mScanAsyncTask == null) { if (mScanAsyncTask == null) {
try { try {
mSerial = new Serial("/dev/ttyS0", 115200, 0); serial = QRCodeScanFactory.create();
} catch (Exception e) { } catch (Exception e) {
LogUtils.file("串口初始化失败"); LogUtils.file("串口初始化失败");
} }
...@@ -85,13 +86,13 @@ public class QRCodeTask { ...@@ -85,13 +86,13 @@ public class QRCodeTask {
TimerHelper.INSTANCE.cancel(mTimerId); TimerHelper.INSTANCE.cancel(mTimerId);
TimerHelper.INSTANCE.cancel(mOfflineTimerId); TimerHelper.INSTANCE.cancel(mOfflineTimerId);
mScanAsyncTask = null; mScanAsyncTask = null;
if (mSerial != null) { if (serial != null) {
try { try {
mSerial.getInputStream().close(); serial.getInputStream().close();
mSerial.getOutputStream().close(); serial.getOutputStream().close();
} catch (Exception e) {} } catch (Exception e) {}
mSerial.close(); serial.close();
mSerial = null; serial = null;
} }
} }
...@@ -107,13 +108,13 @@ public class QRCodeTask { ...@@ -107,13 +108,13 @@ public class QRCodeTask {
case 0: case 0:
LogUtils.file(TAG, "QRCode wait"); LogUtils.file(TAG, "QRCode wait");
String str = null; String str = null;
if (mSerial != null) { if (serial != null) {
byte[] buf = null; byte[] buf = null;
int len = 0; int len = 0;
while (true) { while (true) {
try { try {
byte[] b = new byte[64]; byte[] b = new byte[64];
int l = mSerial.getInputStream().read(b); int l = serial.getInputStream().read(b);
if (l == 0) break; if (l == 0) break;
b = Arrays.copyOfRange(b, 0, l); b = Arrays.copyOfRange(b, 0, l);
buf = ByteUtil.merge(buf, b); buf = ByteUtil.merge(buf, b);
......
#Fri Jul 12 08:50:52 CST 2019
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-5.6.4-all.zip
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or sign in to comment