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.
22 import org.altusmetrum.altoslib_3.*;
24 public class AltosFlightStatsTable extends JComponent {
31 public FlightStat(GridBagLayout layout, int y, String label_text, String ... values) {
32 GridBagConstraints c = new GridBagConstraints();
33 c.insets = new Insets(Altos.tab_elt_pad, Altos.tab_elt_pad, Altos.tab_elt_pad, Altos.tab_elt_pad);
36 label = new JLabel(label_text);
37 label.setFont(Altos.label_font);
38 label.setHorizontalAlignment(SwingConstants.LEFT);
39 c.gridx = 0; c.gridy = y;
40 c.anchor = GridBagConstraints.WEST;
41 c.fill = GridBagConstraints.VERTICAL;
43 layout.setConstraints(label, c);
46 for (int j = 0; j < values.length; j++) {
47 value = new JTextField(values[j]);
48 value.setFont(Altos.value_font);
49 value.setHorizontalAlignment(SwingConstants.RIGHT);
50 c.gridx = j+1; c.gridy = y;
51 c.anchor = GridBagConstraints.EAST;
52 c.fill = GridBagConstraints.BOTH;
54 layout.setConstraints(value, c);
61 static String pos(double p, String pos, String neg) {
67 int deg = (int) Math.floor(p);
68 double min = (p - Math.floor(p)) * 60.0;
69 return String.format("%s %4d° %9.6f'", h, deg, min);
72 public AltosFlightStatsTable(AltosFlightStats stats) {
73 layout = new GridBagLayout();
77 new FlightStat(layout, y++, "Serial", String.format("%d", stats.serial));
78 new FlightStat(layout, y++, "Flight", String.format("%d", stats.flight));
79 if (stats.year != AltosLib.MISSING && stats.hour != AltosLib.MISSING)
80 new FlightStat(layout, y++, "Date/Time",
81 String.format("%04d-%02d-%02d", stats.year, stats.month, stats.day),
82 String.format("%02d:%02d:%02d UTC", stats.hour, stats.minute, stats.second));
84 if (stats.year != AltosLib.MISSING)
85 new FlightStat(layout, y++, "Date",
86 String.format("%04d-%02d-%02d", stats.year, stats.month, stats.day));
87 if (stats.hour != AltosLib.MISSING)
88 new FlightStat(layout, y++, "Time",
89 String.format("%02d:%02d:%02d UTC", stats.hour, stats.minute, stats.second));
91 new FlightStat(layout, y++, "Maximum height",
92 String.format("%5.0f m", stats.max_height),
93 String.format("%5.0f ft", AltosConvert.meters_to_feet(stats.max_height)));
94 if (stats.max_gps_height != AltosLib.MISSING) {
95 new FlightStat(layout, y++, "Maximum GPS height",
96 String.format("%5.0f m", stats.max_gps_height),
97 String.format("%5.0f ft", AltosConvert.meters_to_feet(stats.max_gps_height)));
99 new FlightStat(layout, y++, "Maximum speed",
100 String.format("%5.0f m/s", stats.max_speed),
101 String.format("%5.0f mph", AltosConvert.meters_to_mph(stats.max_speed)),
102 String.format("Mach %4.1f", AltosConvert.meters_to_mach(stats.max_speed)));
103 if (stats.max_acceleration != AltosLib.MISSING) {
104 new FlightStat(layout, y++, "Maximum boost acceleration",
105 String.format("%5.0f m/s²", stats.max_acceleration),
106 String.format("%5.0f ft/s²", AltosConvert.meters_to_feet(stats.max_acceleration)),
107 String.format("%5.0f G", AltosConvert.meters_to_g(stats.max_acceleration)));
108 new FlightStat(layout, y++, "Average boost acceleration",
109 String.format("%5.0f m/s²", stats.state_accel[Altos.ao_flight_boost]),
110 String.format("%5.0f ft/s²", AltosConvert.meters_to_feet(stats.state_accel[Altos.ao_flight_boost])),
111 String.format("%5.0f G", AltosConvert.meters_to_g(stats.state_accel[Altos.ao_flight_boost])));
113 new FlightStat(layout, y++, "Drogue descent rate",
114 String.format("%5.0f m/s", stats.state_speed[Altos.ao_flight_drogue]),
115 String.format("%5.0f ft/s", AltosConvert.meters_to_feet(stats.state_speed[Altos.ao_flight_drogue])));
116 new FlightStat(layout, y++, "Main descent rate",
117 String.format("%5.0f m/s", stats.state_speed[Altos.ao_flight_main]),
118 String.format("%5.0f ft/s", AltosConvert.meters_to_feet(stats.state_speed[Altos.ao_flight_main])));
119 new FlightStat(layout, y++, "Ascent time",
120 String.format("%6.1f s %s", stats.state_end[AltosLib.ao_flight_boost] - stats.state_start[AltosLib.ao_flight_boost],
121 AltosLib.state_name(Altos.ao_flight_boost)),
122 String.format("%6.1f s %s", stats.state_end[AltosLib.ao_flight_fast] - stats.state_start[AltosLib.ao_flight_fast],
123 AltosLib.state_name(Altos.ao_flight_fast)),
124 String.format("%6.1f s %s", stats.state_end[AltosLib.ao_flight_coast] - stats.state_start[AltosLib.ao_flight_coast],
125 AltosLib.state_name(Altos.ao_flight_coast)));
126 new FlightStat(layout, y++, "Descent time",
127 String.format("%6.1f s %s", stats.state_end[AltosLib.ao_flight_drogue] - stats.state_start[AltosLib.ao_flight_drogue],
128 AltosLib.state_name(Altos.ao_flight_drogue)),
129 String.format("%6.1f s %s", stats.state_end[AltosLib.ao_flight_main] - stats.state_start[AltosLib.ao_flight_main],
130 AltosLib.state_name(Altos.ao_flight_main)));
131 new FlightStat(layout, y++, "Flight time",
132 String.format("%6.1f s", stats.state_end[Altos.ao_flight_main] -
133 stats.state_start[Altos.ao_flight_boost]));
135 new FlightStat(layout, y++, "Pad location",
136 pos(stats.pad_lat,"N","S"),
137 pos(stats.pad_lon,"E","W"));
138 new FlightStat(layout, y++, "Last reported location",
139 pos(stats.lat,"N","S"),
140 pos(stats.lon,"E","W"));