搜索附近的人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中通过smtp发邮件的类,测试通过
Jan 22 PHP
用PHP调用Oracle存储过程的方法
Sep 12 PHP
php 删除数组元素
Jan 16 PHP
在yii中新增一个用户验证的方法详解
Jun 20 PHP
mac下安装nginx和php
Nov 04 PHP
php 伪静态之IIS篇
Jun 02 PHP
php使用GeoIP库实例
Jun 27 PHP
PHP学习笔记(二):变量详解
Apr 17 PHP
一个简单至极的PHP缓存类代码
Oct 23 PHP
PHP与SQL语句常用大全
Dec 10 PHP
PHP实现用session来实现记录用户登陆信息
Oct 15 PHP
PHP PDOStatement::errorInfo讲解
Jan 31 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
谈一谈收音机的高放电路
2021/03/02 无线电
php记录日志的实现代码
2011/08/08 PHP
PHP常用技巧总结(附函数代码)
2012/02/04 PHP
基于PHP常用字符串的总结(待续)
2013/06/07 PHP
10分钟学会写Jquery插件实例教程
2014/09/06 Javascript
浅析javascript 定时器
2014/12/23 Javascript
分析了一下JQuery中的extend方法实现原理
2015/02/27 Javascript
JavaScript的面向对象编程基础
2015/08/13 Javascript
基于javascript实现文字无缝滚动效果
2016/03/22 Javascript
jQuery实现简单的tab标签页效果
2016/09/12 Javascript
深入理解JavaScript中的块级作用域、私有变量与模块模式
2016/10/31 Javascript
vue中配置mint-ui报css错误问题的解决方法
2017/10/11 Javascript
jquery UI实现autocomplete在获取焦点时得到显示列表功能示例
2019/06/04 jQuery
微信小程序swiper禁止用户手动滑动代码实例
2019/08/23 Javascript
前端开发基础javaScript的六大作用
2020/08/06 Javascript
ES2020让代码更优美的运算符 (?.) (??)
2021/01/04 Javascript
[02:44]2014DOTA2 国际邀请赛中国区预选赛 大神红毯秀
2014/05/25 DOTA
在Python中操作时间之tzset()方法的使用教程
2015/05/22 Python
深入理解Python中各种方法的运作原理
2015/06/15 Python
Python二分查找详解
2015/09/13 Python
使用Python生成随机密码的示例分享
2016/02/18 Python
20招让你的Python飞起来!
2016/09/27 Python
浅析python打包工具distutils、setuptools
2018/04/20 Python
python验证身份证信息实例代码
2019/05/06 Python
python opencv调用笔记本摄像头
2019/08/28 Python
pandas将多个dataframe以多个sheet的形式保存到一个excel文件中
2019/10/10 Python
PyTorch中torch.tensor与torch.Tensor的区别详解
2020/05/18 Python
Python命令行参数定义及需要注意的地方
2020/11/30 Python
FORZIERI澳大利亚站:全球顶级奢华配饰精品店
2016/12/31 全球购物
个人简历自荐信
2013/12/05 职场文书
文明寝室申报材料
2014/05/12 职场文书
2014教师个人自我评价范文
2014/09/13 职场文书
四风批评与自我批评发言稿
2014/10/14 职场文书
公司经营目标责任书
2015/01/29 职场文书
狂人日记读书笔记
2015/06/30 职场文书
mysql批量新增和存储的方法实例
2021/04/07 MySQL