2 * Copyright © 2011 Keith Packard <keithp@keithp.com>
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation; version 2 of the License.
8 * This program is distributed in the hope that it will be useful, but
9 * WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11 * General Public License for more details.
13 * You should have received a copy of the GNU General Public License along
14 * with this program; if not, write to the Free Software Foundation, Inc.,
15 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
21 import java.awt.event.*;
23 import javax.swing.filechooser.FileNameExtensionFilter;
24 import javax.swing.table.*;
28 import java.util.prefs.*;
29 import java.util.concurrent.*;
30 import org.altusmetrum.AltosLib.*;
32 public class AltosFlightStatsTable extends JComponent {
39 public FlightStat(GridBagLayout layout, int y, String label_text, String ... values) {
40 GridBagConstraints c = new GridBagConstraints();
41 c.insets = new Insets(Altos.tab_elt_pad, Altos.tab_elt_pad, Altos.tab_elt_pad, Altos.tab_elt_pad);
44 label = new JLabel(label_text);
45 label.setFont(Altos.label_font);
46 label.setHorizontalAlignment(SwingConstants.LEFT);
47 c.gridx = 0; c.gridy = y;
48 c.anchor = GridBagConstraints.WEST;
49 c.fill = GridBagConstraints.VERTICAL;
51 layout.setConstraints(label, c);
54 for (int j = 0; j < values.length; j++) {
55 value = new JTextField(values[j]);
56 value.setFont(Altos.value_font);
57 value.setHorizontalAlignment(SwingConstants.RIGHT);
58 c.gridx = j+1; c.gridy = y;
59 c.anchor = GridBagConstraints.EAST;
60 c.fill = GridBagConstraints.BOTH;
62 layout.setConstraints(value, c);
69 public AltosFlightStatsTable(AltosFlightStats stats) {
70 layout = new GridBagLayout();
74 new FlightStat(layout, y++, "Serial", String.format("%d", stats.serial));
75 new FlightStat(layout, y++, "Flight", String.format("%d", stats.flight));
77 new FlightStat(layout, y++, "Date",
78 String.format("%04d-%02d-%02d", stats.year, stats.month, stats.day));
80 new FlightStat(layout, y++, "Time",
81 String.format("%02d:%02d:%02d UTC", stats.hour, stats.minute, stats.second));
82 new FlightStat(layout, y++, "Maximum height",
83 String.format("%5.0f m", stats.max_height),
84 String.format("%5.0f ft", AltosConvert.meters_to_feet(stats.max_height)));
85 new FlightStat(layout, y++, "Maximum speed",
86 String.format("%5.0f m/s", stats.max_speed),
87 String.format("%5.0f ft/s", AltosConvert.meters_to_feet(stats.max_speed)),
88 String.format("Mach %5.3f", AltosConvert.meters_to_mach(stats.max_speed)));
89 if (stats.max_acceleration != AltosRecord.MISSING) {
90 new FlightStat(layout, y++, "Maximum boost acceleration",
91 String.format("%5.0f m/s²", stats.max_acceleration),
92 String.format("%5.0f ft/s²", AltosConvert.meters_to_feet(stats.max_acceleration)),
93 String.format("%5.2f G", AltosConvert.meters_to_g(stats.max_acceleration)));
94 new FlightStat(layout, y++, "Average boost acceleration",
95 String.format("%5.0f m/s²", stats.state_accel[Altos.ao_flight_boost]),
96 String.format("%5.0f ft/s²", AltosConvert.meters_to_feet(stats.state_accel[Altos.ao_flight_boost])),
97 String.format("%5.2f G", AltosConvert.meters_to_g(stats.state_accel[Altos.ao_flight_boost])));
99 new FlightStat(layout, y++, "Drogue descent rate",
100 String.format("%5.0f m/s", stats.state_baro_speed[Altos.ao_flight_drogue]),
101 String.format("%5.0f ft/s", AltosConvert.meters_to_feet(stats.state_baro_speed[Altos.ao_flight_drogue])));
102 new FlightStat(layout, y++, "Main descent rate",
103 String.format("%5.0f m/s", stats.state_baro_speed[Altos.ao_flight_main]),
104 String.format("%5.0f ft/s", AltosConvert.meters_to_feet(stats.state_baro_speed[Altos.ao_flight_main])));
105 for (int s = Altos.ao_flight_boost; s <= Altos.ao_flight_main; s++) {
106 new FlightStat(layout, y++, String.format("%s time", AltosLib.state_name_capital(s)),
107 String.format("%6.2f s", stats.state_end[s] - stats.state_start[s]));
109 new FlightStat(layout, y++, "Flight Time",
110 String.format("%6.2f s", stats.state_end[Altos.ao_flight_main] -
111 stats.state_start[Altos.ao_flight_boost]));