Calculer la distance entre deux coordonnées par la latitude et la longitude y compris une implémentation Javascript.
Ouest y Sud les emplacements sont négatifs. Rappelez-vous que les minutes et les secondes sont en dehors de 60, donc S31 30' est -31,50 degrés.
N'oubliez pas de convertir des degrés en radians . De nombreuses langues disposent de cette fonction. Ou bien il s'agit d'un simple calcul : radians = degrees * PI / 180
.
function degreesToRadians(degrees) {
return degrees * Math.PI / 180;
}
function distanceInKmBetweenEarthCoordinates(lat1, lon1, lat2, lon2) {
var earthRadiusKm = 6371;
var dLat = degreesToRadians(lat2-lat1);
var dLon = degreesToRadians(lon2-lon1);
lat1 = degreesToRadians(lat1);
lat2 = degreesToRadians(lat2);
var a = Math.sin(dLat/2) * Math.sin(dLat/2) +
Math.sin(dLon/2) * Math.sin(dLon/2) * Math.cos(lat1) * Math.cos(lat2);
var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a));
return earthRadiusKm * c;
}
Voici quelques exemples d'utilisation :
distanceInKmBetweenEarthCoordinates(0,0,0,0) // Distance between same
// points should be 0
0
distanceInKmBetweenEarthCoordinates(51.5, 0, 38.8, -77.1) // From London
// to Arlington
5918.185064088764
3 votes
Cet algorithme est connu sous le nom de Distance du Grand Cercle .