Berechnen von Entfernungen aus Breiten- und Längengrad
In diesem Szenario möchten Sie die Punkte innerhalb eines 15-Meilen-Radius um die bestimmen Vom Benutzer eingegebene Koordinaten. Um dies zu erreichen, können Sie mathematische Formeln nutzen, um Entfernungen zu berechnen.
Betrachten Sie die folgende PHP-Funktion:
function get_distance($latitude1, $longitude1, $latitude2, $longitude2, $unit = 'Mi') {
// Calculate the angle difference
$theta = $longitude1 - $longitude2;
// Calculate the distance
$distance = (sin(deg2rad($latitude1)) * sin(deg2rad($latitude2)))
(cos(deg2rad($latitude1)) * cos(deg2rad($latitude2)) *
cos(deg2rad($theta)));
// Convert to degrees
$distance = acos($distance);
$distance = rad2deg($distance);
// Convert to miles or kilometers
$distance = $distance * 60 * 1.1515;
// Round the distance
return (round($distance,2));
}
Alternativ können Sie eine Datenbankabfrage verwenden, um dies zu erreichen:
$query = "SELECT *,(((acos(sin((".$latitude."*pi()/180)) *
sin((`Latitude`*pi()/180)) cos((".$latitude."*pi()/180)) *
cos((`Latitude`*pi()/180)) * cos(((".$longitude."- `Longitude`)*
pi()/180))))*180/pi())*60*1.1515
) as distance
FROM `MyTable`
HAVING distance > ".$distance.";
Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.
Copyright© 2022 湘ICP备2022001581号-3