2018-03-30
这其实有一个求球面距离的公式,忘了,搜索到的……嘿嘿
Java代码
// lat是纬度,lung是经度
//a=Lat1 – Lat2 为两点纬度之差 b=Lung1 -Lung2 为两点经度之差;
//6378.137(KM) 为地球半径 - -@
//恩,结果也是km……
//另外,google的api其实已经实现好了的
// 计算两点距离
private final double EARTH_RADIUS = 6378137.0;
private double gps2m(double lat_a, double lng_a, double lat_b, double lng_b) {
double radLat1 = (lat_a * Math.PI / 180.0);
double radLat2 = (lat_b * Math.PI / 180.0);
double a = radLat1 - radLat2;
double b = (lng_a - lng_b) * Math.PI / 180.0;
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;
}