auto-sync
This commit is contained in:
parent
b58aaa523a
commit
ba55bd455c
|
@ -0,0 +1,86 @@
|
||||||
|
package com.rusefi.ui.widgets;
|
||||||
|
|
||||||
|
import com.irnems.core.Sensor;
|
||||||
|
import com.rusefi.io.CommandQueue;
|
||||||
|
|
||||||
|
import javax.swing.*;
|
||||||
|
import javax.swing.event.ChangeEvent;
|
||||||
|
import javax.swing.event.ChangeListener;
|
||||||
|
import java.awt.*;
|
||||||
|
import java.awt.event.MouseEvent;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.Collection;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* (c) Andrey Belomutskiy
|
||||||
|
* 11/2/14
|
||||||
|
*/
|
||||||
|
public class DetachedSensor {
|
||||||
|
private static final Collection<Sensor> MOCKABLE = Arrays.asList(Sensor.CLT, Sensor.AFR, Sensor.IAT, Sensor.MAF,
|
||||||
|
Sensor.TPS);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* We need to trick the JSlider into displaying float values
|
||||||
|
*/
|
||||||
|
private static final int _5_VOLTS_WITH_DECIMAL = 50;
|
||||||
|
|
||||||
|
private Sensor sensor;
|
||||||
|
private int width;
|
||||||
|
JPanel content = new JPanel(new BorderLayout());
|
||||||
|
JFrame frame;
|
||||||
|
JPanel mockControlPanel = new JPanel(new BorderLayout());
|
||||||
|
|
||||||
|
public DetachedSensor(Sensor sensor, int width) {
|
||||||
|
this.sensor = sensor;
|
||||||
|
this.width = width;
|
||||||
|
frame = new JFrame();
|
||||||
|
frame.setAlwaysOnTop(true);
|
||||||
|
onChange(sensor);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void show(MouseEvent e) {
|
||||||
|
frame.setVisible(true);
|
||||||
|
frame.setLocation(e.getXOnScreen(), e.getYOnScreen());
|
||||||
|
}
|
||||||
|
|
||||||
|
public void onChange(Sensor sensor) {
|
||||||
|
this.sensor = sensor;
|
||||||
|
frame.setTitle(sensor.getName());
|
||||||
|
showMockControl();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void showMockControl() {
|
||||||
|
mockControlPanel.removeAll();
|
||||||
|
boolean isMockable = MOCKABLE.contains(sensor);
|
||||||
|
if (isMockable) {
|
||||||
|
Component mockComponent = createMockVoltageSlider(sensor);
|
||||||
|
mockControlPanel.add(mockComponent);
|
||||||
|
}
|
||||||
|
UpDownImage.trueLayout(content);
|
||||||
|
int size = width;
|
||||||
|
int h = isMockable ? (int) (size * 1.5) : size;
|
||||||
|
frame.setSize(size, h);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private static Component createMockVoltageSlider(final Sensor sensor) {
|
||||||
|
/**
|
||||||
|
*/
|
||||||
|
final JSlider slider = new JSlider(0, _5_VOLTS_WITH_DECIMAL);
|
||||||
|
slider.setLabelTable(SensorGauge.SLIDER_LABELS);
|
||||||
|
slider.setPaintLabels(true);
|
||||||
|
slider.setPaintTicks(true);
|
||||||
|
slider.setMajorTickSpacing(10);
|
||||||
|
slider.setMinorTickSpacing(5);
|
||||||
|
|
||||||
|
slider.addChangeListener(new ChangeListener() {
|
||||||
|
@Override
|
||||||
|
public void stateChanged(ChangeEvent e) {
|
||||||
|
double value = slider.getValue() / 10.0;
|
||||||
|
CommandQueue.getInstance().write("set_mock_" + sensor.name().toLowerCase() + "_voltage " + value);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
return slider;
|
||||||
|
}
|
||||||
|
}
|
|
@ -2,13 +2,10 @@ package com.rusefi.ui.widgets;
|
||||||
|
|
||||||
import com.irnems.core.Sensor;
|
import com.irnems.core.Sensor;
|
||||||
import com.irnems.core.SensorCentral;
|
import com.irnems.core.SensorCentral;
|
||||||
import com.rusefi.io.CommandQueue;
|
|
||||||
import eu.hansolo.steelseries.gauges.Radial;
|
import eu.hansolo.steelseries.gauges.Radial;
|
||||||
import eu.hansolo.steelseries.tools.ColorDef;
|
import eu.hansolo.steelseries.tools.ColorDef;
|
||||||
|
|
||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
import javax.swing.event.ChangeEvent;
|
|
||||||
import javax.swing.event.ChangeListener;
|
|
||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
import java.awt.event.ActionEvent;
|
import java.awt.event.ActionEvent;
|
||||||
import java.awt.event.ActionListener;
|
import java.awt.event.ActionListener;
|
||||||
|
@ -16,8 +13,6 @@ import java.awt.event.MouseAdapter;
|
||||||
import java.awt.event.MouseEvent;
|
import java.awt.event.MouseEvent;
|
||||||
import java.text.DecimalFormat;
|
import java.text.DecimalFormat;
|
||||||
import java.text.Format;
|
import java.text.Format;
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.Collection;
|
|
||||||
import java.util.Hashtable;
|
import java.util.Hashtable;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -26,23 +21,24 @@ import java.util.Hashtable;
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class SensorGauge {
|
public class SensorGauge {
|
||||||
private static final Collection<Sensor> MOCKABLE = Arrays.asList(Sensor.CLT, Sensor.AFR, Sensor.IAT, Sensor.MAF,
|
|
||||||
Sensor.TPS);
|
|
||||||
/**
|
|
||||||
* We need to trick the JSlider into displaying float values
|
|
||||||
*/
|
|
||||||
private static final int _5_VOLTS_WITH_DECIMAL = 50;
|
|
||||||
|
|
||||||
public static Component createGauge(final Sensor sensor) {
|
public static Component createGauge(final Sensor sensor) {
|
||||||
|
return createGauge2(sensor, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Component createGauge2(Sensor sensor, GaugeChangeListener listener) {
|
||||||
JPanel wrapper = new JPanel(new BorderLayout());
|
JPanel wrapper = new JPanel(new BorderLayout());
|
||||||
|
|
||||||
createGaugeBody(sensor, wrapper);
|
createGaugeBody(sensor, wrapper, listener);
|
||||||
|
|
||||||
|
|
||||||
return wrapper;
|
return wrapper;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void createGaugeBody(final Sensor sensor, final JPanel wrapper) {
|
interface GaugeChangeListener {
|
||||||
|
void onChange(Sensor sensor);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void createGaugeBody(final Sensor sensor, final JPanel wrapper, final GaugeChangeListener listener) {
|
||||||
final Radial gauge = createRadial(sensor.getName(), sensor.getUnits(), sensor.getMaxValue(), sensor.getMinValue());
|
final Radial gauge = createRadial(sensor.getName(), sensor.getUnits(), sensor.getMaxValue(), sensor.getMinValue());
|
||||||
|
|
||||||
UpDownImage.setTwoLineToolTip(gauge, "Double-click to detach", "Right-click to change");
|
UpDownImage.setTwoLineToolTip(gauge, "Double-click to detach", "Right-click to change");
|
||||||
|
@ -60,7 +56,7 @@ public class SensorGauge {
|
||||||
@Override
|
@Override
|
||||||
public void mouseClicked(MouseEvent e) {
|
public void mouseClicked(MouseEvent e) {
|
||||||
if (SwingUtilities.isRightMouseButton(e)) {
|
if (SwingUtilities.isRightMouseButton(e)) {
|
||||||
showPopupMenu(e, wrapper);
|
showPopupMenu(e, wrapper, listener);
|
||||||
} else if (e.getClickCount() == 2) {
|
} else if (e.getClickCount() == 2) {
|
||||||
handleDoubleClick(e, gauge, sensor);
|
handleDoubleClick(e, gauge, sensor);
|
||||||
}
|
}
|
||||||
|
@ -72,21 +68,23 @@ public class SensorGauge {
|
||||||
UpDownImage.trueLayout(wrapper.getParent());
|
UpDownImage.trueLayout(wrapper.getParent());
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void showPopupMenu(MouseEvent e, JPanel wrapper) {
|
private static void showPopupMenu(MouseEvent e, JPanel wrapper, GaugeChangeListener listener) {
|
||||||
JPopupMenu pm = new JPopupMenu();
|
JPopupMenu pm = new JPopupMenu();
|
||||||
JMenu gauges = new JMenu("Gauges...");
|
JMenu gauges = new JMenu("Gauges...");
|
||||||
fillGaugeItems(gauges, wrapper);
|
fillGaugeItems(gauges, wrapper, listener);
|
||||||
pm.add(gauges);
|
pm.add(gauges);
|
||||||
pm.show(e.getComponent(), e.getX(), e.getY());
|
pm.show(e.getComponent(), e.getX(), e.getY());
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void fillGaugeItems(JMenu gauges, final JPanel wrapper) {
|
private static void fillGaugeItems(JMenu gauges, final JPanel wrapper, final GaugeChangeListener listener) {
|
||||||
for (final Sensor s : Sensor.values()) {
|
for (final Sensor s : Sensor.values()) {
|
||||||
JMenuItem mi = new JMenuItem(s.getName());
|
JMenuItem mi = new JMenuItem(s.getName());
|
||||||
mi.addActionListener(new ActionListener() {
|
mi.addActionListener(new ActionListener() {
|
||||||
@Override
|
@Override
|
||||||
public void actionPerformed(ActionEvent e) {
|
public void actionPerformed(ActionEvent e) {
|
||||||
createGaugeBody(s, wrapper);
|
createGaugeBody(s, wrapper, listener);
|
||||||
|
if (listener != null)
|
||||||
|
listener.onChange(s);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
gauges.add(mi);
|
gauges.add(mi);
|
||||||
|
@ -94,26 +92,24 @@ public class SensorGauge {
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void handleDoubleClick(MouseEvent e, Radial gauge, Sensor sensor) {
|
private static void handleDoubleClick(MouseEvent e, Radial gauge, Sensor sensor) {
|
||||||
int size = gauge.getSize().width;
|
int width = gauge.getSize().width;
|
||||||
JFrame n = new JFrame(sensor.getName());
|
final DetachedSensor ds = new DetachedSensor(sensor, width);
|
||||||
boolean isMockable = MOCKABLE.contains(sensor);
|
|
||||||
int h = isMockable ? (int) (size * 1.5) : size;
|
|
||||||
|
|
||||||
JPanel content = new JPanel(new BorderLayout());
|
GaugeChangeListener listener = new GaugeChangeListener() {
|
||||||
|
@Override
|
||||||
|
public void onChange(Sensor sensor) {
|
||||||
|
ds.onChange(sensor);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
ds.content.add(createGauge2(sensor, listener), BorderLayout.CENTER);
|
||||||
|
ds.content.add(ds.mockControlPanel, BorderLayout.SOUTH);
|
||||||
|
|
||||||
content.add(createGauge(sensor), BorderLayout.CENTER);
|
|
||||||
|
|
||||||
if (isMockable)
|
ds.frame.add(ds.content);
|
||||||
content.add(createMockVoltageSlider(sensor), BorderLayout.SOUTH);
|
ds.show(e);
|
||||||
|
|
||||||
n.setSize(size, h);
|
|
||||||
n.setAlwaysOnTop(true);
|
|
||||||
n.add(content);
|
|
||||||
n.setVisible(true);
|
|
||||||
n.setLocation(e.getXOnScreen(), e.getYOnScreen());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private final static Hashtable<Integer, JComponent> SLIDER_LABELS = new Hashtable<Integer, JComponent>();
|
final static Hashtable<Integer, JComponent> SLIDER_LABELS = new Hashtable<Integer, JComponent>();
|
||||||
|
|
||||||
static {
|
static {
|
||||||
Format f = new DecimalFormat("0.0");
|
Format f = new DecimalFormat("0.0");
|
||||||
|
@ -125,27 +121,6 @@ public class SensorGauge {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private static Component createMockVoltageSlider(final Sensor sensor) {
|
|
||||||
/**
|
|
||||||
*/
|
|
||||||
final JSlider slider = new JSlider(0, _5_VOLTS_WITH_DECIMAL);
|
|
||||||
slider.setLabelTable(SLIDER_LABELS);
|
|
||||||
slider.setPaintLabels(true);
|
|
||||||
slider.setPaintTicks(true);
|
|
||||||
slider.setMajorTickSpacing(10);
|
|
||||||
slider.setMinorTickSpacing(5);
|
|
||||||
|
|
||||||
slider.addChangeListener(new ChangeListener() {
|
|
||||||
@Override
|
|
||||||
public void stateChanged(ChangeEvent e) {
|
|
||||||
double value = slider.getValue() / 10.0;
|
|
||||||
CommandQueue.getInstance().write("set_mock_" + sensor.name().toLowerCase() + "_voltage " + value);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
return slider;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static Radial createRadial(String title, String units, double maxValue, double minValue) {
|
public static Radial createRadial(String title, String units, double maxValue, double minValue) {
|
||||||
// final Section[] SECTIONS =
|
// final Section[] SECTIONS =
|
||||||
// {
|
// {
|
||||||
|
|
Loading…
Reference in New Issue