【轉】C#計算兩座標點距離

來源:互聯網
上載者:User

標籤:sum   ble   radius   span   style   class   誤差   經緯   點距   

      //地球半徑,單位米       private const double EARTH_RADIUS = 6378137;       /// <summary>       /// 計算兩點位置的距離,返回兩點的距離,單位 米       /// 該公式為GOOGLE提供,誤差小於0.2米       /// </summary>       /// <param name="lat1">第一點緯度</param>       /// <param name="lng1">第一點經度</param>       /// <param name="lat2">第二點緯度</param>       /// <param name="lng2">第二點經度</param>       /// <returns></returns>       public static double GetDistance(double lat1, double lng1, double lat2, double lng2)       {           double radLat1 = Rad(lat1);           double radLng1 = Rad(lng1);           double radLat2 = Rad(lat2);           double radLng2 = Rad(lng2);           double a = radLat1 - radLat2;           double b = radLng1 - radLng2;           double result = 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))) * EARTH_RADIUS;           return result;       }        /// <summary>       /// 經緯度轉化成弧度       /// </summary>       /// <param name="d"></param>       /// <returns></returns>       private static double Rad(double d)       {           return (double)d * Math.PI / 180d;       }

 

【轉】C#計算兩座標點距離

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.