热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

计算两个GPS坐标的距离方法一-C#语言

场景:已知两个GPS点的经纬度坐标信息。计算两点的距离。1.距离纬度关系GPS:22.514519,113.380301GPS:22.511962,11

场景:已知两个GPS点的经纬度坐标信息。计算两点的距离。

1. 距离/纬度关系

  GPS: 22.514519,113.380301

  GPS: 22.511962,113.380301

距离: 284.6439379583341  

jl_wd=284.6439379583341/(22.51451-22.511962)

= 111712.69150641055729984301412873 (米/度)

2. 距离/经度关系

GPS: 22.514866, 113.388444

GPS: 22.514866, 113.379378

距离: 932.2997762326453

jl_jd =932.2997762326453/(113.388444-113.379378)

=102834.74258026089786013677476285(米/度)

3.勾股定理 

勾股定理:a2+b=c2

 

 

看上图中已知道A,B的坐标后,就可以求得A点与B点的纬度差值的绝对值

wd_c=|(N1,-N2)|

A点与B点的经度差值的绝对值

jd_c=|(E2-E1)|

知道了经度、纬度和距离的关系,又知道了A点与B点的经度差和纬度差,那么就可以求出b的长度和a的长度,a和b求出来后就可以用直三角形的勾股定理求出c边的长度也就是A点也B点的距离。

b=wd_c*jl_wd

a=jd_c*jl_jd

c=√(a+b2)

 

C#实现代码:

 

    ///  
     
/// 计算两点GPS坐标的距离
     
///  

     
///   第一点的纬度坐标
     
///   第一点的经度坐标
     
///   第二点的纬度坐标
     
///   第二点的经度坐标
     
///  
         public  static  double Distance( double n1,  double e1,  double n2,  double e2)
        {
             double jl_jd =  102834.74258026089786013677476285;
             double jl_wd =  111712.69150641055729984301412873;
             double b = Math.Abs((e1 - e2) * jl_jd);
             double a = Math.Abs((n1 - n2) * jl_wd);
             return Math.Sqrt((a * a + b * b));

        }


上面的距离:  284.6439379583341 和 距离: 932.2997762326453是怎么来的?
它们是已知的。
由它算出jl_wd=284.6439379583341/(22.51451-22.511962)=  111712.69150641055729984301412873 (米/度)

这个算法的结果是纬差1度的距离是 111712.69150641055729984301412873米,经差1度的距离是102834.74258026089786013677476285米。得到这个结果就可以计算两个点东西方向和南北方向的距离,纬差乘以111713得到南北距离,经差乘以102835得到东西距离,再用勾股定理就可以计算出两点距离。

个人以为这个算法是不可取的,因为距离随经纬度的变化并不是线性的,范围小的话可能相差不大,范围大基本就没用了,何况还必须要先计算变化率。
计算两经纬度坐标点间距离可以先将经纬度按某种投影方式换算为平面坐标,在进行点间距离计算。

http://wenku.baidu.com/link?url=ifZF41TElH6_Qi2y7Rmab0a0Dvg_Sorf8MVBW_bxPpo3tjVfWwAgIMr9_FpsRS_tdJQ6C_mUflGR7FXAAPheyqBw5cIdh9rdXbhJupLfihq


推荐阅读
  • 成都万有算力(广州算力网络科技有限公司)
    在同期举办的第十三届天翼智能生态高峰论坛上,中国电信正式发布《中国电信AI+计划》。但从目前来看,后者的影响早已反过来远大于受置疑的前者。包括自由的金针菇、单纯的长颈鹿在内多位专家 ... [详细]
  • Unity3D平台宏定义之美
    Unity包含一个“平台相关的编译”功能。这包括一些预处理指令,让你分割你的脚本编译和专为支持的平台之一执行代码段。您可以Unity编辑器中运行代码,这 ... [详细]
  • 1.EF跟LINQ不是一码事儿。2.LINQtoEF是LINQ的一个provider,LINQtoSQL也是LINQ的一个provider。LINQtoEF是LINQtoSQL的替 ... [详细]
  • 工作以来接触到的技术流
    2019独角兽企业重金招聘Python工程师标准下面是工作以来接触到的技术平台,以及技术方案。部分在项目中深入过,部分仅选型、实践过。不断补充中. ... [详细]
  • WarensoftUnity3dCommunicationLibthisisahighperformancecommunicationlibraryfor Unity3d,incl ... [详细]
  • 本文内容为asp.net微信公众平台开发的目录汇总,包括数据库设计、多层架构框架搭建和入口实现、微信消息封装及反射赋值、关注事件、用户记录、回复文本消息、图文消息、服务搭建(接入)、自定义菜单等。同时提供了示例代码和相关的后台管理功能。内容涵盖了多个方面,适合综合运用。 ... [详细]
  • 测绘程序设计Excel度分秒转换模板附代码超实用版
    本文介绍了测绘程序设计Excel度分秒转换模板附代码超实用版的相关知识,包括准备工作、编写表达式和注意事项。在实际工作中,将GPS实测的经纬度度转换为度分秒是常见需求,本文提供了在Excel中快速进行转换的方法,以提高工作效率。 ... [详细]
  • 两个方案:1通过android.permission.READ_PHONE_STATE读取2通过短信过滤,读取手机号。按照第1个方案,AndroidManifest.xml需要添加< ... [详细]
  • 安全3AAuthentication:认证Authorzation:授权Accouting|Audition:审计用户管理用户:UID:0,不一定是root,root的uid非0时 ... [详细]
  • 吴恩达“机器学习”——学习笔记二
    定义一些名词欠拟合(underfitting):数据中的某些成分未被捕获到,比如拟合结果是二次函数,结果才只拟合出了一次函数。过拟合(overfitting):使用过量的特征集合, ... [详细]
  • 【实践】基于RTThread的智慧路灯案例实验分享
    之前分享了基于LiteOS的智慧农业案例实验分享基于LiteOS的智慧农业案例实验分享,阅读量挺不错,看样子大家都挺喜欢这种实验。那咱们就再来一个类似的实验:基于RT-Thread ... [详细]
  • Smrti Lab 和 ArkStream Demo Day 10 个参展新项目一览
    元宇宙、跨链桥、NFT交易市场、期权产品服务商、Layer1、DID、Web3基础设施等领域的被投项目参与路演。 ... [详细]
  • 移动传感器扫描覆盖摘要:关于传感器网络中的地址覆盖问题,已经做过很多尝试。他们通常归为两类,全覆盖和栅栏覆盖,统称为静态覆盖 ... [详细]
  • [手机][其他]绝对经典!疯狂Pinphone 3GS又发更新,Pin第三代(转载)
    已经致Pinfans疯狂的Pinphone3GS最近又放出新功能,好评如潮请设置pin。 ... [详细]
  • SLAM优秀开源工程最全汇总
    https:zhuanlan.zhihu.comp145750808 1、CartographerCartographer是一个系统,可跨多个平台和传感器配置以2D和3D形式提供实 ... [详细]
author-avatar
陈俊凯660638
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有