搜索附近的人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 缩略图实现函数代码
Jun 23 PHP
如何使用php绘制在图片上的正余弦曲线
Jun 08 PHP
php生成zip压缩文件的方法详解
Jun 09 PHP
php实现压缩多个CSS与JS文件的方法
Nov 11 PHP
WebQQ最新登陆协议的用法
Dec 22 PHP
在php和MySql中计算时间差的方法详解
Mar 27 PHP
PHP开发中AJAX技术的简单应用
Dec 11 PHP
PHP 实现页面静态化的几种方法
Jul 23 PHP
php实现的redis缓存类定义与使用方法示例
Aug 09 PHP
thinkphp ajaxfileupload实现异步上传图片的示例
Aug 28 PHP
php安装扩展mysqli的实现步骤及报错解决办法
Sep 23 PHP
php ZipArchive实现多文件打包下载实例
Oct 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
PHP 数据库树的遍历方法
2009/02/06 PHP
PHP中执行MYSQL事务解决数据写入不完整等情况
2014/01/07 PHP
PHP生成json和xml类型接口数据格式
2015/05/17 PHP
CodeIgniter配置之routes.php用法实例分析
2016/01/19 PHP
在IIS下安装PHP扩展的方法(超简单)
2017/04/10 PHP
php生成随机数/生成随机字符串的方法小结【5种方法】
2020/05/27 PHP
javascript编程起步(第五课)
2007/01/10 Javascript
番茄的表单验证类代码修改版
2008/07/18 Javascript
动态加载图片路径 保持JavaScript控件的相对独立性
2010/09/03 Javascript
js 处理数组重复元素示例代码
2013/12/27 Javascript
jquery得到iframe src属性值的方法
2014/09/25 Javascript
javascript折半查找详解
2015/01/26 Javascript
javascript图片预加载完整实例
2015/12/10 Javascript
Bootstrap编写一个同时适用于PC、平板、手机的登陆页面
2016/06/30 Javascript
浅析JavaScript中break、continue和return的区别
2016/11/30 Javascript
angular2+nodejs实现图片上传功能
2017/03/27 NodeJs
Bootstrap Table使用整理(二)
2017/06/09 Javascript
zTree树形插件异步加载方法详解
2017/06/14 Javascript
jQuery实现的事件绑定功能基本示例
2017/10/11 jQuery
Vue的全局过滤器和私有过滤器的实现
2020/04/20 Javascript
vue项目接口管理,所有接口都在apis文件夹中统一管理操作
2020/08/13 Javascript
python3实现ftp服务功能(服务端 For Linux)
2017/03/24 Python
Python实现求笛卡尔乘积的方法
2017/09/16 Python
Python中装饰器高级用法详解
2017/12/25 Python
python多维数组切片方法
2018/04/13 Python
pandas使用apply多列生成一列数据的实例
2018/11/28 Python
python实现的MySQL增删改查操作实例小结
2018/12/19 Python
Python基础之条件控制操作示例【if语句】
2019/03/23 Python
python的time模块和datetime模块实例解析
2019/11/29 Python
使用pytorch实现论文中的unet网络
2020/06/24 Python
印尼美容产品购物网站:PerfectBeauty.id
2017/12/01 全球购物
小学生环保倡议书
2014/05/15 职场文书
停水通知
2015/04/16 职场文书
新年晚会主持词开场白
2015/05/28 职场文书
标准版个人借条怎么写?以及什么是借条?
2019/08/28 职场文书
vue router 动态路由清除方式
2022/05/25 Vue.js