根據緯度和經度計算距離
在此場景中,您要確定 15 英里半徑內的點用戶輸入的座標。為此,您可以利用數學公式來計算距離。
考慮以下 PHP 函數:
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));
}
或者,您可以使用資料庫查詢來完成此操作:
$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.";
免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。
Copyright© 2022 湘ICP备2022001581号-3