JTextField value;
AltosLights lights;
+ void show() {
+ value.setVisible(true);
+ lights.setVisible(true);
+ label.setVisible(true);
+ }
+
+ void hide() {
+ value.setVisible(false);
+ lights.setVisible(false);
+ label.setVisible(false);
+ }
+
void show(AltosState state, int crc_errors) {}
void reset() {
value.setText("");
void reset() {
value.setText("");
max_value.setText("");
- max = 0;
+ max = AltosRecord.MISSING;
}
void show(String format, double v) {
- value.setText(String.format(format, v));
- if (v > max) {
- max_value.setText(String.format(format, v));
- max = v;
+ if (v == AltosRecord.MISSING) {
+ value.setText("Missing");
+ max_value.setText("Missing");
+ } else {
+ value.setText(String.format(format, v));
+ if (v > max || max == AltosRecord.MISSING) {
+ max_value.setText(String.format(format, v));
+ max = v;
+ }
}
}
public AscentValueHold (GridBagLayout layout, int y, String text) {
class Apogee extends AscentStatus {
void show (AltosState state, int crc_errors) {
+ show();
value.setText(String.format("%4.2f V", state.drogue_sense));
lights.set(state.drogue_sense > 3.2);
}
class Main extends AscentStatus {
void show (AltosState state, int crc_errors) {
+ show();
value.setText(String.format("%4.2f V", state.main_sense));
lights.set(state.main_sense > 3.2);
}
}
public void show(AltosState state, int crc_errors) {
- if (state.gps != null) {
+ if (state.gps != null && state.gps.connected) {
lat.show(state, crc_errors);
lon.show(state, crc_errors);
} else {
lon.hide();
}
height.show(state, crc_errors);
- main.show(state, crc_errors);
- apogee.show(state, crc_errors);
+ if (state.main_sense != AltosRecord.MISSING)
+ main.show(state, crc_errors);
+ else
+ main.hide();
+ if (state.drogue_sense != AltosRecord.MISSING)
+ apogee.show(state, crc_errors);
+ else
+ apogee.hide();
speed.show(state, crc_errors);
accel.show(state, crc_errors);
}
class Lat extends DescentValue {
void show (AltosState state, int crc_errors) {
- if (state.gps != null)
+ if (state.gps != null && state.gps.connected)
show(pos(state.gps.lat,"N", "S"));
else
show("???");
class Lon extends DescentValue {
void show (AltosState state, int crc_errors) {
- if (state.gps != null)
+ if (state.gps != null && state.gps.connected)
show(pos(state.gps.lon,"W", "E"));
else
show("???");
class Apogee extends DescentStatus {
void show (AltosState state, int crc_errors) {
+ show();
value.setText(String.format("%4.2f V", state.drogue_sense));
lights.set(state.drogue_sense > 3.2);
}
public void show(AltosState state, int crc_errors) {
height.show(state, crc_errors);
speed.show(state, crc_errors);
- if (state.gps != null) {
+ if (state.gps != null && state.gps.connected) {
bearing.show(state, crc_errors);
range.show(state, crc_errors);
elevation.show(state, crc_errors);
lat.hide();
lon.hide();
}
- main.show(state, crc_errors);
- apogee.show(state, crc_errors);
+ if (state.main_sense != AltosRecord.MISSING)
+ main.show(state, crc_errors);
+ else
+ main.hide();
+ if (state.drogue_sense != AltosRecord.MISSING)
+ apogee.show(state, crc_errors);
+ else
+ apogee.hide();
}
public AltosDescent() {
// Telemetry format menu
telemetries = new JComboBox();
- telemetries.addItem("Legacy TeleMetrum");
- telemetries.addItem("Split Telemetry");
+ telemetries.addItem("Original TeleMetrum Telemetry");
+ telemetries.addItem("Standard AltOS Telemetry");
int telemetry = 1;
telemetry = AltosPreferences.telemetry(serial);
if (telemetry > Altos.ao_telemetry_split)
info_add_row(0, "Max Speed", "%8.1f m/s", state.max_speed);
info_add_row(0, "Temperature", "%9.2f °C", state.temperature);
info_add_row(0, "Battery", "%9.2f V", state.battery);
- info_add_row(0, "Drogue", "%9.2f V", state.drogue_sense);
- info_add_row(0, "Main", "%9.2f V", state.main_sense);
+ if (state.drogue_sense != AltosRecord.MISSING)
+ info_add_row(0, "Drogue", "%9.2f V", state.drogue_sense);
+ if (state.main_sense != AltosRecord.MISSING)
+ info_add_row(0, "Main", "%9.2f V", state.main_sense);
info_add_row(0, "Pad altitude", "%6.0f m", state.ground_altitude);
- if (state.gps == null) {
+ if (state.gps == null || !state.gps.connected) {
info_add_row(1, "GPS", "not available");
} else {
if (state.gps_ready)
class Lat extends LandedValue {
void show (AltosState state, int crc_errors) {
show();
- if (state.gps != null)
+ if (state.gps != null && state.gps.connected)
value.setText(pos(state.gps.lat,"N", "S"));
else
value.setText("???");
class Lon extends LandedValue {
void show (AltosState state, int crc_errors) {
show();
- if (state.gps != null)
+ if (state.gps != null && state.gps.connected)
value.setText(pos(state.gps.lon,"E", "W"));
else
value.setText("???");
}
public void show(AltosState state, int crc_errors) {
- if (state.gps != null) {
+ if (state.gps != null && state.gps.connected) {
bearing.show(state, crc_errors);
distance.show(state, crc_errors);
lat.show(state, crc_errors);
class Apogee extends LaunchStatus {
void show (AltosState state, int crc_errors) {
+ show();
value.setText(String.format("%4.2f V", state.drogue_sense));
lights.set(state.drogue_sense > 3.2);
}
class Main extends LaunchStatus {
void show (AltosState state, int crc_errors) {
+ show();
value.setText(String.format("%4.2f V", state.main_sense));
lights.set(state.main_sense > 3.2);
}
public void show(AltosState state, int crc_errors) {
battery.show(state, crc_errors);
- apogee.show(state, crc_errors);
- main.show(state, crc_errors);
+ if (state.drogue_sense == AltosRecord.MISSING)
+ apogee.hide();
+ else
+ apogee.show(state, crc_errors);
+ if (state.main_sense == AltosRecord.MISSING)
+ main.hide();
+ else
+ main.show(state, crc_errors);
pad_alt.show(state, crc_errors);
- if (state.gps != null) {
+ if (state.gps != null && state.gps.connected) {
gps_locked.show(state, crc_errors);
gps_ready.show(state, crc_errors);
pad_lat.show(state, crc_errors);