auto-sync

This commit is contained in:
rusEfi 2015-09-20 23:01:32 -04:00
parent 664062d16b
commit 8897b277b3
5 changed files with 42 additions and 14 deletions

View File

@ -35,8 +35,11 @@ public class RevolutionLog {
} }
public String getCrankAngleByTimeString(double time) { public String getCrankAngleByTimeString(double time) {
double result = getCrankAngleByTime(time); return angle2string(getCrankAngleByTime(time));
return Double.isNaN(result) ? "n/a" : String.format("%.2f", result); }
public static String angle2string(double angle) {
return Double.isNaN(angle) ? "n/a" : String.format("%.2f", angle);
} }
public double getCrankAngleByTime(double time) { public double getCrankAngleByTime(double time) {

View File

@ -32,7 +32,7 @@ import static com.rusefi.ui.storage.PersistentConfiguration.getConfig;
* @see com.rusefi.StartupFrame * @see com.rusefi.StartupFrame
*/ */
public class Launcher { public class Launcher {
public static final int CONSOLE_VERSION = 20150918; public static final int CONSOLE_VERSION = 20150920;
public static final boolean SHOW_STIMULATOR = false; public static final boolean SHOW_STIMULATOR = false;
private static final String TAB_INDEX = "main_tab"; private static final String TAB_INDEX = "main_tab";
protected static final String PORT_KEY = "port"; protected static final String PORT_KEY = "port";

View File

@ -88,7 +88,7 @@ public class EngineSnifferPanel {
}); });
statusPanel.setWaveReport(crank.createTranslator()); statusPanel.setTimeAxisTranslator(crank.createTranslator());
JButton clearButton = new JButton(CLEAR.getMessage()); JButton clearButton = new JButton(CLEAR.getMessage());
clearButton.setMnemonic('c'); clearButton.setMnemonic('c');

View File

@ -46,11 +46,12 @@ public class EngineSnifferStatusPanel {
angleLabel.setText(text); angleLabel.setText(text);
Map.Entry<Integer, Integer> e = time2rpm.getTimeAndRpm(time); Map.Entry<Integer, Integer> e = time2rpm.getTimeAndRpm(time);
if (e == null) if (e == null) {
rpmLabel.setText("n/a"); rpmLabel.setText("n/a");
else } else {
rpmLabel.setText("" + e.getValue()); rpmLabel.setText("" + e.getValue());
} }
}
}; };
private ZoomProvider zoomProvider; private ZoomProvider zoomProvider;
@ -77,7 +78,7 @@ public class EngineSnifferStatusPanel {
infoPanel.add(red); infoPanel.add(red);
} }
public void setWaveReport(TimeAxisTranslator translator) { public void setTimeAxisTranslator(TimeAxisTranslator translator) {
this.translator = translator; this.translator = translator;
} }

View File

@ -49,6 +49,7 @@ public class UpDownImage extends JPanel {
} }
}); });
public boolean showText = true; public boolean showText = true;
private int currentMouseX = -100;
public UpDownImage(final String name) { public UpDownImage(final String name) {
this(EngineReport.MOCK, name); this(EngineReport.MOCK, name);
@ -68,6 +69,13 @@ public class UpDownImage extends JPanel {
setWaveReport(wr, null); setWaveReport(wr, null);
setOpaque(true); setOpaque(true);
translator = createTranslator(); translator = createTranslator();
addMouseMotionListener(new MouseAdapter() {
@Override
public void mouseMoved(MouseEvent e) {
currentMouseX = e.getX();
UiUtils.trueRepaint(UpDownImage.this);
}
});
addMouseListener(new MouseAdapter() { addMouseListener(new MouseAdapter() {
@Override @Override
public void mouseEntered(MouseEvent e) { public void mouseEntered(MouseEvent e) {
@ -217,9 +225,15 @@ public class UpDownImage extends JPanel {
int y = (int) (0.2 * d.height); int y = (int) (0.2 * d.height);
/**
* signal body
*/
g.setColor(Color.lightGray); g.setColor(Color.lightGray);
g.fillRect(x1, y, x2 - x1, d.height - y); g.fillRect(x1, y, x2 - x1, d.height - y);
/**
* signal out-line
*/
g.setColor(Color.blue); g.setColor(Color.blue);
g.drawLine(x1, y, x2, y); g.drawLine(x1, y, x2, y);
g.drawLine(x1, y, x1, d.height); g.drawLine(x1, y, x1, d.height);
@ -231,25 +245,35 @@ public class UpDownImage extends JPanel {
if (showText) { if (showText) {
g.drawString(durationString, x1, (int) (0.5 * d.height)); g.drawString(durationString, x1, (int) (0.5 * d.height));
String fromAngle = time2rpm.getCrankAngleByTimeString(upDown.upTime); double fromAngle = time2rpm.getCrankAngleByTime((double) upDown.upTime);
String toAngle = time2rpm.getCrankAngleByTimeString(upDown.downTime); double toAngle = time2rpm.getCrankAngleByTime((double) upDown.downTime);
String fromAngleStr = RevolutionLog.angle2string(fromAngle);
g.setColor(Color.darkGray); g.setColor(Color.darkGray);
if (upDown.upIndex != -1) { if (upDown.upIndex != -1) {
g.drawString("" + upDown.upIndex, x1, (int) (0.25 * d.height)); g.drawString("" + upDown.upIndex, x1, (int) (0.25 * d.height));
// System.out.println("digital_event," + upDown.upIndex + "," + fromAngle); // System.out.println("digital_event," + upDown.upIndex + "," + fromAngleStr);
} }
if (upDown.downIndex != -1) { if (upDown.downIndex != -1) {
g.drawString("" + upDown.downIndex, x2, (int) (0.25 * d.height)); g.drawString("" + upDown.downIndex, x2, (int) (0.25 * d.height));
// System.out.println("digital_event," + upDown.downIndex + "," + toAngle); // System.out.println("digital_event," + upDown.downIndex + "," + toAngleStr);
} }
int offset = 3; int offset = 3;
g.setColor(Color.black); g.setColor(Color.black);
g.drawString(fromAngle, x1 + offset, (int) (0.75 * d.height)); g.drawString(fromAngleStr, x1 + offset, (int) (0.75 * d.height));
g.setColor(Color.green); g.setColor(Color.black);
g.drawString(toAngle, x1 + offset, (int) (1.0 * d.height));
if (Math.abs(x1 - currentMouseX) < 5) {
double angleDuration = toAngle - fromAngle;
String durationStr = RevolutionLog.angle2string(angleDuration);
g.drawString(durationStr, x1 + offset, (int) (1.0 * d.height));
} else {
String toAngleStr = RevolutionLog.angle2string(toAngle);
g.drawString(toAngleStr, x1 + offset, (int) (1.0 * d.height));
}
} }
} }