www.adminn.cn
站长正能量分享网!

php实现计算百度地图坐标之间距离的方法

AD:阿里云服务器企业会员更优惠 腾讯云香港,韩国免备案服务器1.8折优惠

本文实例讲述了php实现计算百度地图坐标之间距离的方法。分享给大家供大家参考,具体如下:

下面是网上的代码,使用的时候需要进行些许修改

第一个函数是获得范围,参数为纬度经度半径

第二个函数是计算坐标距离

  1. <?php 
  2.  
  3. define('PI',3.1415926535898); 
  4.  
  5. define('EARTH_RADIUS',6378.137); 
  6.  
  7. //计算范围,可以做搜索用户 
  8.  
  9. function GetRange($lat,$lon,$raidus){ 
  10.  
  11.   //计算纬度 
  12.  
  13.   $degree = (24901 * 1609) / 360.0; 
  14.  
  15.   $dpmLat = 1 / $degree
  16.  
  17.   $radiusLat = $dpmLat * $raidus
  18.  
  19.   $minLat = $lat – $radiusLat//得到最小纬度 
  20.  
  21.   $maxLat = $lat + $radiusLat//得到最大纬度 
  22.  
  23.   //计算经度 
  24.  
  25.   $mpdLng = $degree * cos($lat * (PI / 180)); 
  26.  
  27.   $dpmLng = 1 / $mpdLng
  28.  
  29.   $radiusLng = $dpmLng * $raidus
  30.  
  31.   $minLng = $lon – $radiusLng//得到最小经度 
  32.  
  33.   $maxLng = $lon + $radiusLng//得到最大经度 
  34.  
  35.   //范围 
  36.  
  37.   $range = array
  38.  
  39.     'minLat' => $minLat
  40.  
  41.     'maxLat' => $maxLat
  42.  
  43.     'minLon' => $minLng
  44.  
  45.     'maxLon' => $maxLng 
  46.  
  47.   ); 
  48.  
  49.   return $range
  50.  
  51.  
  52. //获取2点之间的距离 
  53.  
  54. function GetDistance($lat1$lng1$lat2$lng2){ 
  55.  
  56.   $radLat1 = $lat1 * (PI / 180); 
  57.  
  58.   $radLat2 = $lat2 * (PI / 180); 
  59.  
  60.   $a = $radLat1 – $radLat2
  61.  
  62.   $b = ($lng1 * (PI / 180)) – ($lng2 * (PI / 180)); 
  63.  
  64.   $s = 2 * asin(sqrt(pow(sin($a/2),2) + cos($radLat1)*cos($radLat2)*pow(sin($b/2),2))); 
  65. //phpfensi.com 
  66.   $s = $s * EARTH_RADIUS; 
  67.  
  68.   $s = round($s * 10000) / 10000; 
  69.  
  70.   return $s
  71.  

模板优惠价: (点击购买)
版权声明:本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权
文章名称:《php实现计算百度地图坐标之间距离的方法》
文章链接:https://www.adminn.cn/news/7581.html
本站资源模板仅供个人学习交流,请于下载后24小时内删除,不允许用于商业用途,否则法律问题自行承担。2021.5月起,网站调整,暂不再分享免费模板。谢谢理解

Adminn.Cn 站长分享圈

帝国CMS精品模板腾讯云优惠券,代金券

2次开发,学习研究使用!扫码支付后联系QQ677123发货!

支付宝扫一扫打赏