我有一个正在运行的应用程序,用于跟踪和记录跑步者的位置,并将坐标保存到数组中,到目前为止一直很好。 我试图在数组上循环并计算总行程距离。
代码:
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;
没有运气。 请帮忙
答案 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/