原貼地址:
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米
驗證正確。