根據兩點經緯度計算距離
阿新 • • 發佈:2017-08-23
根據 地圖 div distance 經緯度坐標 轉化 htm radius i2s google地圖提供的方法:
對上面的公式解釋如下: 1. Lung1 Lat1表示A點經緯度, Lung2 Lat2表示B點經緯度; 2. a=Lat1 – Lat2 為兩點緯度之差 b=Lung1 -Lung2 為兩點經度之差; 3. 6378.137為地球半徑,單位為千米; 4. 計算出來的結果單位為千米,若將半徑改為米為單位則計算的結果單位為米。 5. 計算精度與谷歌地圖的距離精度差不多,相差範圍在0.2米以下。 private static final double EARTH_RADIUS = 6378.137;//赤道半徑(單位km) 轉化為弧度(rad) private static double rad(double d) { return d * Math.PI / 180.0; } 根據兩點間經緯度坐標(double值),計算兩點間距離 lon1 lat1 第一點的經度,緯度 lon2 lat3 第二點的經度,緯度 public static double GetDistance(double lat1,double lon1, double lat2,double lon2) { double radLat1 = rad(lat1); double radLat2 = rad(lat2); double a = radLat1 - radLat2; double b = rad(lon1) - rad(lon2); 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; } 根據經緯度求夾角:
詳細可參見:http://blog.sina.com.cn/s/blog_658a93570101hynw.html
對上面的公式解釋如下: 1. Lung1 Lat1表示A點經緯度, Lung2 Lat2表示B點經緯度; 2. a=Lat1 – Lat2 為兩點緯度之差 b=Lung1 -Lung2 為兩點經度之差; 3. 6378.137為地球半徑,單位為千米; 4. 計算出來的結果單位為千米,若將半徑改為米為單位則計算的結果單位為米。 5. 計算精度與谷歌地圖的距離精度差不多,相差範圍在0.2米以下。 private static final double EARTH_RADIUS = 6378.137;//赤道半徑(單位km) 轉化為弧度(rad) private static double rad(double d) { return d * Math.PI / 180.0; } 根據兩點間經緯度坐標(double值),計算兩點間距離 lon1 lat1 第一點的經度,緯度 lon2 lat3 第二點的經度,緯度 public static double GetDistance(double lat1,double lon1, double lat2,double lon2) { double radLat1 = rad(lat1); double radLat2 = rad(lat2); double a = radLat1 - radLat2; double b = rad(lon1) - rad(lon2); 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; } 根據經緯度求夾角:
根據兩點經緯度計算距離