js根据经纬度计算距离

大家好,又见面了,我是你们的朋友全栈君。

代码语言:javascript
复制
var EARTH_RADIUS = 6378137.0;    //单位M
var PI = Math.PI;



function getRad(d){

    return d*PI/180.0;

}



/**

 * caculate the great circle distance

 * @param {Object} lat1

 * @param {Object} lng1

 * @param {Object} lat2

 * @param {Object} lng2

 */

function getGreatCircleDistance(lat1,lng1,lat2,lng2){

    var radLat1 = getRad(lat1);

    var radLat2 = getRad(lat2);

    

    var a = radLat1 - radLat2;

    var b = getRad(lng1) - getRad(lng2);

    

    var s = 2*Math.asin(Math.sqrt(Math.pow(Math.sin(a/2),2) + Math.cos(radLat1)*Math.cos(radLat2)*Math.pow(Math.sin(b/2),2)));

    s = s*EARTH_RADIUS;

    s = Math.round(s*10000)/10000.0;

            

    return s;

}</code></pre></div></div><p>版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。 </p>