2 * Copyright © 2013 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.
20 import org.altusmetrum.altosuilib_1.*;
21 import org.altusmetrum.altoslib_2.*;
23 public class AltosGraphDataPoint implements AltosUIDataPoint {
27 public static final int data_height = 0;
28 public static final int data_speed = 1;
29 public static final int data_accel = 2;
30 public static final int data_temp = 3;
31 public static final int data_battery_voltage = 4;
32 public static final int data_drogue_voltage = 5;
33 public static final int data_main_voltage = 6;
34 public static final int data_rssi = 7;
35 public static final int data_state = 8;
36 public static final int data_gps_height = 9;
37 public static final int data_gps_nsat_solution = 10;
38 public static final int data_gps_nsat_view = 11;
39 public static final int data_temperature = 12;
40 public static final int data_range = 13;
41 public static final int data_distance = 14;
42 public static final int data_pressure = 15;
44 public double x() throws AltosUIDataMissing {
45 double time = state.time_since_boost();
47 throw new AltosUIDataMissing(-1);
51 public double y(int index) throws AltosUIDataMissing {
52 double y = AltosLib.MISSING;
61 y = state.acceleration();
64 y = state.temperature;
66 case data_battery_voltage:
67 y = state.battery_voltage;
69 case data_drogue_voltage:
70 y = state.apogee_voltage;
72 case data_main_voltage:
73 y = state.main_voltage;
81 case data_gps_nsat_solution:
82 if (state.gps != null)
85 case data_gps_nsat_view:
86 if (state.gps != null && state.gps.cc_gps_sat != null)
87 y = state.gps.cc_gps_sat.length;
89 case data_temperature:
90 y = state.temperature;
96 if (state.from_pad != null)
97 y = state.from_pad.distance;
100 y = state.pressure();
103 if (y == AltosLib.MISSING)
104 throw new AltosUIDataMissing(index);
108 public int id(int index) {
109 if (index == data_state) {
111 if (s < Altos.ao_flight_boost || s > Altos.ao_flight_landed)
118 public String id_name(int index) {
119 if (index == data_state)
120 return state.state_name();
124 public AltosGraphDataPoint (AltosState state) {