zoukankan      html  css  js  c++  java
  • 计算GPS WGS_84 两点的距离

      我们常说的经纬度就是GPS坐标,采用的是WGS_84坐标系统,一般采集来的数据就是GPS数据。我们知道使用ArcGIS Server可以很容易得到相关的数据,但是有时候,很简单的一个小功能,不值得使用这么大的软件。可以直接在客户端计算出来。下面这个算法,比较粗糙,有一定的误差。

     1 function getDistance(p1, p2) {
     2     var r = 6378137;
     3     var x1 = p1.x * Math.PI / 180;
     4     var x2 = p2.x * Math.PI / 180;
     5     var y1 = p1.y * Math.PI / 180;
     6     var y2 = p2.y * Math.PI / 180;
     7     var dx = Math.abs(x1 - x2);
     8     var dy = Math.abs(y1 - y2); 
     9     var p = Math.pow(Math.sin(dx / 2), 2) + Math.cos(x1) * Math.cos(x2) * Math.pow(Math.sin(dy / 2), 2);
    10     var d= r * 2 * Math.asin(Math.sqrt(p));  
    11     return d;
    12 }
    13 
    14 var p1={y:31.224286666667,x:121.420675}
    15 var p2={y:31.220157068379,x:121.42647022694};
    16 console.log(getDistance(p1,p2));

      最近在研究一个新的算法,和使用ArcGIS Server得到的结果,误差到毫米级,很快就可以上线了。

    转载请注明出处,http://www.cnblogs.com/HPhone/

    独立博客启用 万马奔腾-让现在的自己喜欢未来的你

    微博欢迎关注 webgis

  • 相关阅读:
    lesson
    lesson
    课后习题-5
    lesson
    lesson
    lesson
    重启网络服务时 Bringing up interface eth0
    课后习题-4
    基础扩展
    课后习题-3
  • 原文地址:https://www.cnblogs.com/HPhone/p/2802287.html
Copyright © 2011-2022 走看看