altoslib: Create AltosProgrammer class
[fw/altos] / altosui / AltosGraphUI.java
index b376f7de69ee29d4adea4d1d46e56b003bd21af9..c42f7b5f89d4f346517fad948c5b3ec6a86229d4 100644 (file)
@@ -9,7 +9,7 @@ import java.util.ArrayList;
 
 import java.awt.*;
 import javax.swing.*;
-import org.altusmetrum.altoslib_1.*;
+import org.altusmetrum.altoslib_2.*;
 import org.altusmetrum.altosuilib_1.*;
 
 import org.jfree.chart.ChartPanel;
@@ -21,21 +21,48 @@ public class AltosGraphUI extends AltosUIFrame
        JTabbedPane             pane;
        AltosGraph              graph;
        AltosUIEnable           enable;
+       AltosSiteMap            map;
+       AltosState              state;
+       AltosGraphDataSet       graphDataSet;
+       AltosFlightStats        stats;
+       AltosFlightStatsTable   statsTable;
+       boolean                 has_gps;
+
+       void fill_map(AltosStateIterable states) {
+               boolean         any_gps = false;
+               for (AltosState state : states) {
+                       if (state.gps != null && state.gps.locked && state.gps.nsat >= 4) {
+                               if (map == null)
+                                       map = new AltosSiteMap();
+                               map.show(state, null);
+                               has_gps = true;
+                       }
+               }
+       }
+
+       AltosGraphUI(AltosStateIterable states, File file) throws InterruptedException, IOException {
+               super(file.getName());
+               state = null;
 
-       AltosGraphUI(AltosRecordIterable records, String file) throws InterruptedException, IOException {
                pane = new JTabbedPane();
 
                enable = new AltosUIEnable();
 
-               AltosGraph graph = new AltosGraph(enable);
+               stats = new AltosFlightStats(states);
+               graphDataSet = new AltosGraphDataSet(states);
+
+               graph = new AltosGraph(enable, stats, graphDataSet);
 
-               graph.setDataSet(new AltosGraphDataSet(records));
+               statsTable = new AltosFlightStatsTable(stats);
 
                pane.add("Flight Graph", graph.panel);
                pane.add("Configure Graph", enable);
+               pane.add("Flight Statistics", statsTable);
 
-               AltosFlightStatsTable stats = new AltosFlightStatsTable(new AltosFlightStats(records));
-               pane.add("Flight Statistics", stats);
+               has_gps = false;
+               fill_map(states);
+               if (has_gps)
+                       pane.add("Map", map);
 
                setContentPane (pane);
 
@@ -43,5 +70,7 @@ public class AltosGraphUI extends AltosUIFrame
 
                setDefaultCloseOperation(DISPOSE_ON_CLOSE);
                setVisible(true);
+               if (state != null && has_gps)
+                       map.centre(state);
        }
 }