這是一個不錯的示例,直接貼代碼,首先要知道緯度值、經度值
/** * @desc 根據兩點間的經緯度計算距離 * @param float $lat 緯度值 * @param float $lng 經度值 */ 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); }
不會算這個東西,不過看代碼發現你的代碼裡有些問題
第一、兩點間的直線距離平方:$len算完了後面沒有用到,也沒有return, 完全就沒用了
第二、輸入相同的經緯度,結果居然不是0,而且還是個很大的數,所以應該是有問題的
你可以百度一下“php 按經緯度算兩點間距離”,有不少現成的代碼
我看這個介紹的比較詳細,還有代碼,你可以看看
blog.csdn.net/...963740
同緯度不同經度 (赤道除外)
h X 111 X COSD=G (h=兩地經度差 D=當地的地理緯度 G=實際距離)
跨緯度的需要構造個三角
比如說AB兩點不同經緯度(A經B緯)
那就先算出與A點共線的那條緯度B'的距離,在算A到B'的距離,在用勾股定理就可以得出
簡單的說可用以下通用公式:
地球上任兩點間距離公式:
地球上任兩點,其經度分別為A1、A2(E正,W負),緯度分別為B1、B2(N正,S負)。
令A0=(A1-A2)÷2,B0=(BI-B2)÷2
f=√sinB0×sinB0+cosB1×cosB2×sinA0×sinA0
則
1、兩點間空間直線距離=2fR
2、兩點間最小球面距離=arcsinf÷90°×∏R(角度)
3、兩點間最小球面距離=arcsinf×2R(弧度)
說明:E、W、N、S=東西南北;R=地球半徑;√=根號;∏=圓周率。
代入公式自己算吧