zoukankan      html  css  js  c++  java
  • 经纬度之间距离计算

     

      /// <summary>
            
    /// 经纬度之间距离
            
    /// </summary>
            
    /// <param name="lng1">经度,通常大于90的</param>
            
    /// <param name="lat1">纬度,通常小于90的</param>
            
    /// <param name="lng2"></param>
            
    /// <param name="lat2"></param>
            
    /// <param name="gs">可以选默认的:WGS84</param>
            
    /// <returns></returns>
            public static double DistanceOfTwoPoints(double lng1, double lat1, double lng2, double lat2, GaussSphere gs)
            {
                double radLat1 = Rad(lat1);
                double radLat2 = Rad(lat2);
                double a = radLat1 - radLat2;
                double b = Rad(lng1) - Rad(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 * (gs == GaussSphere.WGS84 ? 6378137.0 : (gs == GaussSphere.Xian80 ? 6378140.0 : 6378245.0));
                s = Math.Round(s * 10000) / 10000;
                return s;
            }



            private static double Rad(double d)
            {
                return d * Math.PI / 180.0;
            }

            //GaussSphere 为自定义枚举类型
            /// <summary>
            
    /// 高斯投影中所选用的参考椭球
            
    /// </summary>
            public enum GaussSphere
            {
                Beijing54,
                Xian80,
                WGS84,
            }
  • 相关阅读:
    luogu P2472 [SCOI2007]蜥蜴 网络流 拆点
    luogu P2762 太空飞行计划问题 网络流24
    luogu P2774 方格取数问题 网络流24 最小割
    luogu P2766 最长不下降子序列问题 网络流24
    Codeforces Round #651 (Div. 2) E
    Codeforces Round #651 (Div. 2) D
    Codeforces Round #651 (Div. 2) C
    Codeforces Global Round 8 E
    Codeforces Global Round 8 D
    【最小生成树】Truck History POJ
  • 原文地址:https://www.cnblogs.com/mxh691/p/2383424.html
Copyright © 2011-2022 走看看