搜索附近的人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模板引擎SMARTY
Oct 09 PHP
PHP获取当前文件所在目录 getcwd()函数
May 13 PHP
PHP查询MySQL大量数据的时候内存占用分析
Jul 22 PHP
简单的PHP缓存设计实现代码
Sep 30 PHP
PHP中获取文件扩展名的N种方法小结
Feb 27 PHP
json的键名为数字时的调用方式(示例代码)
Nov 15 PHP
php缩放gif和png图透明背景变成黑色的解决方法
Oct 14 PHP
PHP中的traits简单使用实例
May 13 PHP
php抽象类用法实例分析
Jul 07 PHP
php实现基于openssl的加密解密方法
Sep 30 PHP
微信公众平台开发教程①获取用户Openid及个人信息图文详解
Apr 10 PHP
php进行md5加密简单实例方法
Sep 19 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 IP及IP段进行访问限制的代码
2008/12/17 PHP
PHP 类商品秒杀计时实现代码
2010/05/05 PHP
destoon整合UCenter图文教程
2014/06/21 PHP
php in_array() 检查数组中是否存在某个值详解
2016/11/23 PHP
CodeIgniter框架常见用法工作总结
2017/03/16 PHP
一个不错的仿携程自定义数据下拉选择select
2014/09/01 Javascript
5个书写JavaScript代码的坏习惯,看看你中枪了没?
2014/11/06 Javascript
jQuery获取复选框被选中数量及判断选择值的方法详解
2016/05/25 Javascript
jquery常用的12个小功能
2016/07/22 Javascript
详解nodejs微信jssdk后端接口
2017/05/25 NodeJs
全面解析Node.js 8 重要功能和修复
2017/06/02 Javascript
微信小程序 空白页重定向解决办法
2017/06/27 Javascript
JavaScript生成图形验证码
2020/08/24 Javascript
vue2.x+webpack快速搭建前端项目框架详解
2017/11/30 Javascript
Vue2.0 v-for filter列表过滤功能的实现
2018/09/07 Javascript
vue组件通信传值操作示例
2019/01/08 Javascript
js中script的上下放置区别,Dom的增删改创建操作实例分析
2019/12/16 Javascript
vue实现购物车的监听
2020/04/20 Javascript
[01:08:17]2018DOTA2亚洲邀请赛3月29日 小组赛B组 EG VS VGJ.T
2018/03/30 DOTA
python更新列表的方法
2015/07/28 Python
Python数据类型详解(三)元祖:tuple
2016/05/08 Python
python判断字符串是否是json格式方法分享
2017/11/07 Python
详解将Django部署到Centos7全攻略
2018/09/26 Python
python使用插值法画出平滑曲线
2018/12/15 Python
Python 图像对比度增强的几种方法(小结)
2019/09/25 Python
Python函数的定义方式与函数参数问题实例分析
2019/12/26 Python
HTML5 window/iframe跨域传递消息 API介绍
2013/08/26 HTML / CSS
美国渔具店:FishUSA
2019/08/07 全球购物
SmartBuyGlasses比利时:购买品牌太阳镜和眼镜
2019/08/09 全球购物
一些.net面试题
2014/10/06 面试题
本科毕业生的求职信范文
2013/11/20 职场文书
青春励志演讲稿
2014/04/29 职场文书
公司股份合作协议书
2014/12/07 职场文书
物业公司管理制度
2015/08/05 职场文书
2019年教师入党申请书
2019/06/27 职场文书
CentOS安装Nginx并部署vue
2022/04/12 Servers