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,
            }
  • 相关阅读:
    js 数组操作常用方法
    如何成为一名卓越的前端工程师
    js实现日期显示的一些操作
    JavaScript 创建对象的七种方式
    ios微信浏览器音乐自动播放
    Mac下新建.开头的隐藏文件
    JavaScript判断浏览器UA 、 添加收藏 、设置首页 、调用本地邮箱发送邮件
    获取当前页面参数Hash和Search,或者当前Script的参数
    AJAX调用代码实例
    移动端兼容笔记整理
  • 原文地址:https://www.cnblogs.com/mxh691/p/2383424.html
Copyright © 2011-2022 走看看