JAVA两点经纬度直线距离的计算

原贴地址:

https://www.cnblogs.com/claireyuancy/p/7095725.html

来自谷歌地图的计算公式:

通过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米

验证正确。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章