我使用JSSC库与项目中的硬件设备进行通信。
我的软件和我的团队硬件需要同步工作(我的软件需要显示硬件中当前显示的内容,反之亦然)
一切都与我们团队的面包板完美配合,直到我们将其制作成带有按钮的真正PCB。
我们的团队目前正在为设备使用此USB转串口适配器:https://www.sparkfun.com/products/14050
当我们使用面包板进行测试时,它通过COM3连接。当前设备通过COM5连接。
我的软件现在只能从设备接收数据,并且在点击我的软件中的按钮时无法发回信号(实际上 writeString 方法返回true但我们的设备什么都没有收到)
让我们看一下我软件的一些代码片段:
我已经通过 CONNECT 按钮打开端口并建立通信:
private void connectButtonActionPerformed(java.awt.event.ActionEvent evt) {
if (selectedPort != null && selectedPort.isOpened()) {
// Disconnect
selectedPort.closePort();
connectButton.setText("Connect");
} else { // Connect
selectedPort = new SerialPort(listPort.getSelectedItem().toString());
try {
connectButton.setText("Disconnect");
selectedPort.openPort();
selectedPort.setParams(9600, 8, 1, 0, true, false);
selectedPort.setFlowControlMode(SerialPort.FLOWCONTROL_RTSCTS_IN | SerialPort.FLOWCONTROL_RTSCTS_OUT);
int mask = SerialPort.MASK_RXCHAR;
selectedPort.setEventsMask(mask);
selectedPort.addEventListener(new SerialPortReader());
} catch (SerialPortException ex) {
System.out.println(ex);
}
}
}
我还有 jcombobox 将字符发送到设备:
private void modeListActionPerformed(java.awt.event.ActionEvent evt) {
try {
JComboBox cb = (JComboBox) evt.getSource();
String selectedItem = (String) cb.getSelectedItem();
switch (selectedItem) {
case "VOLTAGE_DC":
dataMode = VOL_DC;
selectedPort.writeString("v");
break;
case "VOLTAGE_AC":
dataMode = VOL_AC;
selectedPort.writeString("V");
break;
case "CURRENT_DC":
dataMode = "CUR_DC";
selectedPort.writeString("i");
break;
case "CURRENT_AC":
dataMode = "CUR_AC";
selectedPort.writeString("I");
break;
case "RESISTANCE":
dataMode = RES;
selectedPort.writeString("r");
break;
case "RESISTANCE_CON":
dataMode = CON;
selectedPort.writeString("c");
break;
default:
break;
}
selectedPort.closePort();
selectedPort.openPort();
selectedPort.addEventListener(new SerialPortReader());
} catch (SerialPortException ex) {
Logger.getLogger(MainForm.class.getName()).log(Level.SEVERE, null, ex);
}
}
我的 SerialPortReader :
public class SerialPortReader implements SerialPortEventListener {
@Override
public void serialEvent(SerialPortEvent event) {
if (event.isRXCHAR() && event.getEventValue() > 0) {
try {
byte[] buffer = selectedPort.readBytes(event.getEventValue());
SwingUtilities.invokeLater(new Runnable() {
public void run() {
update_display_by_buffer(buffer);
});
}
catch (SerialPortException ex) {
System.out.println(ex);
}
}
回顾一些重点:
这个问题的原因是什么?
任何指针都将受到赞赏。
// 更新:
使用jSerialComm库解决问题
结论:
RXTX很乱。
JSSC库糟透了。
答案 0 :(得分:0)
我在另一个项目中观察到相同的行为,有时它是由于"没有刷新数据"写入串口后。 JSSC似乎没有任何冲刷。