這篇文章將為大家詳細(xì)講解有關(guān)PHP如何計算地球上兩點之間的距離,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
創(chuàng)新互聯(lián)公司堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站設(shè)計、成都做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的曲陽網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!給定經(jīng)度和緯度,求地球上兩點之間的距離。首先我們需要了解該問題的解決思路,然后再用PHP代碼來實現(xiàn)計算。
此問題可以用半正矢(haversine)公式
求解:
大圓距離或正交距離是球面(或地球表面)上兩點之間最短的距離。為了使用這種方法,我們需要有點A和點B的坐標(biāo)。大圓法優(yōu)于其他方法。
首先,將緯度和經(jīng)度值從十進(jìn)制度轉(zhuǎn)換為弧度。因此,將經(jīng)度和緯度值同時除以180 / pi。pi圓周率的值是22/7。180/pi的值約為57.29577951。如果我們想計算兩個地方之間的距離(以英里為單位),就用3,963,這是地球的半徑。如果我們想計算兩個地方之間的距離,單位是千米,用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
求出點A的經(jīng)緯度坐標(biāo)。使用上述轉(zhuǎn)換方法將經(jīng)緯度值轉(zhuǎn)換為弧度。我把它叫做lat1和long1。對點B的坐標(biāo)做同樣的處理,得到lat2和long2。
現(xiàn)在,為了得到點A和點B之間的距離,使用下面的公式:
距離,d = 3963.0 * arccos[(sin(lat1) * sin(lat2)) + cos(lat1) * cos(lat2) * cos(long2 - long1)]
得到的距離d的單位是英里。如果你想讓你的值以千米為單位,則d乘以1.609344。
d(千米)= 1.609344 * d(英里)
因此,你可以用大圓距離法得到地球上兩個地方之間最短的距離。
PHP計算地球上兩點間距離的實現(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)緯度兩點 $latitudeFrom = 19.017656 ; $longitudeFrom = 72.856178; $latitudeTo = 40.7127; $longitudeTo = -74.0059; // 孟買和紐約之間的距離 print_r(twopoints_on_earth( $latitudeFrom, $longitudeFrom, $latitudeTo, $longitudeTo).' '.'miles');
輸出:
2.0043678382716137 K.M
關(guān)于PHP如何計算地球上兩點之間的距離就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
文章題目:PHP如何計算地球上兩點之間的距離-創(chuàng)新互聯(lián)
文章網(wǎng)址:http://jinyejixie.com/article18/cshsdp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供手機網(wǎng)站建設(shè)、外貿(mào)建站、網(wǎng)站收錄、服務(wù)器托管、網(wǎng)站制作、網(wǎng)站營銷
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)