micropeak: Make reported 'max height' value show filtered max height
[fw/altos] / altoslib / AltosMapTransform.java
index 30994ecb60bc2dc826f50f6fffbc546b07882e24..b6d4f4356af8166b4dd3322092aaa2ce9682dd39 100644 (file)
@@ -3,7 +3,8 @@
  *
  * This program is free software; you can redistribute it and/or modify
  * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; version 2 of the License.
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
  *
  * This program is distributed in the hope that it will be useful, but
  * WITHOUT ANY WARRANTY; without even the implied warranty of
@@ -15,7 +16,7 @@
  * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
  */
 
-package org.altusmetrum.altoslib_7;
+package org.altusmetrum.altoslib_12;
 
 import java.io.*;
 import java.lang.Math;
@@ -51,6 +52,13 @@ public class AltosMapTransform {
                return new AltosPointDouble(screen.x + offset_x, screen.y + offset_y);
        }
 
+       public double hypot(AltosLatLon a, AltosLatLon b) {
+               AltosPointDouble        a_pt = point(a);
+               AltosPointDouble        b_pt = point(b);
+
+               return Math.hypot(a_pt.x - b_pt.x, a_pt.y - b_pt.y);
+       }
+
        public AltosLatLon screen_lat_lon(AltosPointInt screen) {
                return lat_lon(screen_point(screen));
        }
@@ -110,4 +118,12 @@ public class AltosMapTransform {
                offset_x = centre_pt.x - width / 2.0;
                offset_y = centre_pt.y - height / 2.0;
        }
+
+       public static double lon_from_distance(double lat, double distance) {
+               double c = AltosGreatCircle.earth_radius * Math.cos(lat * Math.PI / 180) * 2 * Math.PI;
+
+               if (c < 10)
+                       return 0;
+               return distance/c * 360.0;
+       }
 }