您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關如何使用php實現搜索附近的人的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
本文實例為大家分享了PHP實現搜索附近的人具體代碼,供大家參考,具體內容如下
實現思路:
首先,我們應該這樣想: 既然我們知道了用戶當前位置的經緯度,又知道我們將要搜索的范圍,我們可不可以計算出一個范圍 ?也就是說,根據一個中心點和半徑,計算出符合條件的經緯度的最大值和最小值 。
具體實現:
那么到此,想要獨立思考完成的小伙伴可以不要繼續往下看了。
上面我們提到該功能的一個實現原理,接下來我們就講解一下具體的實現步驟。
我們先聲明一個函數,用作計算經緯度的范圍:
/** * 根據經緯度和半徑計算出范圍 * @param string $lat 緯度 * @param String $lng 經度 * @param float $radius 半徑 * @return Array 范圍數組 */ private function calcScope($lat, $lng, $radius) { $degree = (24901*1609)/360.0; $dpmLat = 1/$degree; $radiusLat = $dpmLat*$radius; $minLat = $lat - $radiusLat; // 最小緯度 $maxLat = $lat + $radiusLat; // 最大緯度 $mpdLng = $degree*cos($lat * (PI/180)); $dpmLng = 1 / $mpdLng; $radiusLng = $dpmLng*$radius; $minLng = $lng - $radiusLng; // 最小經度 $maxLng = $lng + $radiusLng; // 最大經度 /** 返回范圍數組 */ $scope = array( 'minLat' => $minLat, 'maxLat' => $maxLat, 'minLng' => $minLng, 'maxLng' => $maxLng ); return $scope; }
返回的數組中包含了在 $radius 范圍內,符合條件的最大最小經緯度。
既然我們已經獲取到了范圍,那么我們就可以開始從數據庫中查找所有在這個經緯度范圍內符合條件的記錄:
/** * 根據經緯度和半徑查詢在此范圍內的所有的電站 * @param String $lat 緯度 * @param String $lng 經度 * @param float $radius 半徑 * @return Array 計算出來的結果 */ public function searchByLatAndLng($lat, $lng, $radius) { $scope = $this->calcScope($lat, $lng, $radius); // 調用范圍計算函數,獲取最大最小經緯度 /** 查詢經緯度在 $radius 范圍內的電站的詳細地址 */ $sql = 'SELECT `字段` FROM `表名` WHERE `Latitude` < '.$scope['maxLat'].' and `Latitude` > '.$scope['minLat'].' and `Longitude` < '.$scope['maxLng'].' and `Longitude` > '.$scope['minLng']; $stmt = self::$db->query($sql); $res = $stmt->fetchAll(PDO::FETCH_ASSOC); // 獲取查詢結果并返回 return $res; }
擴展:
直到現在,我們已經知道了如何計算出附近的人,但在實際需求中,我們往往需要計算出每一個人與當前中心點的實際距離。
接著,我們再來看一個方法:
/** * 獲取兩個經緯度之間的距離 * @param string $lat1 緯一 * @param String $lng1 經一 * @param String $lat2 緯二 * @param String $lng2 經二 * @return float 返回兩點之間的距離 */ public function calcDistance($lat1, $lng1, $lat2, $lng2) { /** 轉換數據類型為 double */ $lat1 = doubleval($lat1); $lng1 = doubleval($lng1); $lat2 = doubleval($lat2); $lng2 = doubleval($lng2); /** 以下算法是 Google 出來的,與大多數經緯度計算工具結果一致 */ $theta = $lng1 - $lng2; $dist = sin(deg2rad($lat1)) * sin(deg2rad($lat2)) + cos(deg2rad($lat1)) * cos(deg2rad($lat2)) * cos(deg2rad($theta)); $dist = acos($dist); $dist = rad2deg($dist); $miles = $dist * 60 * 1.1515; return ($miles * 1.609344); }
感謝各位的閱讀!關于“如何使用php實現搜索附近的人”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。