PHP根据两点间的经纬度计算距离,php两点经纬度计算(根据经纬度计算距离)
PHP根據(jù)兩點(diǎn)間的經(jīng)緯度計(jì)算距離,php兩點(diǎn)經(jīng)緯度計(jì)算
這是一個(gè)不錯(cuò)的示例,直接貼代碼,首先要知道緯度值、經(jīng)度值
/**
* @desc 根據(jù)兩點(diǎn)間的經(jīng)緯度計(jì)算距離
* @param float $lat 緯度值
* @param float $lng 經(jīng)度值
*/
function getDistance($lat1, $lng1, $lat2, $lng2)
{
$earthRadius = 6367000; //approximate radius of earth in meters
/*
Convert these degrees to radians
to work with the formula
*/
$lat1 = ($lat1 * pi() ) / 180;
$lng1 = ($lng1 * pi() ) / 180;
$lat2 = ($lat2 * pi() ) / 180;
$lng2 = ($lng2 * pi() ) / 180;
/*
Using the
Haversine formula
http://en.wikipedia.org/wiki/Haversine_formula
calculate the distance
*/
$calcLongitude = $lng2 - $lng1;
$calcLatitude = $lat2 - $lat1;
$stepOne = pow(sin($calcLatitude / 2), 2) + cos($lat1) * cos($lat2) * pow(sin($calcLongitude / 2), 2);
$stepTwo = 2 * asin(min(1, sqrt($stepOne)));
$calculatedDistance = $earthRadius * $stepTwo;
return round($calculatedDistance);
}
登錄后復(fù)制
php計(jì)算兩個(gè)經(jīng)緯度之間的距離問(wèn)題,指導(dǎo)
不會(huì)算這個(gè)東西,不過(guò)看代碼發(fā)現(xiàn)你的代碼里有些問(wèn)題
第一、兩點(diǎn)間的直線距離平方:$len算完了后面沒有用到,也沒有return, 完全就沒用了
第二、輸入相同的經(jīng)緯度,結(jié)果居然不是0,而且還是個(gè)很大的數(shù),所以應(yīng)該是有問(wèn)題的
你可以百度一下“php 按經(jīng)緯度算兩點(diǎn)間距離”,有不少現(xiàn)成的代碼
我看這個(gè)介紹的比較詳細(xì),還有代碼,你可以看看
blog.csdn.net/...963740
?
如果知道兩點(diǎn)的經(jīng)緯度 怎算兩點(diǎn)之間的距離
同緯度不同經(jīng)度 (赤道除外)
h X 111 X COSD=G (h=兩地經(jīng)度差 D=當(dāng)?shù)氐牡乩砭暥?G=實(shí)際距離)
跨緯度的需要構(gòu)造個(gè)三角
比如說(shuō)AB兩點(diǎn)不同經(jīng)緯度(A經(jīng)B緯)
那就先算出與A點(diǎn)共線的那條緯度B'的距離,在算A到B'的距離,在用勾股定理就可以得出
簡(jiǎn)單的說(shuō)可用以下通用公式:
地球上任兩點(diǎn)間距離公式:
地球上任兩點(diǎn),其經(jīng)度分別為A1、A2(E正,W負(fù)),緯度分別為B1、B2(N正,S負(fù))。
令A(yù)0=(A1-A2)÷2,B0=(BI-B2)÷2
f=√sinB0×sinB0+cosB1×cosB2×sinA0×sinA0
則
1、兩點(diǎn)間空間直線距離=2fR
2、兩點(diǎn)間最小球面距離=arcsinf÷90°×∏R(角度)
3、兩點(diǎn)間最小球面距離=arcsinf×2R(弧度)
說(shuō)明:E、W、N、S=東西南北;R=地球半徑;√=根號(hào);∏=圓周率。
代入公式自己算吧
?
總結(jié)
以上是生活随笔為你收集整理的PHP根据两点间的经纬度计算距离,php两点经纬度计算(根据经纬度计算距离)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 北京80后整体亮相《北京作家》
- 下一篇: php是世界上最好的语言是什么梗