summaryrefslogtreecommitdiff
path: root/altosuilib
diff options
context:
space:
mode:
Diffstat (limited to 'altosuilib')
-rw-r--r--altosuilib/AltosFlightStatsTable.java33
-rw-r--r--altosuilib/AltosUIMap.java2
-rw-r--r--altosuilib/AltosUIMapView.java5
3 files changed, 30 insertions, 10 deletions
diff --git a/altosuilib/AltosFlightStatsTable.java b/altosuilib/AltosFlightStatsTable.java
index ec106cf1..b32e92a0 100644
--- a/altosuilib/AltosFlightStatsTable.java
+++ b/altosuilib/AltosFlightStatsTable.java
@@ -19,14 +19,23 @@ package org.altusmetrum.altosuilib_2;
import java.awt.*;
import javax.swing.*;
+import java.util.*;
import org.altusmetrum.altoslib_4.*;
-public class AltosFlightStatsTable extends JComponent {
+public class AltosFlightStatsTable extends JComponent implements AltosFontListener {
GridBagLayout layout;
- class FlightStat {
+ LinkedList<FlightStat> flight_stats = new LinkedList<FlightStat>();
+
+ class FlightStat implements AltosFontListener {
JLabel label;
- JTextField value;
+ JTextField[] value;
+
+ public void font_size_changed(int font_size) {
+ label.setFont(AltosUILib.label_font);
+ for (int i = 0; i < value.length; i++)
+ value[i].setFont(AltosUILib.value_font);
+ }
public FlightStat(GridBagLayout layout, int y, String label_text, String ... values) {
GridBagConstraints c = new GridBagConstraints();
@@ -43,21 +52,28 @@ public class AltosFlightStatsTable extends JComponent {
layout.setConstraints(label, c);
add(label);
+ value = new JTextField[values.length];
for (int j = 0; j < values.length; j++) {
- value = new JTextField(values[j]);
- value.setFont(AltosUILib.value_font);
- value.setHorizontalAlignment(SwingConstants.RIGHT);
+ value[j] = new JTextField(values[j]);
+ value[j].setFont(AltosUILib.value_font);
+ value[j].setHorizontalAlignment(SwingConstants.RIGHT);
c.gridx = j+1; c.gridy = y;
c.anchor = GridBagConstraints.EAST;
c.fill = GridBagConstraints.BOTH;
c.weightx = 1;
- layout.setConstraints(value, c);
- add(value);
+ layout.setConstraints(value[j], c);
+ add(value[j]);
}
+ flight_stats.add(this);
}
}
+ public void font_size_changed(int font_size) {
+ for (FlightStat f : flight_stats)
+ f.font_size_changed(font_size);
+ }
+
static String pos(double p, String pos, String neg) {
String h = pos;
if (p < 0) {
@@ -147,5 +163,4 @@ public class AltosFlightStatsTable extends JComponent {
pos(stats.lon,"E","W"));
}
}
-
}
diff --git a/altosuilib/AltosUIMap.java b/altosuilib/AltosUIMap.java
index fa974d36..91087469 100644
--- a/altosuilib/AltosUIMap.java
+++ b/altosuilib/AltosUIMap.java
@@ -74,7 +74,7 @@ public class AltosUIMap extends JComponent implements AltosFlightDisplay, AltosU
}
public void units_changed(boolean imperial_units) {
- repaint();
+ view.set_units();
}
JLabel zoom_label;
diff --git a/altosuilib/AltosUIMapView.java b/altosuilib/AltosUIMapView.java
index c558118b..edae3e1e 100644
--- a/altosuilib/AltosUIMapView.java
+++ b/altosuilib/AltosUIMapView.java
@@ -68,6 +68,11 @@ public class AltosUIMapView extends Canvas implements MouseMotionListener, Mouse
line.set_font(AltosUILib.value_font);
for (AltosUIMapTile tile : tiles.values())
tile.set_font(AltosUILib.value_font);
+ repaint();
+ }
+
+ public void set_units() {
+ repaint();
}
private boolean is_drag_event(MouseEvent e) {