本文實例為大家分享了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+ajax做仿百度搜索下拉自動提示框(有實例)
- php啟用sphinx全文搜索的實現方法
- php站內搜索并高亮顯示關鍵字的實現代碼
- PHP 搜索查詢功能實現
- php 搜索框提示(自動完成)實例代碼
- jquery+php實現搜索框自動提示
- ThinkPHP讓分頁保持搜索狀態的方法
- php使用正則表達式進行字符串搜索的方法
- 利用PHP+JS實現搜索自動提示(實例)