X-Git-Url: https://git.gag.com/?p=fw%2Faltos;a=blobdiff_plain;f=altosui%2FAltosGraphUI.java;h=c42f7b5f89d4f346517fad948c5b3ec6a86229d4;hp=b376f7de69ee29d4adea4d1d46e56b003bd21af9;hb=b19a648b667c298d2d9d5ed4ee9db661be058d1a;hpb=bf88c5f829ea5d32043431945e862a9f6c96740a diff --git a/altosui/AltosGraphUI.java b/altosui/AltosGraphUI.java index b376f7de..c42f7b5f 100644 --- a/altosui/AltosGraphUI.java +++ b/altosui/AltosGraphUI.java @@ -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); } }