根据两点经纬度计算距离
Posted 路人浅笑
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了根据两点经纬度计算距离相关的知识,希望对你有一定的参考价值。
google地图提供的方法:
1. Lung1 Lat1表示A点经纬度, Lung2 Lat2表示B点经纬度;
2. a=Lat1 – Lat2 为两点纬度之差 b=Lung1 -Lung2 为两点经度之差;
3. 6378.137为地球半径,单位为千米;
4. 计算出来的结果单位为千米,若将半径改为米为单位则计算的结果单位为米。
5. 计算精度与谷歌地图的距离精度差不多,相差范围在0.2米以下。
private static final double EARTH_RADIUS = 6378.137;//赤道半径(单位km)
转化为弧度(rad)
private static double rad(double d)
{
return d * Math.PI / 180.0;
}
根据两点间经纬度坐标(double值),计算两点间距离
lon1 lat1 第一点的经度,纬度
lon2 lat3 第二点的经度,纬度
public static double GetDistance(double lat1,double lon1, double lat2,double lon2)
{
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;
s = Math.round(s * 10000) / 10000;
return s;
}
根据经纬度求夹角:
详细可参见:http://blog.sina.com.cn/s/blog_658a93570101hynw.html
以上是关于根据两点经纬度计算距离的主要内容,如果未能解决你的问题,请参考以下文章