搜索附近的人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中创建并处理图象
Oct 09 PHP
我的论坛源代码(二)
Oct 09 PHP
《PHP编程最快明白》第三讲:php数组
Nov 01 PHP
通过JavaScript或PHP检测Android设备的代码
Mar 09 PHP
一个PHP验证码类代码分享(已封装成类)
Jul 17 PHP
Linux下CoreSeek及PHP扩展模块的安装
Sep 23 PHP
php生成二维码的几种方式整理及使用实例
Jun 03 PHP
教你识别简单的免查杀PHP后门
Sep 13 PHP
PHP查看SSL证书信息的方法
Sep 22 PHP
PHP单态模式简单用法示例
Nov 16 PHP
thinkPHP中U方法加密传递参数功能示例
May 29 PHP
PHP页面静态化――纯静态与伪静态用法详解
Jun 05 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地址段访问的方法
2015/02/25 PHP
php自动更新版权信息显示的方法
2015/06/19 PHP
基于php数组中的索引数组和关联数组详解
2018/03/12 PHP
PHP进阶学习之垃圾回收机制详解
2019/06/18 PHP
js导出txt示例代码
2014/01/14 Javascript
javascript模拟订火车票和退票示例
2014/04/24 Javascript
JS实现滑动菜单效果代码(包括Tab,选项卡,横向等效果)
2015/09/24 Javascript
Dojo获取下拉框的文本和值实例代码
2016/05/27 Javascript
Angular.js中用ng-repeat-start实现自定义显示
2016/10/18 Javascript
JS伪继承prototype实现方法示例
2018/06/20 Javascript
Vuejs+vue-router打包+Nginx配置的实例
2018/09/20 Javascript
详解element-ui日期时间选择器的日期格式化问题
2019/04/08 Javascript
Vue组件实现触底判断
2019/06/26 Javascript
Vue自定义render统一项目组弹框功能
2020/06/07 Javascript
五句话帮你轻松搞定js原型链
2020/12/09 Javascript
javascript实现移动端轮播图
2020/12/09 Javascript
[01:02]DOTA2上海特锦赛SHOWOPEN
2016/03/25 DOTA
Python设计模式之观察者模式实例
2014/04/26 Python
基于python 二维数组及画图的实例详解
2018/04/03 Python
python批量导入数据进Elasticsearch的实例
2018/05/30 Python
对Python通过pypyodbc访问Access数据库的方法详解
2018/10/27 Python
Django 批量插入数据的实现方法
2020/01/12 Python
使用 HTML5 Canvas 制作水波纹效果点击图片就会触发
2014/09/15 HTML / CSS
雅萌 (YA-MAN) :日本美容家电领域的龙头企业
2017/05/12 全球购物
台湾旅游网站:雄狮旅游网
2017/08/16 全球购物
飞利浦美国官网:Philips美国
2020/02/28 全球购物
精选鞋类、服装和配饰的全球领先目的地:Bodega
2021/02/27 全球购物
英国领先的在线鱼贩:The Fish Society
2020/08/12 全球购物
人力资源管理专业应届生求职信
2013/09/28 职场文书
网络工程师个人的自我评价范文
2013/10/01 职场文书
旷课检讨书3000字
2014/02/04 职场文书
党支部对照检查材料
2014/08/25 职场文书
2014镇党委班子对照检查材料思想汇报
2014/09/23 职场文书
婚前协议书范本
2014/10/27 职场文书
复制别人的成功真的会成功吗?
2019/10/17 职场文书
「偶像大师 MILLION LIVE!」七尾百合子手办开订
2022/03/21 日漫