婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 搜索附近的人PHP實現代碼

搜索附近的人PHP實現代碼

熱門標簽:長沙crm外呼系統業務 江蘇外呼電銷機器人報價 400電話申請方法收費 深圳外呼系統收費 南寧高頻外呼回撥系統哪家好 離石地圖標注 專業電話機器人批發商 電話機器人危險嗎 400電話辦理福州市

本文實例為大家分享了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實現搜索自動提示(實例)

標簽:株洲 濱州 白酒營銷 興安盟 南昌 曲靖 南京 太原

巨人網絡通訊聲明:本文標題《搜索附近的人PHP實現代碼》,本文關鍵詞  搜索,附,近的,人,PHP,實現,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《搜索附近的人PHP實現代碼》相關的同類信息!
  • 本頁收集關于搜索附近的人PHP實現代碼的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 腾冲县| 上蔡县| 正定县| 南召县| 定南县| 新竹市| 杭州市| 禹州市| 邢台市| 临海市| 广汉市| 曲水县| 陇南市| 孙吴县| 莱芜市| 开江县| 南澳县| 冷水江市| 新野县| 即墨市| 西林县| 探索| 昂仁县| 西安市| 大宁县| 瓦房店市| 衡山县| 博罗县| 天津市| 合水县| 玉溪市| 疏附县| 澄迈县| 西林县| 汽车| 乐平市| 镇安县| 吉安县| 福清市| 本溪| 芷江|