溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

PHP如何計(jì)算地球上兩點(diǎn)之間的距離

發(fā)布時(shí)間:2020-10-29 11:45:35 來(lái)源:億速云 閱讀:129 作者:小新 欄目:編程語(yǔ)言

這篇文章將為大家詳細(xì)講解有關(guān)PHP如何計(jì)算地球上兩點(diǎn)之間的距離,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

給定經(jīng)度和緯度,求地球上兩點(diǎn)之間的距離。首先我們需要了解該問(wèn)題的解決思路,然后再用PHP代碼來(lái)實(shí)現(xiàn)計(jì)算。

此問(wèn)題可以用半正矢(haversine)公式求解:

大圓距離或正交距離是球面(或地球表面)上兩點(diǎn)之間最短的距離。為了使用這種方法,我們需要有點(diǎn)A和點(diǎn)B的坐標(biāo)。大圓法優(yōu)于其他方法。

首先,將緯度和經(jīng)度值從十進(jìn)制度轉(zhuǎn)換為弧度。因此,將經(jīng)度和緯度值同時(shí)除以180 / pi。pi圓周率的值是22/7。180/pi的值約為57.29577951。如果我們想計(jì)算兩個(gè)地方之間的距離(以英里為單位),就用3,963,這是地球的半徑。如果我們想計(jì)算兩個(gè)地方之間的距離,單位是千米,用6,378.8,也就是地球的半徑。

求緯度值(以弧度為單位):
緯度值,單位為弧度,lat =緯度/ (180/pi)
或
緯度值,以弧度為單位,lat =緯度/ 57.29577951

求經(jīng)度的弧度值:
經(jīng)度值,單位為弧度,long =經(jīng)度/ (180/pi)
或
經(jīng)度值,單位為弧度,long =經(jīng)度/ 57.29577951

求出點(diǎn)A的經(jīng)緯度坐標(biāo)。使用上述轉(zhuǎn)換方法將經(jīng)緯度值轉(zhuǎn)換為弧度。我把它叫做lat1和long1。對(duì)點(diǎn)B的坐標(biāo)做同樣的處理,得到lat2和long2。

現(xiàn)在,為了得到點(diǎn)A和點(diǎn)B之間的距離,使用下面的公式:

距離,d = 3963.0 * arccos[(sin(lat1) * sin(lat2)) + cos(lat1) * cos(lat2) * cos(long2 - long1)]

得到的距離d的單位是英里。如果你想讓你的值以千米為單位,則d乘以1.609344。

d(千米)= 1.609344 * d(英里)

因此,你可以用大圓距離法得到地球上兩個(gè)地方之間最短的距離。

PHP計(jì)算地球上兩點(diǎn)間距離的實(shí)現(xiàn)代碼如下:

<?php 
         
      function twopoints_on_earth($latitudeFrom, $longitudeFrom, 
                                    $latitudeTo,  $longitudeTo) 
      { 
           $long1 = deg2rad($longitudeFrom); 
           $long2 = deg2rad($longitudeTo); 
           $lat1 = deg2rad($latitudeFrom); 
           $lat2 = deg2rad($latitudeTo); 
              
           $dlong = $long2 - $long1; 
           $dlati = $lat2 - $lat1; 
              
           $val = pow(sin($dlati/2),2)+cos($lat1)*cos($lat2)*pow(sin($dlong/2),2); 
              
           $res = 2 * asin(sqrt($val)); 
              
           $radius = 3958.756; 
              
           return ($res*$radius); 
      } 
  
      //經(jīng)緯度兩點(diǎn)
      $latitudeFrom = 19.017656 ; 
      $longitudeFrom = 72.856178; 
      $latitudeTo = 40.7127; 
      $longitudeTo = -74.0059; 
         
      // 孟買(mǎi)和紐約之間的距離
      print_r(twopoints_on_earth( $latitudeFrom, $longitudeFrom,  
                    $latitudeTo,  $longitudeTo).' '.'miles');

輸出:

2.0043678382716137 K.M

關(guān)于PHP如何計(jì)算地球上兩點(diǎn)之間的距離就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI