Рассчитать расстояние в метрах, когда вы знаете долготу и широту в java
Возможный дубликат:
Работа с значениями широты/долготы в Java
Duplicate:
Мне нужно рассчитать расстояние между двумя точками, заданными двумя координатами. Проект, над которым я работаю, - это Java-проект, поэтому Java-код будет отличным, но псевдокод также может быть задан, тогда я могу реализовать его сам:)
Как вы, наверное, знаете, существует три способа представления координат:
- Градусы: минуты: секунды (49 ° 30'00 "с.ш., 123 ° 30'00" з.д.)
- Градусы: десятичные минуты (49 ° 30,0 ', -123 ° 30,0'), (49d30.0m, -123d30.0 ')
- Десятичные градусы (49.5000 °, -123.5000 °), обычно с 4-6 десятичными числами.
Это третий способ, которым мои координаты указаны, поэтому код для этих значений будет предпочтительнее:)
Ответы
Ответ 1
На основе fooobar.com/questions/75793/..., я получил этот код.. Это вычисляет результат в метрах, а не в милях:)
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;
}
Ответ 2
Вы можете использовать Java Geodesy Library for GPS, он использует формулы
Ответ 3
В С++ это делается следующим образом:
#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;
}