搜索附近的人PHP实现代码


Posted in PHP onFebruary 11, 2018

本文实例为大家分享了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 相关文章推荐
我的论坛源代码(二)
Oct 09 PHP
PHP生成静态页面详解
Nov 19 PHP
用PHP生成静态HTML速度快类库
Mar 18 PHP
PHP实现批量生成App各种尺寸Logo
Mar 19 PHP
php函数连续调用实例分析
Jul 30 PHP
php生成4位数字验证码的实现代码
Nov 23 PHP
PHP常用设计模式之委托设计模式
Feb 13 PHP
PHP在线调试执行的实现方法(附demo源码)
Apr 28 PHP
PHP XML和数组互相转换详解
Oct 26 PHP
Linux平台php命令行程序处理管道数据的方法
Nov 10 PHP
Zend Framework动作控制器用法示例
Dec 09 PHP
PHP实现的mongoDB数据库操作类完整实例
Apr 10 PHP
PHP的RSA加密解密方法以及开发接口使用
Feb 11 #PHP
php+ajax实现无刷新文件上传功能(ajaxuploadfile)
Feb 11 #PHP
PHP实现的多维数组排序算法分析
Feb 10 #PHP
ThinkPHP整合datatables实现服务端分页的示例代码
Feb 10 #PHP
PHP实现APP微信支付的实例讲解
Feb 10 #PHP
PHP有序表查找之插值查找算法示例
Feb 10 #PHP
PHP有序表查找之二分查找(折半查找)算法示例
Feb 09 #PHP
You might like
根德Grundig S400/S500/S700电路分析
2021/03/02 无线电
php设计模式 State (状态模式)
2011/06/26 PHP
浅谈thinkphp的实例化模型
2015/01/04 PHP
如何使用纯PHP实现定时器任务(Timer)
2015/07/31 PHP
PHP实现防盗链的方法分析
2017/07/25 PHP
PHP实现的权重算法示例【可用于游戏根据权限来随机物品】
2019/02/15 PHP
用jquery实现自定义风格的滑动条实现代码
2011/04/26 Javascript
jquery实现通用版鼠标经过淡入淡出效果
2014/06/15 Javascript
escape编码与unescape解码汉字出现乱码的解决方法
2014/07/02 Javascript
jQuery网页选项卡插件rTabs用法实例分析
2015/08/26 Javascript
jQuery Validate插件实现表单验证
2016/08/19 Javascript
微信小程序 wxapp内容组件 text详细介绍
2016/10/31 Javascript
浅谈Angular.js中使用$watch监听模型变化
2017/01/10 Javascript
vue2 全局变量的设置方法
2018/03/09 Javascript
vue cli3.0 引入eslint 结合vscode使用
2019/05/27 Javascript
vue使用codemirror的两种用法
2019/08/27 Javascript
JS实现水平移动与垂直移动动画
2019/12/19 Javascript
微信小程序实现下拉加载更多商品
2020/12/29 Javascript
跨平台python异步回调机制实现和使用方法
2013/11/26 Python
Python进程间通信Queue实例解析
2018/01/25 Python
Python实现读取Properties配置文件的方法
2018/03/29 Python
Python 比较文本相似性的方法(difflib,Levenshtein)
2018/10/15 Python
python反转列表的三种方式解析
2019/11/08 Python
Python正则表达式急速入门(小结)
2019/12/16 Python
python给list排序的简单方法
2020/12/10 Python
简单介绍CSS3中Media Query的使用
2015/07/07 HTML / CSS
采购员的工作职责
2013/12/26 职场文书
读群众路线心得体会
2014/03/07 职场文书
美术指导助理求职信
2014/04/20 职场文书
本科应届生自荐信
2014/06/29 职场文书
会计试用期自我评价怎么写
2014/09/18 职场文书
县政府班子个人对照检查材料
2014/10/05 职场文书
个人总结与自我评价2015
2015/03/11 职场文书
勤俭节约主题班会
2015/08/13 职场文书
JavaScript使用canvas绘制坐标和线
2021/04/28 Javascript
原生JS实现飞机大战小游戏
2021/06/09 Javascript