c#中利用google map距离计算公式实现两点间距离的计算

该博客介绍了如何在C#中使用Google地图的计算公式,以弧度表示的经纬度来计算两点之间的距离。提供的C#函数将两点的经纬度转换为弧度,然后应用数学公式,最终返回以公里为单位的距离。经过验证,该函数计算结果准确。
摘要由CSDN通过智能技术生成

计算公式如下:

说明:

1、公式中经纬度均用弧度表示;

2、Lat1 Lng1 分别表示A点经、纬度,Lat2 Lng2  分别表示B点经纬度;

3、a=Lng1 -Lng2 为两点纬度之差  b=Lat1 – Lat2 为两点经度之差;

4、6378.137为地球半径,单位为公里;

 

c#实现函数如下:

        public double DistanceOfTwoPoints(double lat1, double lng1, double lat2, double lng2)
        {
            double radLng1 = lng1 * Math.PI / 180.0;
            double radLng2 = lng2 * Math.PI / 180.0;
            double a = radLng1 - radLng2;
            double b = (lat1-lat2) * Math.PI / 180.0;
            double s = 2 * Math.Asin(Math.Sqrt(Math.Pow(Math.Sin(a/2), 2) +
                Math.Cos(radLng1) * Math.Cos(radLng2) * Math.Pow(Math.Sin(b/2), 2)))* 6378.137;
            s =Math.Round(s * 10000) / 10000;

 

            return s;
        }

 

经实际验证正确通过(返回结果单位为:公里)。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值