我正在尝试为非常短的距离计算2个GPS坐标之间的距离。我发现了一些方法,但是它们都需要math类的方法。我的目标是实现这样的算法:
public static double haversine(
double lat1, double lng1, double lat2, double lng2) {
int r = 6371; // average radius of the earth in km
double dLat = Math.toRadians(lat2 - lat1);
double dLon = 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(dLon / 2) * Math.sin(dLon / 2);
double c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
double d = r * c;
return d;
}
我知道如何在度和弧度之间转换。有没有一种方法可以在cn1中进行计算,或者有什么方法可以使用比MathUtil提供的更多的数学函数,例如sin cos和tan函数。
MapComponent中有一个静态实用程序方法可以做到这一点:
public static long distance(double latitude1, double longitude1, double latitude2, double longitude2) {
double latitudeSin = Math.sin(Math.toRadians(latitude2 - latitude1) / 2);
double longitudeSin = Math.sin(Math.toRadians(longitude2 - longitude1) / 2);
double a = latitudeSin * latitudeSin
+ Math.cos(Math.toRadians(latitude1)) * Math.cos(Math.toRadians(latitude2)) * longitudeSin * longitudeSin;
double c = 2 * MathUtil.atan2(Math.sqrt(a), Math.sqrt(1 - a));
return (long) (6378137 * c);
}
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句