Create own GUI with USBtinLib for testing or simulating CAN bus devices
For testing or simulating CAN bus devices an own GUI is often useful. This page shows step-by-step how to create such an application with USBtinLib, the open source library for
USBtin.
Contents
Setup NetBeans IDE project
- Download, install and start NetBeans IDE (tested with IDE 8.0.2 "All").
- "File" -> "New Project..."
- Choose Categories "Java" and Projects "Java Application" and click "Next".
data:image/s3,"s3://crabby-images/02db8/02db8d3ffe4bb1b8e0c2697fb955e13c9d23946d" alt="NetBeans New Project Dialog"
- Set project name and location. Disable checkbox "Create Main Class". Click "Finish".
data:image/s3,"s3://crabby-images/f33e6/f33e6461e071b9cb3476fb796e1fdacf7ba5ebf6" alt="NetBeans New Project Dialog Name and Location"
- Right-click on project, "New" -> "Other..."
data:image/s3,"s3://crabby-images/3c863/3c863b319c5dffa4bf3ada824a9a11f432f50288" alt="Add jFrame to project"
- Select category "Swing GUI Forms" and file type "JFrame Form". Click "Next".
data:image/s3,"s3://crabby-images/f67e9/f67e9cbe7562aa92baa89816f41d4891c2cd5452" alt="Add jFrame to project"
- Input class name. Click "Finish".
data:image/s3,"s3://crabby-images/3f057/3f057e244c7ce9c4493ea72bd2287757b99892c2" alt="Set name and location of JFrame"
- Now, the basic project is setup up and you can test the application with "Run" -> "Run Project" (shows blank frame).
Add libraries (USBtinLib and jSSC) to project
- Create new folder "lib" in file browser tab.
data:image/s3,"s3://crabby-images/b22fd/b22fd2efec37a76f78219b84dea89934f39e5cf3" alt="Add library folder"
- Download jar file of USBtinLib (direct download link: USBtinLib-1.1.0.jar) and save it to the "lib" folder.
- Download jar file of jSSC (Java Simple Serial Connector) (direct download link: jssc-2.8.0.jar) and save it to the "lib" folder".
data:image/s3,"s3://crabby-images/e6fa0/e6fa0fc380555efa321e253bf6335b03c83f73d0" alt="library folder"
- Add libraries to project: right-click on "Libraries" -> "Add JAR/Folder..." and choose the two jar files.
data:image/s3,"s3://crabby-images/4334b/4334b2eb59c327afec0cb02220ac16ce2b6fbbe0" alt="Add libraries"
data:image/s3,"s3://crabby-images/908c4/908c42975976b2a92047e4ef67df2c4dccc6e44a" alt="Project libraries"
- Add imports to main java class:
import de.fischl.usbtin.*;
import jssc.SerialPortList;
and add member
protected USBtin usbtin = new USBtin();
data:image/s3,"s3://crabby-images/c5a73/c5a7332ad8f2926f21dbfb3583caf3ba753f9f04" alt="Add imports"
- Open design view of main java class, add a combobox and change its name to "serialPort"
data:image/s3,"s3://crabby-images/b4681/b4681bfd6514c8c3ce8a00154d6bdb9728f21e38" alt="Set combobox name"
- Right-click on combobox -> "Properties" -> Click on "..." behind "model" text input field. Choose "Custom code" and input
new javax.swing.DefaultComboBoxModel(SerialPortList.getPortNames())
data:image/s3,"s3://crabby-images/3d56d/3d56de3ac4f0166ca224cc3aafbfcbcf622f3fdc" alt="Set model of combobox"
- Add button to design, change variable name to "connectionButton" and set text to "Connect".
data:image/s3,"s3://crabby-images/54b11/54b11d35c66b76af0689b8991b94f7c19155f1c8" alt="Add connection button"
- Double click on button and implement connect/disconnect method (here, the CAN channel opens in ACTIVE mode with 100kBaud):
private void connectionButtonActionPerformed(java.awt.event.ActionEvent evt) {
if (connectionButton.getText().equals("Disconnect")) {
try {
usbtin.closeCANChannel();
usbtin.disconnect();
System.out.println("Disconnected");
} catch (USBtinException e) {
System.err.println(e.getMessage());
}
connectionButton.setText("Connect");
serialPort.setEnabled(true);
} else {
try {
usbtin.connect((String) serialPort.getSelectedItem());
usbtin.openCANChannel(100000, USBtin.OpenMode.ACTIVE);
connectionButton.setText("Disconnect");
serialPort.setEnabled(false);
System.out.println("Connected to USBtin (FW" + usbtin.getFirmwareVersion() +
"/HW" + usbtin.getHardwareVersion() + ")");
} catch (USBtinException e) {
System.err.println(e.getMessage());
}
}
}
data:image/s3,"s3://crabby-images/7b0a5/7b0a5379042c7b0fa584ab23561347e9be0f8d5f" alt="Action performed handler for connection button"
- Time to test the application: plug in USBtin (tested with USBtin EB) and "Run" -> "Run Project". If you click the button, the USBtin led goes on and you can see the USBtin version in the NetBeans output window.
data:image/s3,"s3://crabby-images/55485/55485dc02c7e45b2f6913d9bfd86ccb1bcdeb130" alt="Test connection"
Send a CAN message
- Add new button, set text and set variable name to "sendButton".
data:image/s3,"s3://crabby-images/e0e23/e0e238cb62f1ac8e52fd8a9fbc974e194968bf6f" alt="Add send button"
- Double-click on button and implement handler:
private void sendButtonActionPerformed(java.awt.event.ActionEvent evt) {
try {
usbtin.send(new CANMessage(0x100, new byte[]{0x11, 0x22, 0x33}));
} catch (USBtinException e) {
System.err.println(e.getMessage());
}
}
- Run the project an test it. Here a second USBtin EB is connected and opened in USBtinViewer (right window) to see the output of the first USBtin interface:
data:image/s3,"s3://crabby-images/f5830/f5830e7ba078c4ef8c165a19a580ff31e16a74ad" alt="Send test"
Receive CAN messages
- Add text area and change variable name to "logTextArea".
data:image/s3,"s3://crabby-images/08f90/08f9071a07b483f36a446b2ed68032f972654e45" alt="Add textarea for logging"
- Switch to code view and add "CANMessageListener" to the class:
public class USBtinLibGUIDemo extends javax.swing.JFrame implements CANMessageListener {
Implement the listener method:
@Override
public void receiveCANMessage(CANMessage canmessage) {
logTextArea.append(canmessage.toString() + "\n");
}
And finally register the message listener in the constructor:
usbtin.addMessageListener(this);
data:image/s3,"s3://crabby-images/b8a14/b8a1447cefa0062dabf854d7dea7efb23c07a6cf" alt="Add receive functions"
- Run the project an test it. Here a second USBtin EB is connected and opened in USBtinViewer (right window) to send CAN messages to the first USBtin interface:
data:image/s3,"s3://crabby-images/c7904/c7904a814fe798fe21e32489487e6a6bc182d4a7" alt="Receive CAN message test"
Add slider which sends CAN messages on change
Add slider and change variable name to "testSlider". Set properies for minimum and maximum.
data:image/s3,"s3://crabby-images/4b6f5/4b6f501265a1e1cc6c1ffcfb5ed6705ef8004084" alt="Add slider"
Add "stateChanged" event to slider and implement event method:
private void testSliderStateChanged(javax.swing.event.ChangeEvent evt) {
JSlider source = (JSlider)evt.getSource();
if (!source.getValueIsAdjusting()) {
try {
usbtin.send(new CANMessage(0x101, new byte[]{(byte)source.getValue()}));
} catch (USBtinException e) {
System.err.println(e.getMessage());
}
}
}
data:image/s3,"s3://crabby-images/87e45/87e45ed2cb30f97e96fe93d392e8bb96991eb1ed" alt="Add event to slider"
Run the project an test it. Here a second USBtin EB is connected and opened in USBtinViewer (right window) to see the output of the first USBtin interface:
data:image/s3,"s3://crabby-images/6f68c/6f68c0561d56017e00b8d634b9e45a8cba7891ff" alt="Slider test"
Simulate behavior of a CAN device
Example: we simulate a CAN device which waits for messages with ID 0x001, sums the data bytes and send a CAN message with the sum as payload within ID 0x002.
Extend the listener method (see Receive CAN messages) to simulate our sum-device
@Override
public void receiveCANMessage(CANMessage canmessage) {
logTextArea.append(canmessage.toString() + "\n");
if (canmessage.getId() == 0x001) {
byte sum = 0;
for (byte b : canmessage.getData()) sum += b;
try {
usbtin.send(new CANMessage(0x002, new byte[]{sum}));
} catch (USBtinException e) {
System.err.println(e.getMessage());
}
}
}
Run the project an test it. Here a second USBtin EB is connected and opened in USBtinViewer (right window) to send messages and see the output of the first USBtin interface:
data:image/s3,"s3://crabby-images/d87a1/d87a167f0dc2fc72ae86ade1f7d331ab5e0d1493" alt="Simulation test"