>  기사  >  백엔드 개발  >  PHP는 두 좌표(경도, 위도) 사이의 거리를 계산합니다.

PHP는 두 좌표(경도, 위도) 사이의 거리를 계산합니다.

WBOY
WBOY원래의
2016-07-25 08:43:06960검색

php计算两个坐标(经度,纬度)之间的距离,返回结果为米或者千米

  1. function distance($lat1, $lng1, $lat2, $lng2, $miles = true)
  2. {
  3. $pi80 = M_PI / 180;
  4. $lat1 *= $pi80;
  5. $lng1 *= $pi80;
  6. $lat2 *= $pi80;
  7. $lng2 *= $pi80;
  8. $r = 6372.797; // mean radius of Earth in km
  9. $dlat = $lat2 - $lat1;
  10. $dlng = $lng2 - $lng1;
  11. $a = sin($dlat / 2) * sin($dlat / 2) cos($lat1) * cos($lat2) * sin($dlng / 2) * sin($dlng / 2);
  12. $c = 2 * atan2(sqrt($a), sqrt(1 - $a));
  13. $km = $r * $c;
  14. return ($miles ? ($km * 0.621371192) : $km);
  15. }
复制代码

PHP


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.