我們常說的經緯度就是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得到的結果,誤差到毫米級,很快就可以上線了。