通过两点经纬度信息 计算两点距离(C#语言)

本文介绍了一种使用C#编程语言计算地图上任意两点间距离的方法,通过将经纬度转换为弧度并利用地球半径,实现了精确的距离计算。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 /// <summary>    
      ///  通过地图上的两个坐标计算距离(C#)   
     /// </summary>    
     
      public class MapHelper
      {  
        // 地球半径
        private const double EarthRadius = 6378.137;    //单位:KM 如需要M在结果*1000即可    
        /// <summary>        
        /// 经纬度转化成弧度       
        /// </summary>        
        /// /// <param name="d"></param>        
        /// /// <returns></returns>        
        private static double Rad(double d)
        {
            return d * Math.PI / 180d;
        }          
        /// <summary>       
        ///  计算两个坐标点之间的距离      
        /// </summary>       
        ///  <param name="firstLatitude">第一个坐标的纬度</param>      
        ///  <param name="firstLongitude">第一个坐标的经度</param>        
        ///  <param name="secondLatitude">第二个坐标的纬度</param>        
        ///  <param name="secondLongitude">第二个坐标的经度</param>        
        ///  <returns>返回两点之间的距离,单位:公里/千米</returns>
          public static double GetDistance(double firstLatitude, double firstLongitude, double secondLatitude, double secondLongitude)
          {
            var firstRadLat = Rad(firstLatitude); //第一个坐标的纬度(已转化为弧度)
            var firstRadLng = Rad(firstLongitude); //第一个坐标的经度(已转化为弧度)
            var secondRadLat = Rad(secondLatitude); //第二个坐标的纬度(已转化为弧度)
            var secondRadLng = Rad(secondLongitude); //第二个坐标的经度(已转化为弧度)
            var a = firstRadLat - secondRadLat;    //维度差值(已转化为弧度)
            var b = firstRadLng - secondRadLng;    //精度差值(已转化为弧度)
            var cal = 2 * Math.Asin(Math.Sqrt(Math.Pow(Math.Sin(a / 2), 2) + Math.Cos(firstRadLat) * Math.Cos(secondRadLat) * Math.Pow(Math.Sin(b / 2), 2))) * EarthRadius;    //两坐标点距离(km)                  

            var result = Math.Round(cal * 10000) / 10000;
            return result;
          }          
        /// <summary>        
        /// 计算两个坐标点之间的距离       
        ///  </summary>        
        ///  <param name="firstPoint">第一个坐标点的(纬度,经度)</param>        
        /// <param name="secondPoint">第二个坐标点的(纬度,经度)</param>       
        ///  <returns>返回两点之间的距离,单位:公里/千米</returns>        
          public static double GetPointDistance(string firstPoint, string secondPoint)
          {
            var firstArray = firstPoint.Split(',');    //按照 , 分割字符串
            var secondArray = secondPoint.Split(',');
            var firstLatitude = Convert.ToDouble(firstArray[1].Trim());   //第一个坐标的纬度
            var firstLongitude = Convert.ToDouble(firstArray[0].Trim());  //第一个坐标的经度
            var secondLatitude = Convert.ToDouble(secondArray[1].Trim());  //第二个坐标的纬度
            var secondLongitude = Convert.ToDouble(secondArray[0].Trim());  //第二个坐标的经度
            return GetDistance(firstLatitude, firstLongitude, secondLatitude, secondLongitude);
          }

      }

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值