计算距离,在米的时候你知道的经度和纬度在java[重复]
-
10-07-2019 - |
题
可能的重复:
工作与纬度/经度值在Java
重复:
我需要计算的距离两点之间给出的通过两个坐标。该项目的我的工作就是一个Java的项目,因此Java码将是巨大的,但是伪码还可以给出的,然后我就可以实现它自己:)
正如你可能知道,有三种方式表示坐标:
- 度:分:秒(49°30'00"N,123°30'00"W)
- 度:十进制分钟(49°30.0', -123°30.0'), (49d30.0,-123d30.0')
- 十进制度(49.5000°,-123.5000°),一般有4到6小数。
这是第三种方式的我的坐标在,这样的代码这种价值观将是优选:)
解决方案
基于上 另一个问题上的计算器, 我得到了这个代码..这一计算的结果在米,不是在里)
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;
}
其他提示
你可以使用 Java大地测量图书馆的GPS, 它使用 Vincenty的公式 它考虑到了地球表面的曲度。
执行情况是这样的:
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
所得到的距离是在米。
C++它是这样的:
#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;
}
不隶属于 StackOverflow