这是一个不错的示例,直接贴代码,首先要知道纬度值、经度值
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
/** * @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 ); } |