文章主要為大家詳細(xì)介紹了php兩點(diǎn)地理坐標(biāo)距離的計(jì)算方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
php計(jì)算兩點(diǎn)地理坐標(biāo)距離的具體代碼,具體內(nèi)容如下
功能:根據(jù)圓周率和地球半徑系數(shù)與兩點(diǎn)坐標(biāo)的經(jīng)緯度,計(jì)算兩點(diǎn)之間的球面距離。
獲取兩點(diǎn)坐標(biāo)距離:
<?php
/**
* 計(jì)算兩點(diǎn)地理坐標(biāo)之間的距離
* @param Decimal $longitude1 起點(diǎn)經(jīng)度
* @param Decimal $latitude1 起點(diǎn)緯度
* @param Decimal $longitude2 終點(diǎn)經(jīng)度
* @param Decimal $latitude2 終點(diǎn)緯度
* @param Int $unit 單位 1:米 2:公里
* @param Int $decimal 精度 保留小數(shù)位數(shù)
* @return Decimal
*/
function
getDistance(
$longitude1
,
$latitude1
,
$longitude2
,
$latitude2
,
$unit
=2,
$decimal
=2){
$EARTH_RADIUS
= 6370.996;
// 地球半徑系數(shù)
$PI
= 3.1415926;
$radLat1
=
$latitude1
*
$PI
/ 180.0;
$radLat2
=
$latitude2
*
$PI
/ 180.0;
$radLng1
=
$longitude1
*
$PI
/ 180.0;
$radLng2
=
$longitude2
*
$PI
/180.0;
$a
=
$radLat1
-
$radLat2
;
$b
=
$radLng1
-
$radLng2
;
$distance
= 2 * asin(sqrt(pow(sin(
$a
/2),2) +
cos
(
$radLat1
) *
cos
(
$radLat2
) * pow(sin(
$b
/2),2)));
$distance
=
$distance
*
$EARTH_RADIUS
* 1000;
if
(
$unit
==2){
$distance
=
$distance
/ 1000;
}
return
round
(
$distance
,
$decimal
);
}
// 起點(diǎn)坐標(biāo)
$longitude1
= 113.330405;
$latitude1
= 23.147255;
// 終點(diǎn)坐標(biāo)
$longitude2
= 113.314271;
$latitude2
= 23.1323;
$distance
= getDistance(
$longitude1
,
$latitude1
,
$longitude2
,
$latitude2
, 1);
echo
$distance
.
'm'
;
// 2342.38m
$distance
= getDistance(
$longitude1
,
$latitude1
,
$longitude2
,
$latitude2
, 2);
echo
$distance
.
'km'
;
// 2.34km
?>
以上就是php兩點(diǎn)地理坐標(biāo)距離的計(jì)算方法的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助。
- PHP獲取HTTP body內(nèi)容的方法
- PHP面向?qū)ο蟪绦蛟O(shè)計(jì)中獲取對象屬性的3種方法實(shí)例分析
- php5.5新增的yield關(guān)鍵字功能與相關(guān)使用技巧
- Windows7下IIS+php配置教程詳細(xì)介紹
- PHP序列化的四種實(shí)現(xiàn)方法與橫向?qū)Ρ冉坛?/a>
- PHP基于Redis消息隊(duì)列實(shí)現(xiàn)的消息推送的方法
- Linux服務(wù)器下 php7安裝redis的方法
- PHP判斷電子郵件是否正確的簡單方法介紹
- 在PHP中進(jìn)行curl開啟操作的具體教程
- PHP中間件ICE,ICE的安裝配置,ICE常見編譯和運(yùn)行(異常)
分享到:
投訴收藏