這篇文章將為大家詳細(xì)講解有關(guān)PHP如何計(jì)算地球上兩點(diǎn)之間的距離,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
成都創(chuàng)新互聯(lián)公司服務(wù)項(xiàng)目包括玉門網(wǎng)站建設(shè)、玉門網(wǎng)站制作、玉門網(wǎng)頁(yè)制作以及玉門網(wǎng)絡(luò)營(yíng)銷策劃等。多年來(lái),我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,玉門網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到玉門省份的部分城市,未來(lái)相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
給定經(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)代碼如下:
輸出:
2.0043678382716137 K.M關(guān)于PHP如何計(jì)算地球上兩點(diǎn)之間的距離就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。
文章名稱:PHP如何計(jì)算地球上兩點(diǎn)之間的距離
分享網(wǎng)址:http://weahome.cn/article/jhiiji.html