计算地球上2点之间的距离

// 这个函数取2个坐标,一个起点坐标和一个终点坐标,并返回二者之间的距离(千米)
    function computeDistance(startCoords,destCoords){
        var startLatRads = degreesToRadians(startCoords.latitude);
        var startLoingRads = degreesToRadians(startCoords.longitude);
        var destLatRads = degreesToRadians(destCoords.latitude);
        var destLongRads = degreesToRadians(destCoords.longitude);

        var Radius = 6371; //radius of the Earth in km
        var distance = Math.acos(Math.sin(startLatRads) * Math.sin(destLatRads) + Math.cos(startLatRads) * Math.cos(destLatRads) * Math.cos(startLoingRads - destLongRads)) * Radius;

        return distance;
    }

    function degreesToRadians(degrees){
        var radians = (degrees * Math.PI) / 180;
        return radians;
    }

测试:

// 测试
    var startCoords = {
        latitude: 29.8604472,
        longitude:121.498982
    };
    var destCoords = {
        latitude: 47.624851,
        longitude:-122.52099
    };

    var km = computeDistance(startCoords,destCoords);
    alert(km); //9293.980559898791
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值