当前位置:首页 > PHP教程 > php应用 > 列表

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

发布:smiling 来源: PHP粉丝网  添加日期:2019-07-28 14:50:42 浏览: 评论:0 

本文实例讲述了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.  

Tags: php百度地图 php坐标距离

分享到: