搜索附近的人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中利用XML技术构造远程服务(上)
Oct 09 PHP
PHP实现文件安全下载
Oct 09 PHP
在PHP3中实现SESSION的功能(三)
Oct 09 PHP
PHP 获取MSN好友列表的代码(2009-05-14测试通过)
Sep 09 PHP
PHP中json_encode、json_decode与serialize、unserialize的性能测试分析
Jun 09 PHP
php 面试碰到过的问题 在此做下记录
Jun 09 PHP
PHP简单实现无限级分类的方法
May 13 PHP
php版微信公众号接口实现发红包的方法
Oct 14 PHP
phpinfo无法显示的原因及解决办法
Feb 15 PHP
php curl发送请求实例方法
Aug 01 PHP
laravel5.2表单验证,并显示错误信息的实例
Sep 29 PHP
TP3.2框架分页相关实现方法分析
Jun 03 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
为查询结果建立向后/向前按钮
2006/10/09 PHP
PHP 中 Orientation 属性判断上传图片是否需要旋转
2015/10/16 PHP
js去除空格的12种实用方法
2013/11/08 Javascript
javascript怎么禁用浏览器后退按钮
2014/03/27 Javascript
javascript定时器完整实例
2015/02/10 Javascript
JavaScript实现多个重叠层点击切换效果的方法
2015/04/24 Javascript
js中setTimeout()与clearTimeout()用法实例浅析
2015/05/12 Javascript
javascript图片延迟加载实现方法及思路
2015/12/31 Javascript
浅谈JavaScript 浏览器对象
2016/06/03 Javascript
JQuery异步加载PartialView的方法
2016/06/07 Javascript
Nodejs 发送Post请求功能(发短信验证码例子)
2017/02/09 NodeJs
浅谈$_FILES数组为空的原因
2017/02/16 Javascript
微信小程序实现页面跳转传值的方法
2017/10/12 Javascript
关于Webpack dev server热加载失败的解决方法
2018/02/22 Javascript
解决Echarts2竖直datazoom滑动后显示数据不全的问题
2020/07/20 Javascript
Element Popover 弹出框的使用示例
2020/07/26 Javascript
Python程序员开发中常犯的10个错误
2014/07/07 Python
Python Queue模块详细介绍及实例
2016/12/27 Python
django框架如何集成celery进行开发
2017/05/24 Python
python实现关键词提取的示例讲解
2018/04/28 Python
Python实现多线程的两种方式分析
2018/08/29 Python
Python3中内置类型bytes和str用法及byte和string之间各种编码转换 问题
2018/09/27 Python
Python发展史及网络爬虫
2019/06/19 Python
pygame实现五子棋游戏
2019/10/29 Python
Python 矩阵转置的几种方法小结
2019/12/02 Python
如何使用PyCharm将代码上传到GitHub上(图文详解)
2020/04/27 Python
Python实现列表中非负数保留,负数转化为指定的数值方式
2020/06/04 Python
Python3如何实现Win10桌面自动切换
2020/08/11 Python
Python Pygame实现俄罗斯方块
2021/02/19 Python
HTML5自定义元素播放焦点图动画的实现
2019/09/25 HTML / CSS
酒店执行总经理岗位职责
2013/12/15 职场文书
教师个人鉴定材料
2014/02/08 职场文书
2014年单位法制宣传日活动总结
2014/11/01 职场文书
2014年音乐教师工作总结
2014/12/03 职场文书
详解jQuery的核心函数和事件处理
2022/02/18 jQuery
微软团队与 NASA 科学家和惠普企业(HPE)的工程师合作
2022/04/21 数码科技