auto-sync
This commit is contained in:
parent
528425cfe4
commit
3d4dced8ac
|
@ -62,6 +62,7 @@ class PortHolder {
|
|||
}
|
||||
|
||||
try {
|
||||
// todo: why is this delay here? add a comment
|
||||
Thread.sleep(200);
|
||||
} catch (InterruptedException e) {
|
||||
throw new IllegalStateException(e);
|
||||
|
@ -71,6 +72,16 @@ class PortHolder {
|
|||
this.serialPort = serialPort;
|
||||
portLock.notifyAll();
|
||||
}
|
||||
|
||||
try {
|
||||
/**
|
||||
* Let's make sure we have not connected to Tuner Studio port?
|
||||
* @see EngineState#TS_PROTOCOL_TAG
|
||||
*/
|
||||
doWriteCommand("test");
|
||||
} catch (SerialPortException e) {
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -106,13 +117,17 @@ class PortHolder {
|
|||
}
|
||||
// we are here only when serialPort!=null, that means we have a connection
|
||||
try {
|
||||
serialPort.writeString(command + "\r\n");
|
||||
doWriteCommand(command);
|
||||
} catch (SerialPortException e) {
|
||||
throw new IllegalStateException(e);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void doWriteCommand(String command) throws SerialPortException {
|
||||
serialPort.writeString(command + "\r\n");
|
||||
}
|
||||
|
||||
public static PortHolder getInstance() {
|
||||
return instance;
|
||||
}
|
||||
|
|
|
@ -3,6 +3,7 @@ package com.irnems.core;
|
|||
import com.irnems.FileLog;
|
||||
import org.jetbrains.annotations.NotNull;
|
||||
|
||||
import javax.swing.*;
|
||||
import java.util.*;
|
||||
import java.util.concurrent.CopyOnWriteArrayList;
|
||||
|
||||
|
@ -22,6 +23,10 @@ public class EngineState {
|
|||
}
|
||||
};
|
||||
public static final String PACKING_DELIMITER = ":";
|
||||
/**
|
||||
* If we get this tag we have probably connected to the wrong port
|
||||
*/
|
||||
private static final CharSequence TS_PROTOCOL_TAG = "ts_p_al";
|
||||
private final Object lock = new Object();
|
||||
|
||||
static class StringActionPair extends Pair<String, ValueCallback<String>> {
|
||||
|
@ -209,6 +214,10 @@ public class EngineState {
|
|||
*/
|
||||
public static String unpackString(String message) {
|
||||
String prefix = "line" + PACKING_DELIMITER;
|
||||
if (message.contains(TS_PROTOCOL_TAG)) {
|
||||
JOptionPane.showMessageDialog(null, "Are you sure you are not connected to TS port?");
|
||||
return null;
|
||||
}
|
||||
if (!message.startsWith(prefix)) {
|
||||
FileLog.MAIN.logLine("EngineState: unexpected header: " + message + " while looking for " + prefix);
|
||||
return null;
|
||||
|
|
|
@ -19,7 +19,7 @@ import javax.swing.*;
|
|||
* @see WavePanel
|
||||
*/
|
||||
public class Launcher extends FrameHelper {
|
||||
public static final int CONSOLE_VERSION = 20140828;
|
||||
public static final int CONSOLE_VERSION = 20140829;
|
||||
public static final boolean SHOW_STIMULATOR = true;
|
||||
|
||||
public Launcher(String port) {
|
||||
|
@ -40,10 +40,10 @@ public class Launcher extends FrameHelper {
|
|||
// tabbedPane.addTab("ADC", new AdcPanel(new BooleanInputsModel()).createAdcPanel());
|
||||
if (SHOW_STIMULATOR) {
|
||||
EcuStimulator stimulator = EcuStimulator.getInstance();
|
||||
tabbedPane.add("Emulation Map", stimulator.getPanel());
|
||||
tabbedPane.add("ECU stimulation", stimulator.getPanel());
|
||||
}
|
||||
// tabbedPane.addTab("live map adjustment", new Live3DReport().getControl());
|
||||
tabbedPane.add("MessagesCentral", new MsgPanel(true).getContent());
|
||||
tabbedPane.add("Messages", new MsgPanel(true).getContent());
|
||||
|
||||
tabbedPane.add("Log Viewer", new LogViewer());
|
||||
|
||||
|
|
|
@ -1,7 +1,5 @@
|
|||
package com.rusefi.ui;
|
||||
|
||||
import com.rusefi.EcuStimulator;
|
||||
import com.irnems.Launcher;
|
||||
import com.irnems.core.EngineTimeListener;
|
||||
import com.irnems.core.Sensor;
|
||||
import com.rusefi.ui.widgets.*;
|
||||
|
@ -20,7 +18,6 @@ import java.awt.event.ActionListener;
|
|||
*/
|
||||
public class RpmPanel {
|
||||
private RpmControl rpmControl = new RpmControl();
|
||||
// this label displays real RPM received from ECU
|
||||
// that's for CKP signal emulation
|
||||
public final WaveInfoPanel wave0 = new WaveInfoPanel(0);
|
||||
public final WaveInfoPanel wave1 = new WaveInfoPanel(1);
|
||||
|
@ -30,18 +27,6 @@ public class RpmPanel {
|
|||
rpmControl.setSize(15);
|
||||
}
|
||||
|
||||
private WaveInfoPanel findWavePanel(int index) {
|
||||
WaveInfoPanel wave;
|
||||
if (index == 0)
|
||||
wave = wave0;
|
||||
else if (index == 1)
|
||||
wave = wave1;
|
||||
else
|
||||
throw new IllegalStateException("unexpected index " + index);
|
||||
return wave;
|
||||
}
|
||||
|
||||
|
||||
public JComponent createRpmPanel() {
|
||||
JPanel controls = createControls();
|
||||
|
||||
|
@ -60,6 +45,25 @@ public class RpmPanel {
|
|||
// gauges.add(GaugesPanel.createGauge(Sensor.MAF));
|
||||
|
||||
|
||||
startConnectionWatchDog();
|
||||
|
||||
JPanel msgPanel = new JPanel(new BorderLayout());
|
||||
msgPanel.add(new AnyCommand(), BorderLayout.NORTH);
|
||||
msgPanel.add(new MsgPanel(false).getContent(), BorderLayout.CENTER);
|
||||
|
||||
|
||||
JComponent rpmPanel = new JPanel(new BorderLayout());
|
||||
rpmPanel.setBorder(BorderFactory.createLineBorder(Color.white));
|
||||
|
||||
rpmPanel.add(rpmControl.getContent(), BorderLayout.NORTH);
|
||||
rpmPanel.add(controls, BorderLayout.WEST);
|
||||
rpmPanel.add(gauges, BorderLayout.CENTER);
|
||||
rpmPanel.add(msgPanel, BorderLayout.EAST);
|
||||
|
||||
return rpmPanel;
|
||||
}
|
||||
|
||||
private void startConnectionWatchDog() {
|
||||
final Timer reconnectTimer = new Timer(10000, new ActionListener() {
|
||||
@Override
|
||||
public void actionPerformed(ActionEvent e) {
|
||||
|
@ -75,20 +79,8 @@ public class RpmPanel {
|
|||
* this timer will reconnect
|
||||
*/
|
||||
postponeReconnecting(reconnectTimer);
|
||||
|
||||
}
|
||||
});
|
||||
|
||||
JComponent rpmPanel = new JPanel(new BorderLayout());
|
||||
rpmPanel.setBorder(BorderFactory.createLineBorder(Color.white));
|
||||
|
||||
rpmPanel.add(rpmControl.getContent(), BorderLayout.NORTH);
|
||||
rpmPanel.add(controls, BorderLayout.WEST);
|
||||
rpmPanel.add(gauges, BorderLayout.CENTER);
|
||||
MsgPanel msgPanel = new MsgPanel(false);
|
||||
rpmPanel.add(msgPanel.getContent(), BorderLayout.EAST);
|
||||
|
||||
return rpmPanel;
|
||||
}
|
||||
|
||||
private void postponeReconnecting(Timer timer2) {
|
||||
|
@ -101,7 +93,6 @@ public class RpmPanel {
|
|||
controls.add(new RpmCommand(), "grow, wrap");
|
||||
// controls.add(new PotCommand(0).panel, "grow, wrap");
|
||||
// controls.add(new PotCommand(1).panel, "grow, wrap");
|
||||
controls.add(new AnyCommand(), "grow, wrap");
|
||||
|
||||
controls.add(new MafCommand(), "grow, wrap");
|
||||
|
||||
|
|
Loading…
Reference in New Issue