Merge branch 'buttonbox' into sitemap
authorAnthony Towns <aj@erisian.com.au>
Sat, 20 Nov 2010 22:56:13 +0000 (08:56 +1000)
committerAnthony Towns <aj@erisian.com.au>
Sat, 20 Nov 2010 22:56:13 +0000 (08:56 +1000)
ao-tools/altosui/AltosAscent.java
ao-tools/altosui/AltosDescent.java
ao-tools/altosui/AltosLanded.java
ao-tools/altosui/AltosPad.java

index 38ced95eeb3593712a734b643f716e09fa1fed9c..2ceaa183b1ca1fa49c0f3173d87376041aa8385f 100644 (file)
@@ -65,10 +65,11 @@ public class AltosAscent extends JComponent implements AltosFlightDisplay {
                        layout.setConstraints(label, c);
                        add(label);
 
-                       value = new JTextField(15);
+                       value = new JTextField(17);
                        value.setFont(Altos.value_font);
                        value.setHorizontalAlignment(SwingConstants.RIGHT);
                        c.gridx = 2; c.gridy = y;
+                       c.gridwidth = 2;
                        c.anchor = GridBagConstraints.WEST;
                        c.fill = GridBagConstraints.BOTH;
                        c.weightx = 1;
@@ -93,7 +94,7 @@ public class AltosAscent extends JComponent implements AltosFlightDisplay {
                        label = new JLabel(text);
                        label.setFont(Altos.label_font);
                        label.setHorizontalAlignment(SwingConstants.LEFT);
-                       c.gridx = 0; c.gridy = y;
+                       c.gridx = 1; c.gridy = y;
                        c.insets = new Insets(Altos.tab_elt_pad, Altos.tab_elt_pad, Altos.tab_elt_pad, Altos.tab_elt_pad);
                        c.anchor = GridBagConstraints.WEST;
                        c.fill = GridBagConstraints.VERTICAL;
@@ -101,10 +102,10 @@ public class AltosAscent extends JComponent implements AltosFlightDisplay {
                        layout.setConstraints(label, c);
                        add(label);
 
-                       value = new JTextField(30);
+                       value = new JTextField(17);
                        value.setFont(Altos.value_font);
                        value.setHorizontalAlignment(SwingConstants.RIGHT);
-                       c.gridx = 1; c.gridy = y;
+                       c.gridx = 2; c.gridy = y;
                        c.anchor = GridBagConstraints.WEST;
                        c.fill = GridBagConstraints.BOTH;
                        c.gridwidth = 2;
@@ -142,7 +143,7 @@ public class AltosAscent extends JComponent implements AltosFlightDisplay {
                        label = new JLabel(text);
                        label.setFont(Altos.label_font);
                        label.setHorizontalAlignment(SwingConstants.LEFT);
-                       c.gridx = 0; c.gridy = y;
+                       c.gridx = 1; c.gridy = y;
                        c.insets = new Insets(Altos.tab_elt_pad, Altos.tab_elt_pad, Altos.tab_elt_pad, Altos.tab_elt_pad);
                        c.anchor = GridBagConstraints.WEST;
                        c.fill = GridBagConstraints.VERTICAL;
@@ -150,20 +151,20 @@ public class AltosAscent extends JComponent implements AltosFlightDisplay {
                        layout.setConstraints(label, c);
                        add(label);
 
-                       value = new JTextField(15);
+                       value = new JTextField(17);
                        value.setFont(Altos.value_font);
                        value.setHorizontalAlignment(SwingConstants.RIGHT);
-                       c.gridx = 1; c.gridy = y;
+                       c.gridx = 2; c.gridy = y;
                        c.anchor = GridBagConstraints.EAST;
                        c.fill = GridBagConstraints.BOTH;
                        c.weightx = 1;
                        layout.setConstraints(value, c);
                        add(value);
 
-                       max_value = new JTextField(15);
+                       max_value = new JTextField(17);
                        max_value.setFont(Altos.value_font);
                        max_value.setHorizontalAlignment(SwingConstants.RIGHT);
-                       c.gridx = 2; c.gridy = y;
+                       c.gridx = 3; c.gridy = y;
                        c.anchor = GridBagConstraints.EAST;
                        c.fill = GridBagConstraints.BOTH;
                        c.weightx = 1;
@@ -299,14 +300,14 @@ public class AltosAscent extends JComponent implements AltosFlightDisplay {
                cur = new JLabel("Current");
                cur.setFont(Altos.label_font);
                c = new GridBagConstraints();
-               c.gridx = 1; c.gridy = y;
+               c.gridx = 2; c.gridy = y;
                c.insets = new Insets(Altos.tab_elt_pad, Altos.tab_elt_pad, Altos.tab_elt_pad, Altos.tab_elt_pad);
                layout.setConstraints(cur, c);
                add(cur);
 
                max = new JLabel("Maximum");
                max.setFont(Altos.label_font);
-               c.gridx = 2; c.gridy = y;
+               c.gridx = 3; c.gridy = y;
                layout.setConstraints(max, c);
                add(max);
        }
index aacd2998dc4b0cf09c0ceaebd075b59d08cb025f..abe64fdcc6772bc6e579555b5f86b3c403ef9b9c 100644 (file)
@@ -31,12 +31,12 @@ import java.util.concurrent.LinkedBlockingQueue;
 public class AltosDescent extends JComponent implements AltosFlightDisplay {
        GridBagLayout   layout;
 
-       public class DescentStatus {
+       public abstract class DescentStatus {
                JLabel          label;
                JTextField      value;
                AltosLights     lights;
 
-               void show(AltosState state, int crc_errors) {}
+               abstract void show(AltosState state, int crc_errors);
                void reset() {
                        value.setText("");
                        lights.set(false);
@@ -61,14 +61,16 @@ public class AltosDescent extends JComponent implements AltosFlightDisplay {
                        c.insets = new Insets(Altos.tab_elt_pad, Altos.tab_elt_pad, Altos.tab_elt_pad, Altos.tab_elt_pad);
                        c.anchor = GridBagConstraints.WEST;
                        c.fill = GridBagConstraints.VERTICAL;
+                       c.gridwidth = 3;
                        c.weightx = 0;
                        layout.setConstraints(label, c);
                        add(label);
 
-                       value = new JTextField(15);
+                       value = new JTextField(17);
                        value.setFont(Altos.value_font);
                        value.setHorizontalAlignment(SwingConstants.RIGHT);
-                       c.gridx = 2; c.gridy = y;
+                       c.gridx = 4; c.gridy = y;
+                       c.gridwidth = 1;
                        c.anchor = GridBagConstraints.WEST;
                        c.fill = GridBagConstraints.BOTH;
                        c.weightx = 1;
@@ -77,19 +79,25 @@ public class AltosDescent extends JComponent implements AltosFlightDisplay {
 
                }
        }
-       public class DescentValue {
+
+       public abstract class DescentValue {
                JLabel          label;
                JTextField      value;
-               void show(AltosState state, int crc_errors) {}
 
                void reset() {
                        value.setText("");
                }
 
+               abstract void show(AltosState state, int crc_errors);
+
                void show(String format, double v) {
                        value.setText(String.format(format, v));
                }
 
+               void show(String v) {
+                       value.setText(v);
+               }
+
                public DescentValue (GridBagLayout layout, int x, int y, String text) {
                        GridBagConstraints      c = new GridBagConstraints();
                        c.weighty = 1;
@@ -97,23 +105,80 @@ public class AltosDescent extends JComponent implements AltosFlightDisplay {
                        label = new JLabel(text);
                        label.setFont(Altos.label_font);
                        label.setHorizontalAlignment(SwingConstants.LEFT);
-                       c.gridx = x + 0; c.gridy = y;
+                       c.gridx = x + 1; c.gridy = y;
                        c.insets = new Insets(Altos.tab_elt_pad, Altos.tab_elt_pad, Altos.tab_elt_pad, Altos.tab_elt_pad);
                        c.anchor = GridBagConstraints.WEST;
                        c.fill = GridBagConstraints.VERTICAL;
                        c.weightx = 0;
-                       layout.setConstraints(label, c);
-                       add(label);
+                       add(label, c);
 
                        value = new JTextField(17);
                        value.setFont(Altos.value_font);
                        value.setHorizontalAlignment(SwingConstants.RIGHT);
+                       c.gridx = x + 2; c.gridy = y;
+                       c.gridwidth = 1;
+                       c.anchor = GridBagConstraints.WEST;
+                       c.fill = GridBagConstraints.BOTH;
+                       c.weightx = 1;
+                       add(value, c);
+               }
+       }
+
+       public abstract class DescentDualValue {
+               JLabel          label;
+               JTextField      value1;
+               JTextField      value2;
+
+               void reset() {
+                       value1.setText("");
+                       value2.setText("");
+               }
+
+               abstract void show(AltosState state, int crc_errors);
+               void show(String v1, String v2) {
+                       value1.setText(v1);
+                       value2.setText(v2);
+               }
+               void show(String f1, double v1, String f2, double v2) {
+                       value1.setText(String.format(f1, v1));
+                       value2.setText(String.format(f2, v2));
+               }
+
+               public DescentDualValue (GridBagLayout layout, int x, int y, String text) {
+                       GridBagConstraints      c = new GridBagConstraints();
+                       c.weighty = 1;
+
+                       label = new JLabel(text);
+                       label.setFont(Altos.label_font);
+                       label.setHorizontalAlignment(SwingConstants.LEFT);
                        c.gridx = x + 1; c.gridy = y;
+                       c.insets = new Insets(Altos.tab_elt_pad, Altos.tab_elt_pad, Altos.tab_elt_pad, Altos.tab_elt_pad);
+                       c.anchor = GridBagConstraints.WEST;
+                       c.fill = GridBagConstraints.VERTICAL;
+                       c.weightx = 0;
+                       layout.setConstraints(label, c);
+                       add(label);
+
+                       value1 = new JTextField(17);
+                       value1.setFont(Altos.value_font);
+                       value1.setHorizontalAlignment(SwingConstants.RIGHT);
+                       c.gridx = x + 2; c.gridy = y;
                        c.anchor = GridBagConstraints.WEST;
                        c.fill = GridBagConstraints.BOTH;
                        c.weightx = 1;
-                       layout.setConstraints(value, c);
-                       add(value);
+                       layout.setConstraints(value1, c);
+                       add(value1);
+
+                       value2 = new JTextField(17);
+                       value2.setFont(Altos.value_font);
+                       value2.setHorizontalAlignment(SwingConstants.RIGHT);
+                       c.gridx = x + 4; c.gridy = y;
+                       c.anchor = GridBagConstraints.WEST;
+                       c.fill = GridBagConstraints.BOTH;
+                       c.weightx = 1;
+                       c.gridwidth = 1;
+                       layout.setConstraints(value2, c);
+                       add(value2);
                }
        }
 
@@ -150,15 +215,15 @@ public class AltosDescent extends JComponent implements AltosFlightDisplay {
                }
                int deg = (int) Math.floor(p);
                double min = (p - Math.floor(p)) * 60.0;
-               return String.format("%s %4d° %9.6f", h, deg, min);
+               return String.format("%s %d° %9.6f", h, deg, min);
        }
 
        class Lat extends DescentValue {
                void show (AltosState state, int crc_errors) {
                        if (state.gps != null)
-                               value.setText(pos(state.gps.lat,"N", "S"));
+                               show(pos(state.gps.lat,"N", "S"));
                        else
-                               value.setText("???");
+                               show("???");
                }
                public Lat (GridBagLayout layout, int x, int y) {
                        super (layout, x, y, "Latitude");
@@ -170,9 +235,9 @@ public class AltosDescent extends JComponent implements AltosFlightDisplay {
        class Lon extends DescentValue {
                void show (AltosState state, int crc_errors) {
                        if (state.gps != null)
-                               value.setText(pos(state.gps.lon,"E", "W"));
+                               show(pos(state.gps.lon,"W", "E"));
                        else
-                               value.setText("???");
+                               show("???");
                }
                public Lon (GridBagLayout layout, int x, int y) {
                        super (layout, x, y, "Longitude");
@@ -205,88 +270,44 @@ public class AltosDescent extends JComponent implements AltosFlightDisplay {
 
        Main main;
 
-       class Bearing {
-               JLabel          label;
-               JTextField      value;
-               JTextField      value_deg;
-               void reset () {
-                       value.setText("");
-                       value_deg.setText("");
-               }
+       class Bearing extends DescentDualValue {
                void show (AltosState state, int crc_errors) {
                        if (state.from_pad != null) {
-                               value.setText(state.from_pad.bearing_words(
-                                                     AltosGreatCircle.BEARING_LONG));
-                               value_deg.setText(String.format("%3.0f°", state.from_pad.bearing));
+                               show( String.format("%3.0f°", state.from_pad.bearing),
+                                     state.from_pad.bearing_words(
+                                             AltosGreatCircle.BEARING_LONG));
                        } else {
-                               value.setText("???");
-                               value_deg.setText("???");
+                               show("???", "???");
                        }
                }
                public Bearing (GridBagLayout layout, int x, int y) {
-                       GridBagConstraints      c = new GridBagConstraints();
-                       c.weighty = 1;
-
-                       label = new JLabel("Bearing");
-                       label.setFont(Altos.label_font);
-                       label.setHorizontalAlignment(SwingConstants.LEFT);
-                       c.gridx = x + 0; c.gridy = y;
-                       c.insets = new Insets(Altos.tab_elt_pad, Altos.tab_elt_pad, Altos.tab_elt_pad, Altos.tab_elt_pad);
-                       c.anchor = GridBagConstraints.WEST;
-                       c.weightx = 0;
-                       c.fill = GridBagConstraints.VERTICAL;
-                       layout.setConstraints(label, c);
-                       add(label);
-
-                       value = new JTextField(30);
-                       value.setFont(Altos.value_font);
-                       value.setHorizontalAlignment(SwingConstants.RIGHT);
-                       c.gridx = x + 1; c.gridy = y;
-                       c.anchor = GridBagConstraints.EAST;
-                       c.weightx = 1;
-                       c.gridwidth = 2;
-                       c.fill = GridBagConstraints.BOTH;
-                       layout.setConstraints(value, c);
-                       add(value);
-
-                       value_deg = new JTextField(5);
-                       value_deg.setFont(Altos.value_font);
-                       value_deg.setHorizontalAlignment(SwingConstants.RIGHT);
-                       c.gridx = x + 3; c.gridy = y;
-                       c.anchor = GridBagConstraints.EAST;
-                       c.weightx = 1;
-                       c.fill = GridBagConstraints.BOTH;
-                       layout.setConstraints(value_deg, c);
-                       add(value_deg);
+                       super (layout, x, y, "Bearing");
                }
        }
 
        Bearing bearing;
 
-       class Elevation extends DescentValue {
+       class Range extends DescentValue {
                void show (AltosState state, int crc_errors) {
-                       if (state.from_pad != null)
-                               show("%3.0f°", state.elevation);
-                       else
-                               value.setText("???");
+                       show("%6.0f m", state.range);
                }
-               public Elevation (GridBagLayout layout, int x, int y) {
-                       super (layout, x, y, "Elevation");
+               public Range (GridBagLayout layout, int x, int y) {
+                       super (layout, x, y, "Range");
                }
        }
 
-       Elevation elevation;
+       Range range;
 
-       class Range extends DescentValue {
+       class Elevation extends DescentValue {
                void show (AltosState state, int crc_errors) {
-                       show("%6.0f m", state.range);
+                       show("%3.0f°", state.elevation);
                }
-               public Range (GridBagLayout layout, int x, int y) {
-                       super (layout, x, y, "Range");
+               public Elevation (GridBagLayout layout, int x, int y) {
+                       super (layout, x, y, "Elevation");
                }
        }
 
-       Range range;
+       Elevation elevation;
 
        public void reset() {
                lat.reset();
@@ -294,8 +315,8 @@ public class AltosDescent extends JComponent implements AltosFlightDisplay {
                height.reset();
                speed.reset();
                bearing.reset();
-               elevation.reset();
                range.reset();
+               elevation.reset();
                main.reset();
                apogee.reset();
        }
@@ -304,8 +325,8 @@ public class AltosDescent extends JComponent implements AltosFlightDisplay {
                height.show(state, crc_errors);
                speed.show(state, crc_errors);
                bearing.show(state, crc_errors);
-               elevation.show(state, crc_errors);
                range.show(state, crc_errors);
+               elevation.show(state, crc_errors);
                lat.show(state, crc_errors);
                lon.show(state, crc_errors);
                main.show(state, crc_errors);
@@ -318,12 +339,15 @@ public class AltosDescent extends JComponent implements AltosFlightDisplay {
                setLayout(layout);
 
                /* Elements in descent display */
-               speed = new Speed(layout, 0, 0);        height = new Height(layout, 2, 0);
-               elevation = new Elevation(layout, 0, 1); range = new Range(layout, 2, 1);
+               speed = new Speed(layout, 0, 0);
+               height = new Height(layout, 2, 0);
+               elevation = new Elevation(layout, 0, 1);
+               range = new Range(layout, 2, 1);
                bearing = new Bearing(layout, 0, 2);
                lat = new Lat(layout, 0, 3);
-               lon = new Lon(layout, 0, 4);
-               apogee = new Apogee(layout, 5);
-               main = new Main(layout, 6);
+               lon = new Lon(layout, 2, 3);
+
+               apogee = new Apogee(layout, 4);
+               main = new Main(layout, 5);
        }
 }
index 0656ea6cfda717c857cfd6b9c5f42b6d18d65d91..059dbb6dcf91ab2d50bbf5b8a027e8476e308a87 100644 (file)
@@ -61,7 +61,7 @@ public class AltosLanded extends JComponent implements AltosFlightDisplay {
                        layout.setConstraints(label, c);
                        add(label);
 
-                       value = new JTextField(30);
+                       value = new JTextField(17);
                        value.setFont(value_font);
                        value.setHorizontalAlignment(SwingConstants.RIGHT);
                        c.gridx = 1; c.gridy = y;
index 77289f896a039126d3f008e2673af851e85ed692..480e4d79f81aa73778ec665b75dd6d4e5eca7632 100644 (file)
@@ -65,7 +65,7 @@ public class AltosPad extends JComponent implements AltosFlightDisplay {
                        layout.setConstraints(label, c);
                        add(label);
 
-                       value = new JTextField(15);
+                       value = new JTextField(17);
                        value.setFont(Altos.value_font);
                        value.setHorizontalAlignment(SwingConstants.RIGHT);
                        c.gridx = 2; c.gridy = y;
@@ -101,7 +101,7 @@ public class AltosPad extends JComponent implements AltosFlightDisplay {
                        layout.setConstraints(label, c);
                        add(label);
 
-                       value = new JTextField(30);
+                       value = new JTextField(17);
                        value.setFont(Altos.value_font);
                        value.setHorizontalAlignment(SwingConstants.RIGHT);
                        c.gridx = 2; c.gridy = y;