搜索附近的人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 相关文章推荐
PHP 编程的 5个良好习惯
Feb 20 PHP
9个PHP开发常用功能函数小结
Jul 15 PHP
yii框架配置默认controller和action示例
Apr 30 PHP
ThinkPHP权限认证Auth实例详解
Jul 22 PHP
php根据某字段对多维数组进行排序的方法
Mar 07 PHP
使用PHP如何实现高效安全的ftp服务器(一)
Dec 20 PHP
PHP模块化安装教程
Jun 01 PHP
利用PHP抓取百度阅读的方法示例
Dec 18 PHP
php7安装mongoDB扩展的方法分析
Aug 02 PHP
PDO::commit讲解
Jan 27 PHP
PHP中的Iterator迭代对象属性详解
Apr 12 PHP
php集成开发环境详解
Sep 24 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
xss防御之php利用httponly防xss攻击
2014/03/21 PHP
php5.3不能连接mssql数据库的解决方法
2014/12/27 PHP
PHP 正则表达式小结
2015/02/12 PHP
使用prototype.js 的时候应该特别注意的几个问题.
2007/04/12 Javascript
响应鼠标变换表格背景或者颜色的代码
2009/03/30 Javascript
javascript 得到变量类型的函数
2010/05/19 Javascript
去掉gridPanel表头全选框的小例子
2013/07/18 Javascript
使用jquery实现以post打开新窗口
2014/03/19 Javascript
常用的Javascript数据验证插件
2015/08/04 Javascript
详解JavaScript UTC时间转换方法
2016/01/07 Javascript
Node.js+Express配置入门教程
2016/05/19 Javascript
js创建对象几种方式的优缺点对比
2016/09/28 Javascript
利用nginx + node在阿里云部署https的步骤详解
2017/12/19 Javascript
Angular5中提取公共组件之radio list的实例代码
2018/07/10 Javascript
vue debug 二种方法
2018/09/16 Javascript
Vue+ElementUI table实现表格分页
2019/12/14 Javascript
JavaScript单线程和任务队列原理解析
2020/02/04 Javascript
JavaScript实现PC端横向轮播图
2020/02/07 Javascript
Vue使用Three.js加载glTF模型的方法详解
2020/06/14 Javascript
原生js滑动轮播封装
2020/07/31 Javascript
python socket网络编程步骤详解(socket套接字使用)
2013/12/06 Python
python基础教程之字典操作详解
2014/03/25 Python
python django集成cas验证系统
2014/07/14 Python
Python中关键字is与==的区别简述
2014/07/31 Python
python3 pillow生成简单验证码图片的示例
2017/09/19 Python
Python字符串和正则表达式中的反斜杠('\')问题详解
2019/09/03 Python
opencv python图像梯度实例详解
2020/02/04 Python
pycharm远程连接vagrant虚拟机中mariadb数据库
2020/06/05 Python
Python实现手绘图效果实例分享
2020/07/22 Python
意大利在线大学图书馆:Libreria universitaria
2019/07/16 全球购物
期终自我鉴定
2014/02/17 职场文书
汽车销售经理岗位职责
2014/06/09 职场文书
垃圾桶标语
2014/06/24 职场文书
2014年纪委工作总结
2014/12/05 职场文书
js实现自动锁屏功能
2021/06/02 Javascript
Python中的socket网络模块介绍
2022/07/23 Python