Verwenden Sie Haversine, um den Unterschied zwischen den zwei Punkten in Metern zu berechnen; Passen Sie dann den Wert der Personenkoordinaten proportional an.
$radius = 6378100; // radius of earth in meters
$latDist = $lat - $lat2;
$lngDist = $lng - $lng2;
$latDistRad = deg2rad($latDist);
$lngDistRad = deg2rad($lngDist);
$sinLatD = sin($latDistRad);
$sinLngD = sin($lngDistRad);
$cosLat1 = cos(deg2rad($lat));
$cosLat2 = cos(deg2rad($lat2));
$a = ($sinLatD/2)*($sinLatD/2) + $cosLat1*$cosLat2*($sinLngD/2)*($sinLngD/2);
if($a<0) $a = -1*$a;
$c = 2*atan2(sqrt($a), sqrt(1-$a));
$distance = $radius*$c;
Füttern Sie Ihre Werte:
$lat = 51.26667; // Just South of Aardenburg in Belgium
$lng = 3.45417;
$lat2 = 51.575001; // To the East of Breda in Holland
$lng2 = 4.83889;
ein Ergebnis von 102059,82251083 Meter gibt, 102,06 Kilometer
Das Verhältnis einzustellen, indem wird 100/102059,82251083 = 0,0009798174985988102859004569070625
$newLat = $lat + (($lat2 - $lat) * $ratio);
$newLng = $lng + (($lng2 - $lng) * $ratio);
Gibt einen neuen Breitengrad von 51,266972108109 und Längengrad 3,4555 an 267728867
Sind die Koordinaten in Meter oder ist das lat/lon? Wenn Letzteres erforderlich ist, müssen Sie eine Koordinatenprojektion in WGS84 oder ein Simillar-Ellipsoid durchführen, um Koordinaten in Metern zu erhalten. Angenommen, Sie möchten 100 näher in einer geraden Linie (keine Straßen oder Wände zu berücksichtigen) bewegen, können Sie die euklidische Distanzformel verwenden –
Sind diese Dezimalzahlen? – Jeriko
das sind lat, lng Koordinaten. Verwendet von Google Maps –