private static final double EARTH_RADIUS = 6378137;//赤道半径
private static double rad(double d){
return d * Math.PI / 180.0;
}
public static double GetDistance(double lon1,double lat1,double lon2, double lat2) {
double radLat1 = rad(lat1);
double radLat2 = rad(lat2);
double a = radLat1 - radLat2;
double b = rad(lon1) - rad(lon2);
double s = 2 *Math.asin(Math.sqrt(Math.pow(Math.sin(a/2),2)+Math.cos(radLat1)*Math.cos(radLat2)*Math.pow(Math.sin(b/2),2)));
s = s * EARTH_RADIUS;
return s;//单位米
}
本文介绍了一种使用球面三角公式计算两点间地理距离的算法。通过将经纬度转换为弧度,并利用球面三角公式计算两个地理位置之间的大圆距离,最终得出精确到米的地球表面两点距离。
5446

被折叠的 条评论
为什么被折叠?



