Calcola la distanza in metri quando conosci longitudine e latitudine in java [duplicato]
-
10-07-2019 - |
Domanda
Possibile duplicato:
Lavorare con i valori di latitudine / longitudine in Java
Duplica:
- Lavorare con i valori di latitudine / longitudine in Java
- Come posso calcolare la distanza tra due punti di latitudine?
Devo calcolare la distanza tra due punti dati da due coordinate. Il progetto a cui sto lavorando è un progetto Java, quindi il codice Java sarà fantastico, ma può anche essere dato uno pseudo-codice, quindi posso implementarlo da solo :)
Come probabilmente sai, ci sono tre modi per rappresentare le coordinate:
- Gradi: minuti: secondi (49 & # 176; 30'00 " N, 123 & # 176; 30'00 " W)
- Gradi: minuti decimali (49 & # 176; 30.0 ', -123 & # 176; 30.0'), (49d30.0m, -123d30.0 ')
- Gradi decimali (49.5000 & # 176;, - 123.5000 & # 176;), generalmente con 4-6 numeri decimali.
È il terzo modo in cui sono fornite le mie coordinate, quindi il codice per questi valori sarà preferito :)
Soluzione
Basato su un'altra domanda su stackoverflow , ho ottenuto questo codice .. Questo calcola il risultato in metri, non in miglia: )
public static float distFrom(float lat1, float lng1, float lat2, float lng2) {
double earthRadius = 6371000; //meters
double dLat = Math.toRadians(lat2-lat1);
double dLng = Math.toRadians(lng2-lng1);
double a = Math.sin(dLat/2) * Math.sin(dLat/2) +
Math.cos(Math.toRadians(lat1)) * Math.cos(Math.toRadians(lat2)) *
Math.sin(dLng/2) * Math.sin(dLng/2);
double c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a));
float dist = (float) (earthRadius * c);
return dist;
}
Altri suggerimenti
Puoi utilizzare la Java Geodesy Library per GPS , utilizza le le formule di Vincenty che tengono conto della curvatura della superficie terrestre.
L'implementazione va così:
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
La distanza risultante è in metri.
In C ++ è fatto così:
#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;
}