循环遍历坐标数组并计算距离javascript

时间:2015-06-30 16:28:50

标签: javascript arrays geolocation coordinates

我有一个正在运行的应用程序,用于跟踪和记录跑步者的位置,并将坐标保存到数组中,到目前为止一直很好。 我试图在数组上循环并计算总行程距离。

代码:

        var startPos;
        var num;
        var distance;

        navigator.geolocation.getCurrentPosition(function (position) {
            startPos = position;
        });
        //
        watchID = navigator.geolocation.watchPosition(function (position) {

        pathArr.push(new google.maps.LatLng(position.coords.latitude, position.coords.longitude));
        var lat = position.coords.latitude;
        var lon = position.coords.longitude;
        var latlng = new google.maps.LatLng(lat, lon);

        var num = calculateDistance(startPos.coords.latitude,startPos.coords.longitude,
        position.coords.latitude, position.coords.longitude);
        distance = num;
        },


        function (positionError) {
            $("#error").append("Error: " + positionError.message + "<br />");
        }, {
            enableHighAccuracy: true,
            timeout: 30 * 1000
        });


function calculateDistance(lat1, lon1, lat2, lon2) {
    var R = 6371; // km
    var dLat = (lat2 - lat1).toRad();
    var dLon = (lon2 - lon1).toRad();
    var a = Math.sin(dLat / 2) * Math.sin(dLat / 2) + Math.cos(lat1.toRad()) * Math.cos(lat2.toRad()) * Math.sin(dLon / 2) * Math.sin(dLon / 2);
    var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
    var d = R * c;
    return d;
}

我所意识到的是,如果我走一条直线,计算只能正常工作,因为它总是从开始到当前而不是一个接一个,如果跑步者将圈回到零点,则总数将为0或关闭到0,我需要改变它以计算从坐标到坐标的距离并加上总数。

我试过这个:

        var lat = position.coords.latitude;
        var lon = position.coords.longitude;
        var latlng = new google.maps.LatLng(lat, lon);

            num += calculateDistance(startPos.coords.latitude, startPos.coords.longitude,
            position.coords.latitude, position.coords.longitude);
            startPos = latlng;
            distance = num;

没有运气。 请帮忙

1 个答案:

答案 0 :(得分:4)

您需要遍历数组中的所有地理坐标,找到每个连续两个坐标之间的距离,并将它们添加到距离之和以查找总距离。

简化代码的相关部分如下:

鉴于coords持有地理坐标数组,

for (var i = 0; i < coords.length - 1; i++) {
    distanceTotal += google.maps.geometry.spherical.computeDistanceBetween(coords[i], coords[i+1]);
}

以下是Google Maps API的示例:http://jsfiddle.net/90kbnjqx/2/