Berechnen Entfernung in Metern, wenn Sie wissen, Längen- und Breitengrade in Java [Duplicate]

StackOverflow https://stackoverflow.com/questions/837872

Frage

  

Mögliche Duplizieren:
   Arbeiten mit Breiten- / Längenwerten in Java

Duplizieren:

Ich brauche den Abstand zwischen zwei Punkten durch zwei Koordinaten gegeben zu berechnen. Das Projekt arbeite ich an einem Java-Projekt, so Java-Code wird groß sein, aber pseudo-Code kann auch angegeben werden, dann kann ich es selbst implementieren:)

Wie Sie wahrscheinlich wissen, gibt es drei Möglichkeiten Koordinaten darzustellen:

  • Degrees: Minuten: Sekunden (49 ° 30'00 "N, 123 ° 30'00" W)
  • Degrees: Dezimal-Minuten (49 ° 30,0' , -123 ° 30,0 '), (49d30.0m, -123d30.0')
  • Dezimalgrad (49,5000 °, -123,5000 °), in der Regel mit 4-6 Dezimalzahlen.

Es ist der dritte Weg, um meine Koordinaten sind in, so dass der Code für diese Werte werden bevorzugt:)

Andere Tipps

Sie können die Java Geodäsie Bibliothek für GPS , verwendet es die Vincenty des , die wegen der Krümmung Erdoberfläche nimmt.

Die Umsetzung geht wie folgt aus:

import org.gavaghan.geodesy.*;

...

GeodeticCalculator geoCalc = new GeodeticCalculator();

Ellipsoid reference = Ellipsoid.WGS84;  

GlobalPosition pointA = new GlobalPosition(latitude, longitude, 0.0); // Point A

GlobalPosition userPos = new GlobalPosition(userLat, userLon, 0.0); // Point B

double distance = geoCalc.calculateGeodeticCurve(reference, userPos, pointA).getEllipsoidalDistance(); // Distance between Point A and Point B

Der resultierende Abstand in Metern.

In C ++ wird wie folgt durchgeführt:

#define LOCAL_PI 3.1415926535897932385 

double ToRadians(double degrees) 
{
  double radians = degrees * LOCAL_PI / 180;
  return radians;
}

double DirectDistance(double lat1, double lng1, double lat2, double lng2) 
{
  double earthRadius = 3958.75;
  double dLat = ToRadians(lat2-lat1);
  double dLng = ToRadians(lng2-lng1);
  double a = sin(dLat/2) * sin(dLat/2) + 
             cos(ToRadians(lat1)) * cos(ToRadians(lat2)) * 
             sin(dLng/2) * sin(dLng/2);
  double c = 2 * atan2(sqrt(a), sqrt(1-a));
  double dist = earthRadius * c;
  double meterConversion = 1609.00;
  return dist * meterConversion;
}
Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow
scroll top