Oblicz odległość w metrach, gdy znasz długość i szerokość geograficzną w Javie [duplikat]
Możliwy duplikat:
Praca z wartościami szerokości / długości geograficznej w Javie
Duplikat:
- praca z wartościami szerokości / długości geograficznej w Javie
- Jak obliczyć odległość między dwoma punktami długości geograficznej?
Muszę obliczyć odległość między dwoma punktami podanymi przez dwie współrzędne. Projekt, nad którym pracuję jest projektem Java, więc Java-code będzie świetny, ale pseudo-kod może również być podane, wtedy sam mogę to wdrożyć:)
Jak zapewne wiesz, istnieją trzy sposoby przedstawiania współrzędnych:
- Stopnie: Minuty:Sekundy (49°30'00"N, 123°30'00"W)
- stopnie: minuty dziesiętne (49°30.0', -123°30.0'), (49d30.0m,-123d30. 0')
- stopnie dziesiętne (49.5000°, -123.5000°), zwykle z 4-6 liczbami dziesiętnymi.
To trzeci sposób, w jaki moje współrzędne są podane, więc kod dla tych wartości będzie preferowany:)
3 answers
Na podstawie innego pytania na temat stackoverflow , mam ten kod.. To oblicza wynik w metrach, a nie w milach:)
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;
}
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2017-05-23 12:10:54
Możesz użyć Biblioteki Geodezji Java dla GPS , wykorzystuje ona wzory Vincenty ' ego , które uwzględniają krzywiznę powierzchni Ziemi.
Implementacja wygląda tak:
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
Otrzymana odległość jest wyrażona w metrach.
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2013-04-07 18:01:53
W C++ robi się to tak:
#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;
}
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2009-12-17 20:01:28