来自谷歌地图的计算公式:
通过JAVA的Math类各种方法调用。实现上述公式
private static double EARTH_RADIUS = 6378.137;// 单位千米/*** 角度弧度计算公式 rad:(). <br/>* * 360度=2π π=Math.PI* * x度 = x*π/360 弧度* * @author chiwei* @param d* @return* @since JDK 1.6*/private static double getRadian(double degree) {return degree * Math.PI / 180.0;}/*** 依据经纬度计算两点之间的距离 GetDistance:(). <br/>* * * @author chiwei* @param lat1* 1点的纬度* @param lng1* 1点的经度* @param lat2* 2点的纬度* @param lng2* 2点的经度* @return 距离 单位 米* @since JDK 1.6*/public static double getDistance(double lat1, double lng1, double lat2, double lng2) {double radLat1 = getRadian(lat1);double radLat2 = getRadian(lat2);double a = radLat1 - radLat2;// 两点纬度差double b = getRadian(lng1) - getRadian(lng2);// 两点的经度差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 * 1000;}
合肥与杭州的经纬度距离计算
public static void main(String ar[]) {getDistance(31.86, 117.27, 30.26, 120.19);}
330518米
验证正确。