搜索附近的人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 相关文章推荐
第五节 克隆 [5]
Oct 09 PHP
表单复选框向PHP传输数据的代码
Nov 13 PHP
PHP版国家代码、缩写查询函数代码
Aug 14 PHP
php 批量添加多行文本框textarea一行一个
Jun 03 PHP
初识php MVC
Sep 10 PHP
PHP对文件进行加锁、解锁实例
Jan 23 PHP
PHP中SSO Cookie登录分析和实现
Nov 06 PHP
用HTML/JS/PHP方式实现页面延时跳转的简单实例
Jul 18 PHP
PHP中Cookie的使用详解(简单易懂)
Apr 28 PHP
详解PHP字符串替换str_replace()函数四种用法
Oct 13 PHP
thinkphp5 migrate数据库迁移工具
Feb 20 PHP
PhpStorm配置Xdebug调试的方法步骤
Feb 02 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开发的微信现金红包功能示例
2017/06/29 PHP
php实现支付宝当面付(扫码支付)功能
2018/05/30 PHP
JavaScript 版本自动生成文章摘要
2008/07/23 Javascript
web的各种前端打印方法之jquery打印插件jqprint实现网页打印
2013/01/09 Javascript
js confirm()方法的使用方法实例
2013/07/13 Javascript
js去除空格的12种实用方法
2013/11/08 Javascript
js 一个关于图片onload加载的事
2013/11/10 Javascript
屏蔽script注入小例子
2013/11/12 Javascript
jQuery中:file选择器用法实例
2015/01/04 Javascript
yarn与npm的命令行小结
2016/10/20 Javascript
浅析bootstrap原理及优缺点
2017/03/19 Javascript
在 Angular 中使用Chart.js 和 ng2-charts的示例代码
2017/08/17 Javascript
浅谈angular4 ng-content 中隐藏的内容
2017/08/18 Javascript
详解Vue路由钩子及应用场景(小结)
2017/11/07 Javascript
vue+element的表格实现批量删除功能示例代码
2018/08/17 Javascript
使用vue引入maptalks地图及聚合效果的实现
2020/08/10 Javascript
探索浏览器页面关闭window.close()的使用详解
2020/08/21 Javascript
[54:54]Newbee vs Serenity 2018国际邀请赛小组赛BO2 第一场 8.17
2018/08/18 DOTA
Python元组及文件核心对象类型详解
2018/02/11 Python
Python根据已知邻接矩阵绘制无向图操作示例
2018/06/23 Python
python生成1行四列全2矩阵的方法
2018/08/04 Python
pandas dataframe添加表格框线输出的方法
2019/02/08 Python
python中的列表与元组的使用
2019/08/08 Python
python3中利用filter函数输出小于某个数的所有回文数实例
2019/11/24 Python
Python栈的实现方法示例【列表、单链表】
2020/02/22 Python
Python接口测试数据库封装实现原理
2020/05/09 Python
python切割图片的示例
2020/11/12 Python
使用OpenCV校准鱼眼镜头的方法
2020/11/26 Python
8款使用 CSS3 实现超炫的 Loading(加载)的动画效果
2015/03/17 HTML / CSS
同步和异步有何异同,在什么情况下分别使用他们?
2012/12/28 面试题
新闻学毕业生自荐信
2013/11/15 职场文书
信息与计算科学专业推荐信
2014/02/23 职场文书
医德医风演讲稿
2014/05/20 职场文书
Go遍历struct,map,slice的实现
2021/06/13 Golang
PostgreSQL数据库创建并使用视图以及子查询
2022/04/11 PostgreSQL
pandas时间序列之pd.to_datetime()的实现
2022/06/16 Python