用PHP 計算郵遞區號之間的距離
計算兩個郵遞區號之間的距離需要存取包含每個郵遞區號的緯度和經度資訊的資料庫代碼。本問題探討如何使用 MySQL 表中的資料計算此距離。
解
建議的解法利用 PHP 函數來計算給定兩點之間的距離緯度和經度。程式碼如下:
<code class="php">function calc_distance($point1, $point2) { // Constants $radius = 3958; // Earth's radius (miles) $deg_per_rad = 57.29578; // Number of degrees/radian (for conversion) $distance = ($radius * pi() * sqrt( ($point1['lat'] - $point2['lat']) * ($point1['lat'] - $point2['lat']) + cos($point1['lat'] / $deg_per_rad) // Convert to radians for cos() * cos($point2['lat'] / $deg_per_rad) // Convert to radians for cos() * ($point1['long'] - $point2['long']) * ($point1['long'] - $point2['long']) ) / 180); return $distance; // Returned using the units used for $radius. }</code>
USAGE
此函數需要兩個資料點($point1 和$point2)作為參數,每個資料點包含一個點的緯度和經度郵遞區號。返回的距離將採用與提供的半徑常數相同的單位(在本例中為英里)。
以上是如何在 PHP 中計算兩個郵遞區號之間的距離?的詳細內容。更多資訊請關注PHP中文網其他相關文章!