网站首页 > 网络编程教程 > C#/CSHARP教程 > c#中利用google map距离计算公式实现两点间距离的计算

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

  • 作者:互联网
  • 时间:2009-12-10 16:57:09

计算公式如下:

 

说明:

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 * Ma***Asin(Ma***Sqrt(Math.Pow(Math.Sin(a/2), 2) +
                Math.Cos(radLng1) * Math.Cos(radLng2) * Math.Pow(Math.Sin(b/2), 2)))* 6378.137;
            s =M***.Round(s * 10000) / 10000;

            return s;
        }

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