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,
            }
  • 相关阅读:
    软件测试初探
    weiPHPOneThink1.0开发手册
    关于.aspx与.aspx.cs的关系
    佩服的牛人
    当客户说“没钱”,我该怎么应对?
    weiphp 简介笔记
    FlashFXP、LeapFTP、CuteFTP 等FTP软件二进制上传或下载方法
    集体智慧编程(一)
    Sargur Srihari 的两个课程 ML和DM
    一个神人Hoifung Poon
  • 原文地址:https://www.cnblogs.com/mxh691/p/2383424.html
Copyright © 2011-2022 走看看