在坐标数组上循环并计算距离javascript

loop over array of coordinates and calculate distance javascript

本文关键字:计算 距离 javascript 循环 坐标 数组      更新时间:2023-09-26

我有一个正在运行的应用程序,它可以跟踪和记录跑步者的位置,并将坐标保存到数组中,到目前为止还不错。我试着在数组上循环,计算出总共行进的距离。

代码:

        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;

没有运气。请帮助

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

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

假定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/