当前位置: 首页 > news >正文

PHP/Laravel通过经纬度计算距离获取附近商家

实际开发中,常常需要获取用户附近的商家,思路是

  • 获取用户位置(经纬度信息)
  • 在数据库中查询在距离范围内的商家

注: 本文章内计算距离所使用地球半径统一为 6378.138 km

public function mpa_list($latitude,$longitude,$distance){// $latitude = 34.306465;// $longitude = 109.050952;// $distance = 5;//1.计算最大最小经纬度范围$range  = 180 / pi() * $distance / 6378.138; //搜索 N km 之内$lngR   = $range / cos($latitude * pi() / 180);$maxLat = $latitude + $range; //最大纬度$minLat = $latitude - $range; //最小纬度$maxLng = $longitude + $lngR; //最大经度$minLng = $longitude - $lngR; //最小经度//2.查找经纬度符合条件的商家$list = Village::select("id","title","longitude","latitude")->whereBetween('latitude', [$minLat, $maxLat])->whereBetween('longitude', [$minLng, $maxLng])->where('status', 1)->get();//3.计算距离foreach ($list as &$item){$item['distance'] = $this->getDistanceBy2Point([$longitude, $latitude], [$item['longitude'], $item['latitude']]);}if($list){$list = $list->toArray();}//4.排序$list = $this->arraySort($list, 'distance');return $list;}

二维数组排序方法

// 二维数组排序方法public static function arraySort($arr, $field, $sort = SORT_ASC){$key = array_column($arr, $field);array_multisort($key, $sort, $arr);return $arr;}

根据经纬度计算两点距离

    /*** 根据起点坐标和终点坐标测距离* @param  [array]   $from     [起点坐标(经纬度),例如:array(118.012951,36.810024)]* @param  [array]   $to     [终点坐标(经纬度)]* @param  [bool]    $km        是否以公里为单位 false:米 true:公里(千米)* @param  [int]     $decimal   精度 保留小数位数* @return [string]  距离数值*/public static function getDistanceBy2Point($from, $to, $km = true, $decimal = 2){sort($from);sort($to);$EARTH_RADIUS = 6378.138; // 地球半径系数$distance = $EARTH_RADIUS*2*asin(sqrt(pow(sin( ($from[0]*pi()/180-$to[0]*pi()/180)/2),2)+cos($from[0]*pi()/180)*cos($to[0]*pi()/180)* pow(sin( ($from[1]*pi()/180-$to[1]*pi()/180)/2),2)))*1000;if($km && $distance > 1000){return round($distance / 1000, 2) . 'km';}return round($distance, $decimal) . 'm';}

实际测试:我这边的测试数据比较少,我就用了50公里范围之内的。因为我的数据库里面只添加了连个测试商家,大家将就看一下,理解了就行了。

http://www.lryc.cn/news/237591.html

相关文章:

  • grafana面板介绍
  • 实验三 循环结构程序设计(Python)
  • Flutter笔记:目录与文件存储以及在Flutter中的使用(上)
  • 注意了!申请流量卡时地址一定不要填写学校,不好下卡哦!
  • minio使用shell上传文件
  • LeetCode538. Convert BST to Greater Tree
  • iPaaS和RPA,企业自动化应该如何选择?
  • AI实践与学习1_Milvus向量数据库实践与原理分析
  • 3Dexcite deltgen 2022x 新功能
  • 代码随想录算法训练营第六十天 | LeetCode 84. 柱状图中最大的矩形
  • 【2023云栖】陈守元:阿里云开源大数据产品年度发布
  • Element UI 禁用数字输入框组件添加鼠标滚动事件
  • 担忧CentOS停服?KeyarchOS系统来支撑
  • 聚观早报 |联想集团Q2财季业绩;小鹏汽车Q3营收
  • SAP ABAP权限控制中常用TCODE
  • 云计算赛项容器云2023搭建
  • 11.1 文件拷贝移动与删除
  • redhat下使用CentOS yum源,并安装docker
  • 基于单片机体温脉搏检测控制系统及源程序
  • MyBatis-Plus逻辑删@TableLogic
  • 本地私域线上线下 线上和线下的小程序
  • 【前端学java】java中的Object类(8)
  • TensorFlow实战教程(二十六)-什么是生成对抗网络GAN?基础原理和代码普及
  • IDEA版SSM入门到实战(Maven+MyBatis+Spring+SpringMVC) -Maven依赖管理,版本号管理,继承和聚合
  • OpenVPN Connect使用连接公网VPN服务器实现内网穿透
  • Redis(集合Set和有序集合SortedSet)
  • 黔院长 | 《黄帝内经》——奇病论!
  • 手撕单链表(C语言)
  • 60 权限提升-MYMSORA等SQL数据库提权
  • 【C++上层应用】2. 预处理器