搜索附近的人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实现javascript的escape和unescape函数
Jun 29 PHP
PHP生成验证码时“图像因其本身有错无法显示”的解决方法
Aug 07 PHP
Zend studio文件注释模板设置方法
Sep 29 PHP
在PHP中使用X-SendFile头让文件下载更快
Jun 01 PHP
PHP自带函数给数字或字符串自动补齐位数
Jul 29 PHP
又一个PHP实现的冒泡排序算法分享
Aug 21 PHP
ThinkPHP实例化模型的四种方法概述
Aug 22 PHP
php基于双向循环队列实现历史记录的前进后退等功能
Aug 08 PHP
PHP将MySQL的查询结果转换为数组并用where拼接的示例
May 13 PHP
php版微信开发之接收消息,自动判断及回复相应消息的方法
Sep 23 PHP
PHP设计模式之注册树模式分析
Jan 26 PHP
PHP快速导出百万级数据到CSV或者EXCEL文件
Nov 27 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新手上路(十二)
2006/10/09 PHP
采用header定义为文件然后readfile下载(隐藏下载地址)
2014/01/31 PHP
PHP传参之传值与传址的区别
2015/04/24 PHP
php eval函数一句话木马代码
2015/05/21 PHP
PHP设计模式之 策略模式Strategy详解【对象行为型】
2020/05/01 PHP
认识延迟时间为0的setTimeout
2008/05/16 Javascript
JavaScript 学习技巧
2010/02/17 Javascript
javascript面向对象编程代码
2011/12/19 Javascript
详解jQuery中的元素的属性和相关操作
2015/08/14 Javascript
老生常谈jacascript DOM节点获取
2017/04/17 Javascript
微信小程序商城项目之商品属性分类(4)
2017/04/17 Javascript
React入门教程之Hello World以及环境搭建详解
2017/07/11 Javascript
深入浅析Vue中的slots/scoped slots
2018/04/03 Javascript
Webpack之tree-starking 解析
2018/09/11 Javascript
基于游标的分页接口实现代码示例
2018/11/12 Javascript
[00:10]DOTA2 TI9勇士令状明日上线
2019/05/07 DOTA
python 判断自定义对象类型
2009/03/21 Python
python机器学习理论与实战(四)逻辑回归
2018/01/19 Python
python队列Queue的详解
2019/05/10 Python
python 画出使用分类器得到的决策边界
2019/08/21 Python
python list转置和前后反转的例子
2019/08/26 Python
pytorch使用tensorboardX进行loss可视化实例
2020/02/24 Python
基于tensorflow for循环 while循环案例
2020/06/30 Python
python实现AdaBoost算法的示例
2020/10/03 Python
Peter Millar官网:美国高档生活服饰品牌
2018/07/02 全球购物
安踏官方商城:anta.cn
2019/12/16 全球购物
美术师范毕业生自荐信
2013/11/16 职场文书
个人查摆剖析材料
2014/02/04 职场文书
质量承诺书范文
2014/03/27 职场文书
献爱心活动总结
2014/05/07 职场文书
献爱心大型公益活动策划方案
2014/09/15 职场文书
酒店财务总监岗位职责
2015/04/03 职场文书
小学生安全教育主题班会
2015/08/12 职场文书
《学会看病》教学反思
2016/02/17 职场文书
fastdfs+nginx集群搭建的实现
2021/03/31 Servers
Win11 BitLocker 驱动器加密
2022/04/19 数码科技