搜索附近的人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初学入门
Nov 19 PHP
使用eAccelerator加密PHP程序
Oct 03 PHP
生成ubuntu自动切换壁纸xml文件的php代码
Jul 17 PHP
基于PHP常用函数的用法详解
May 10 PHP
PHP下获取上个月、下个月、本月的日期(strtotime,date)
Feb 02 PHP
浅谈php和.net的区别
Sep 28 PHP
ucenter通信原理分析
Jan 09 PHP
php遍历目录方法小结
Mar 10 PHP
如何利用http协议发布博客园博文评论
Aug 03 PHP
服务器迁移php版本不同可能诱发的问题
Dec 22 PHP
PHP的Yii框架入门使用教程
Feb 15 PHP
PHP生成腾讯云COS接口需要的请求签名
May 20 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
PHP文件缓存smarty模板应用实例分析
2016/02/26 PHP
关于Laravel参数验证的一些疑与惑
2019/11/19 PHP
PHP单元测试配置与使用方法详解
2019/12/27 PHP
jquery 选择器部分整理
2009/10/28 Javascript
网页中的图片的处理方法与代码
2009/11/26 Javascript
自定义一个jquery插件[鼠标悬浮时候 出现说明label]
2011/06/27 Javascript
jquery实现动态画圆
2014/12/04 Javascript
JQuery中serialize() 序列化
2015/03/13 Javascript
JavaScript代码实现左右上下自动晃动自动移动
2016/04/08 Javascript
JS在一定时间内跳转页面及各种刷新页面的实现方法
2016/05/26 Javascript
微信小程序三级联动地址选择器的实例代码
2017/07/12 Javascript
快速解决vue-cli不能初始化webpack模板的问题
2018/03/20 Javascript
通过滑动翻页效果实现和移动端click事件问题
2021/01/26 Javascript
[44:58]2018DOTA2亚洲邀请赛 4.5 淘汰赛 LGD vs Liquid 第二场
2018/04/06 DOTA
Python实现简单截取中文字符串的方法
2015/06/15 Python
python 处理telnet返回的More,以及get想要的那个参数方法
2019/02/14 Python
python3+PyQt5 创建多线程网络应用-TCP客户端和TCP服务器实例
2019/06/17 Python
python 接口实现 供第三方调用的例子
2019/08/13 Python
pycharm修改file type方式
2019/11/19 Python
解决json中ensure_ascii=False的问题
2020/04/03 Python
文件上传服务器-jupyter 中python解压及压缩方式
2020/04/22 Python
将pymysql获取到的数据类型是tuple转化为pandas方式
2020/05/15 Python
Python3 用什么IDE开发工具比较好
2020/11/28 Python
Lookfantastic澳大利亚官网:英国知名美妆购物网站
2021/01/07 全球购物
PHP如何去执行一个SQL语句
2016/03/05 面试题
超市营业员求职简历的自我评价
2013/10/17 职场文书
给导游的表扬信
2014/01/10 职场文书
社团2014年植树节活动总结
2014/03/11 职场文书
群众路线党课主持词
2014/04/01 职场文书
双方协议书
2014/04/22 职场文书
新农村建设汇报材料
2014/08/15 职场文书
教师节活动总结
2014/08/29 职场文书
2014年度党员自我评议
2014/09/13 职场文书
淘宝好评语句大全
2014/12/31 职场文书
2015年学校综合治理工作总结
2015/07/20 职场文书
Python selenium绕过webdriver监测执行javascript
2022/04/12 Python