【JAVA】兩點經緯度直線距離的計算


來自谷歌地圖的計算公式:


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

驗證正確。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM