Change mouse button handling in simulation plot. Left click drag zooms
area, and ctrl left click drag pans.
This commit is contained in:
parent
06e702839f
commit
b16917995d
@ -1099,7 +1099,7 @@ TCMotorSelPan.noDescription = No description available.
|
||||
|
||||
! PlotDialog
|
||||
PlotDialog.CheckBox.Showdatapoints = Show data points
|
||||
PlotDialog.lbl.Chart = mouse wheel to zoom. alt-mouse wheel to zoom x axis only. drag to pan.
|
||||
PlotDialog.lbl.Chart = left click drag to zoom area. mouse wheel to zoom. ctrl-mouse wheel to zoom x axis only. ctrl-left click drag to pan. right click drag to zoom dynamically.
|
||||
|
||||
|
||||
! "main" prefix is used for the main application dialog
|
||||
|
@ -15,7 +15,6 @@ import javax.swing.BorderFactory;
|
||||
import org.jfree.chart.ChartPanel;
|
||||
import org.jfree.chart.ChartRenderingInfo;
|
||||
import org.jfree.chart.JFreeChart;
|
||||
import org.jfree.chart.plot.Pannable;
|
||||
import org.jfree.chart.plot.PiePlot;
|
||||
import org.jfree.chart.plot.Plot;
|
||||
import org.jfree.chart.plot.PlotOrientation;
|
||||
@ -41,18 +40,21 @@ public class SimulationChart extends ChartPanel {
|
||||
private double panW;
|
||||
private double panH;
|
||||
|
||||
private enum Interaction {ZOOM, PAN};
|
||||
private Interaction interaction = Interaction.PAN;
|
||||
private enum Interaction {
|
||||
ZOOM
|
||||
};
|
||||
|
||||
private Interaction interaction = null;
|
||||
|
||||
private MouseWheelHandler mouseWheelHandler = null;
|
||||
|
||||
public SimulationChart(JFreeChart chart) {
|
||||
super(chart,
|
||||
/* properties */false,
|
||||
/* save */ true,
|
||||
/* print */ false,
|
||||
/* zoom */ true,
|
||||
/* tooltips */ true);
|
||||
/* save */true,
|
||||
/* print */false,
|
||||
/* zoom */true,
|
||||
/* tooltips */true);
|
||||
this.setMouseWheelEnabled(true);
|
||||
this.setEnforceFileExtensions(true);
|
||||
this.setInitialDelay(500);
|
||||
@ -66,10 +68,10 @@ public class SimulationChart extends ChartPanel {
|
||||
|
||||
@Override
|
||||
public void setMouseWheelEnabled(boolean flag) {
|
||||
if ( flag && mouseWheelHandler == null ) {
|
||||
if (flag && mouseWheelHandler == null) {
|
||||
this.mouseWheelHandler = new MouseWheelHandler();
|
||||
this.addMouseWheelListener(this.mouseWheelHandler);
|
||||
} else if ( !flag && mouseWheelHandler != null ) {
|
||||
} else if (!flag && mouseWheelHandler != null) {
|
||||
this.removeMouseWheelListener(this.mouseWheelHandler);
|
||||
this.mouseWheelHandler = null;
|
||||
}
|
||||
@ -77,39 +79,41 @@ public class SimulationChart extends ChartPanel {
|
||||
|
||||
@Override
|
||||
public void mousePressed(MouseEvent e) {
|
||||
if ( e.getButton() == MouseEvent.BUTTON1 || e.getButton() == MouseEvent.BUTTON3) {
|
||||
// if no modifiers, use pan
|
||||
if (e.getButton() == MouseEvent.BUTTON3) {
|
||||
|
||||
Rectangle2D screenDataArea = getScreenDataArea(e.getX(), e.getY());
|
||||
|
||||
if ( screenDataArea != null && screenDataArea.contains(e.getPoint())) {
|
||||
if (screenDataArea != null && screenDataArea.contains(e.getPoint())) {
|
||||
this.panW = screenDataArea.getWidth();
|
||||
this.panH = screenDataArea.getHeight();
|
||||
this.panLast = e.getPoint();
|
||||
this.startPoint = e.getPoint();
|
||||
}
|
||||
}
|
||||
|
||||
if ( e.getButton() == MouseEvent.BUTTON2 ) {
|
||||
// middle/scroll button
|
||||
} else if ( e.getButton() == MouseEvent.BUTTON3 ) { // right button
|
||||
interaction = Interaction.ZOOM;
|
||||
setCursor (Cursor.getPredefinedCursor(Cursor.NE_RESIZE_CURSOR));
|
||||
} else if ( e.getButton() == MouseEvent.BUTTON1 ) { // left button
|
||||
interaction = Interaction.PAN;
|
||||
setCursor( Cursor.getPredefinedCursor( Cursor.MOVE_CURSOR));
|
||||
setCursor(Cursor.getPredefinedCursor(Cursor.NE_RESIZE_CURSOR));
|
||||
|
||||
}
|
||||
else {
|
||||
interaction = null;
|
||||
super.mousePressed(e);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void mouseDragged(MouseEvent e) {
|
||||
if ( panLast == null ) {
|
||||
if (interaction == null) {
|
||||
super.mouseDragged(e);
|
||||
return;
|
||||
}
|
||||
|
||||
if (panLast == null) {
|
||||
return;
|
||||
}
|
||||
|
||||
double dx = e.getX() - this.panLast.getX();
|
||||
double dy = e.getY() - this.panLast.getY();
|
||||
if ( dx == 0.0 && dy == 0.0 ) {
|
||||
return ;
|
||||
if (dx == 0.0 && dy == 0.0) {
|
||||
return;
|
||||
}
|
||||
double wPercent = -dx / this.panW;
|
||||
double hPercent = dy / this.panH;
|
||||
@ -117,26 +121,15 @@ public class SimulationChart extends ChartPanel {
|
||||
this.getChart().getPlot().setNotify(false);
|
||||
|
||||
switch (interaction) {
|
||||
case PAN:
|
||||
Pannable p = (Pannable) this.getChart().getPlot();
|
||||
if ( p.getOrientation() == PlotOrientation.VERTICAL){
|
||||
p.panDomainAxes( wPercent, this.getChartRenderingInfo().getPlotInfo(),panLast);
|
||||
p.panRangeAxes( hPercent, this.getChartRenderingInfo().getPlotInfo(),panLast);
|
||||
} else {
|
||||
p.panDomainAxes( hPercent, this.getChartRenderingInfo().getPlotInfo(),panLast);
|
||||
p.panRangeAxes( wPercent, this.getChartRenderingInfo().getPlotInfo(),panLast);
|
||||
}
|
||||
|
||||
break;
|
||||
case ZOOM:
|
||||
Zoomable pz = (Zoomable) this.getChart().getPlot();
|
||||
|
||||
double zoomx = 1 + 2*wPercent;
|
||||
double zoomy = 1 + 2*hPercent;
|
||||
double zoomx = 1 + 2 * wPercent;
|
||||
double zoomy = 1 + 2 * hPercent;
|
||||
|
||||
Point2D anchor = SimulationChart.this.translateScreenToJava2D(startPoint);
|
||||
|
||||
if ( pz.getOrientation() == PlotOrientation.VERTICAL) {
|
||||
if (pz.getOrientation() == PlotOrientation.VERTICAL) {
|
||||
pz.zoomDomainAxes(zoomx, this.getChartRenderingInfo().getPlotInfo(), anchor, true);
|
||||
pz.zoomRangeAxes(zoomy, this.getChartRenderingInfo().getPlotInfo(), anchor, true);
|
||||
} else {
|
||||
@ -154,10 +147,16 @@ public class SimulationChart extends ChartPanel {
|
||||
|
||||
@Override
|
||||
public void mouseReleased(MouseEvent e) {
|
||||
if ( this.panLast != null ) {
|
||||
if (interaction == null) {
|
||||
super.mouseReleased(e);
|
||||
return;
|
||||
}
|
||||
|
||||
if (this.panLast != null) {
|
||||
this.panLast = null;
|
||||
setCursor(Cursor.getDefaultCursor());
|
||||
}
|
||||
interaction = null;
|
||||
}
|
||||
|
||||
|
||||
@ -257,8 +256,8 @@ public class SimulationChart extends ChartPanel {
|
||||
if (SimulationChart.this.isDomainZoomable()) {
|
||||
zoomable.zoomDomainAxes(zf, pinfo, p, true);
|
||||
}
|
||||
boolean domainOnly = ( e.getModifiers() & InputEvent.ALT_MASK ) != 0;
|
||||
if (SimulationChart.this.isRangeZoomable() && !domainOnly ) {
|
||||
boolean domainOnly = (e.getModifiers() & InputEvent.CTRL_MASK) != 0;
|
||||
if (SimulationChart.this.isRangeZoomable() && !domainOnly) {
|
||||
zoomable.zoomRangeAxes(zf, pinfo, p, true);
|
||||
}
|
||||
plot.setNotify(notifyState); // this generates the change event too
|
||||
|
Loading…
x
Reference in New Issue
Block a user