1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
|
/*
* Copyright © 2012 Keith Packard <keithp@keithp.com>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; version 2 of the License.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
*/
package org.altusmetrum.micropeak;
import java.io.*;
import java.util.ArrayList;
import java.awt.*;
import javax.swing.*;
import org.altusmetrum.AltosLib.*;
import org.jfree.ui.*;
import org.jfree.chart.*;
import org.jfree.chart.plot.*;
import org.jfree.chart.axis.*;
import org.jfree.chart.renderer.*;
import org.jfree.chart.renderer.xy.*;
import org.jfree.chart.labels.*;
import org.jfree.data.xy.*;
import org.jfree.data.*;
public class MicroGraph {
XYPlot plot;
JFreeChart chart;
ChartPanel panel;
NumberAxis xAxis;
XYSeries heightSeries;
XYSeries speedSeries;
XYSeries accelSeries;
MicroData data;
public JPanel panel() {
return panel;
}
private void addSeries(XYSeries series, int index, String label, String units) {
XYSeriesCollection dataset = new XYSeriesCollection(series);
NumberAxis axis = new NumberAxis(String.format("%s (%s)", label, units));
XYItemRenderer renderer = new XYLineAndShapeRenderer(true, false);
renderer.setPlot(plot);
renderer.setBaseToolTipGenerator(new StandardXYToolTipGenerator(String.format("{1}s: {2}%s ({0})", units),
new java.text.DecimalFormat("0.00"),
new java.text.DecimalFormat("0.00")));
plot.setRangeAxis(index, axis);
plot.setDataset(index, dataset);
plot.setRenderer(index, renderer);
plot.mapDatasetToRangeAxis(index, index);
}
public void setData (MicroData data) {
heightSeries.clear();
speedSeries.clear();
accelSeries.clear();
for (int i = 0; i < data.pressures.length; i++) {
double x = data.time(i);
heightSeries.add(x, data.height(i));
speedSeries.add(x, data.speed(i));
accelSeries.add(x, data.acceleration(i));
}
}
public MicroGraph(MicroData data) {
this.data = data;
heightSeries = new XYSeries("Height");
speedSeries = new XYSeries("Speed");
accelSeries = new XYSeries("Acceleration");
xAxis = new NumberAxis("Time (s)");
xAxis.setAutoRangeIncludesZero(true);
plot = new XYPlot();
plot.setDomainAxis(xAxis);
plot.setOrientation(PlotOrientation.VERTICAL);
plot.setDomainPannable(true);
plot.setRangePannable(true);
addSeries(heightSeries, 0, "Height", "m");
addSeries(speedSeries, 1, "Speed", "m/s");
addSeries(accelSeries, 2, "Acceleration", "m/s²");
chart = new JFreeChart("Flight", JFreeChart.DEFAULT_TITLE_FONT,
plot, true);
ChartUtilities.applyCurrentTheme(chart);
panel = new ChartPanel(chart);
panel.setMouseWheelEnabled(true);
panel.setPreferredSize(new java.awt.Dimension(800, 500));
}
}
|