void fill_map(AltosFlightSeries flight_series) {
boolean any_gps = false;
-
- for (AltosGPSTimeValue gtv : flight_series.gps_series) {
- AltosGPS gps = gtv.gps;
- if (gps != null &&
- gps.locked &&
- gps.nsat >= 4) {
- if (map == null)
- map = new AltosUIMap();
- map.show(gps, AltosLib.ao_flight_pad);
- this.gps = gps;
- has_gps = true;
+ AltosGPSTimeValue gtv_last = null;
+
+ if (flight_series.gps_series != null) {
+ for (AltosGPSTimeValue gtv : flight_series.gps_series) {
+ gtv_last = gtv;
+ AltosGPS gps = gtv.gps;
+ if (gps != null &&
+ gps.locked &&
+ gps.nsat >= 4) {
+ if (map == null)
+ map = new AltosUIMap();
+ map.show(gps, (int) flight_series.value_before(AltosFlightSeries.state_name, gtv.time));
+ this.gps = gps;
+ has_gps = true;
+ }
}
}
+ if (gtv_last != null) {
+ int state = (int) flight_series.value_after(AltosFlightSeries.state_name, gtv_last.time);
+ if (state == AltosLib.ao_flight_landed)
+ map.show(gtv_last.gps, state);
+ }
}
public void font_size_changed(int font_size) {
set.capture_series(flight_series);
- flight_series.fill_in();
+ flight_series.finish();
stats = new AltosFlightStats(flight_series);
- graph = new AltosGraphNew(enable, stats, flight_series, cal_data);
+ graph = new AltosGraphNew(enable, stats, flight_series);
statsTable = new AltosFlightStatsTable(stats);