PHP 根据两点的坐标计算之间的距离

后端开发   发布日期:2025年05月02日   浏览次数:214
  1. define('PI',3.1415926535898);
  2. define('EARTH_RADIUS',6378.137);
  3. //计算范围,可以做搜索用户
  4. function GetRange($lat,$lon,$raidus){
  5. //计算纬度
  6. $degree = (24901 * 1609) / 360.0;
  7. $dpmLat = 1 / $degree;
  8. $radiusLat = $dpmLat * $raidus;
  9. $minLat = $lat - $radiusLat; //得到最小纬度
  10. $maxLat = $lat + $radiusLat; //得到最大纬度
  11. //计算经度
  12. $mpdLng = $degree * cos($lat * (PI / 180));
  13. $dpmLng = 1 / $mpdLng;
  14. $radiusLng = $dpmLng * $raidus;
  15. $minLng = $lon - $radiusLng; //得到最小经度
  16. $maxLng = $lon + $radiusLng; //得到最大经度
  17. //范围
  18. $range = array(
  19. 'minLat' => $minLat,
  20. 'maxLat' => $maxLat,
  21. 'minLon' => $minLng,
  22. 'maxLon' => $maxLng
  23. );
  24. return $range;
  25. }
  26. //获取2点之间的距离
  27. function GetDistance($lat1, $lng1, $lat2, $lng2){
  28. $radLat1 = $lat1 * (PI / 180);
  29. $radLat2 = $lat2 * (PI / 180);
  30. $a = $radLat1 - $radLat2;
  31. $b = ($lng1 * (PI / 180)) - ($lng2 * (PI / 180));
  32. $s = 2 * asin(sqrt(pow(sin($a/2),2) + cos($radLat1)*cos($radLat2)*pow(sin($b/2),2)));
  33. $s = $s * EARTH_RADIUS;
  34. $s = round($s * 10000) / 10000;
  35. return $s;
  36. }

 

以上就是PHP 根据两点的坐标计算之间的距离的详细内容,更多关于PHP 根据两点的坐标计算之间的距离的资料请关注九品源码其它相关文章!