经纬度之间的距离计算
生活随笔
收集整理的這篇文章主要介紹了
经纬度之间的距离计算
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
來自谷歌地圖的計(jì)算公式:
通過JAVA的Math類各種方法調(diào)用。實(shí)現(xiàn)上述公式
?
private static double EARTH_RADIUS = 6378.137;// 單位千米/*** 角度弧度計(jì)算公式 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;}/*** 依據(jù)經(jīng)緯度計(jì)算兩點(diǎn)之間的距離 GetDistance:(). <br/>* * * @author chiwei* @param lat1* 1點(diǎn)的緯度* @param lng1* 1點(diǎn)的經(jīng)度* @param lat2* 2點(diǎn)的緯度* @param lng2* 2點(diǎn)的經(jīng)度* @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;// 兩點(diǎn)緯度差double b = getRadian(lng1) - getRadian(lng2);// 兩點(diǎn)的經(jīng)度差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;}合肥與杭州的經(jīng)緯度距離計(jì)算
?
?
public static void main(String ar[]) {getDistance(31.86, 117.27, 30.26, 120.19);}330518米
?
驗(yàn)證正確。
轉(zhuǎn)載于:https://www.cnblogs.com/fengli9998/p/8810463.html
總結(jié)
以上是生活随笔為你收集整理的经纬度之间的距离计算的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 钉钉api 获取 accesstoken
- 下一篇: android 摄像头预览左右镜像_Op