PHP计算两点经纬度之间的距离代码

清华大佬耗费三个月吐血整理的几百G的资源,免费分享!....>>>

以下是对PHP计算2点经纬度之间的距离代码进行了分析介绍
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
<?php  
function getDistanceBetweenPointsNew($latitude1, $longitude1, $latitude2, $longitude2) { 
    $theta = $longitude1 - $longitude2
    $miles = (sin(deg2rad($latitude1)) * sin(deg2rad($latitude2))) + (cos(deg2rad($latitude1)) * cos(deg2rad($latitude2)) * cos(deg2rad($theta))); 
    $miles = acos($miles); 
    $miles = rad2deg($miles); 
    $miles = $miles * 60 * 1.1515; 
    $feet = $miles * 5280; 
    $yards = $feet / 3; 
    $kilometers = $miles * 1.609344; 
    $meters = $kilometers * 1000; 
    return compact('miles','feet','yards','kilometers','meters'); 
   
$point1 = array('lat' => 40.770623, 'long' => -73.964367); 
$point2 = array('lat' => 40.758224, 'long' => -73.917404); 
$distance = getDistanceBetweenPointsNew($point1['lat'], $point1['long'], $point2['lat'], $point2['long']); 
foreach ($distance as $unit => $value) { 
    echo $unit.': '.number_format($value,4).'<br />'
?>