ホームページ >バックエンド開発 >PHPチュートリアル >PHPは2つの緯度と経度の間の距離を計算します

PHPは2つの緯度と経度の間の距離を計算します

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBオリジナル
2016-07-25 08:42:411121ブラウズ
  1. function getDistanceBetweenPointsNew($latitude1, $longitude1, $latitude2, $longitude2) {
  2. $theta = $longitude1 - $longitude2;
  3. $miles = (sin(deg2rad($latitude1)) * sin(deg2rad($latitude2) ))) + (cos(deg2rad($latitude1)) * cos(deg2rad($latitude2)) * cos(deg2rad($theta)));
  4. $マイル = acos($マイル);
  5. $マイル = rad2deg($マイル);
  6. $マイル = $マイル * 60 * 1.1515;
  7. $フィート = $マイル * 5280;
  8. $ヤード = $フィート / 3;
  9. $キロ = $マイル * 1.609344;
  10. $メートル = $キロ * 1000;
  11. return Compact('マイル','フィート','ヤード','キロメートル','メートル');
  12. }
复制代

使用法:
  1. $point1 = array('lat' => 40.770623, 'long' => -73.964367);
  2. $point2 = array('lat' => 40.758224, '長い' => -73.917404);
  3. $距離 = getDistanceBetweenPointsNew($point1['lat'], $point1['long'], $point2['lat'], $point2['long']);
  4. foreach ($ distance as $unit => $value) {
  5. echo $unit.': '.number_format($value,4).'
    ';
  6. }
  7. ?>
复制代

PHP


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。