HPhone 发表于 2012-12-29 11:08:14

计算GPS WGS_84 两点的距离

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

<div class="cnblogs_code"> 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));
页: [1]
查看完整版本: 计算GPS WGS_84 两点的距离