我在PHP
中有一个函数来计算两个地方之间的距离。
这是 php代码:
function distance($lat1, $lon1, $lat2, $lon2) {
$earth_radius = 6371;
$delta_lat = $lat2 - $lat1 ;
$delta_lon = $lon2 - $lon1 ;
$distance = sin(deg2rad($lat1)) * sin(deg2rad($lat2)) + cos(deg2rad($lat1)) * cos(deg2rad($lat2)) * cos(deg2rad($delta_lon)) ;
$distance = acos($distance);
$distance = rad2deg($distance);
$distance = $distance * 60 * 1.1515;
$distance = round($distance, 4);
return $distance = $distance * 1.609344;
}
它提供了25 km
周围的良好计算,但在500 km
左右,计算错误。
我的另一个问题是it really giving miles or kilometers?
例如,此map从443 km
到Morbi
的距离为Surat
,但该函数的结果为274 km
答案 0 :(得分:1)
好的,现在很清楚你想要道路距离,我们可以给你一个正确的答案,得到结果,你可以使用Google API Distance Matrix,你有不同的选项和参数,你必须弄清楚哪个最适合你,请注意有一些限制(免费版):
<<
The Distance Matrix API has the following limits in place:
100 elements per query.
100 elements per 10 seconds.
2 500 elements per 24 hour period.
>>
然而,为了回答你的问题,我编写了一个简单的PHP脚本,它获取XML文件并使用SimpleXMLElement解析距离/持续时间......
<?php
$start = "morbi"; // You can either set lon and lat separated with a comma ex: 22.814162,70.834351
$destination = "surat";
$mode = "driving"; // Different modes: driving,walking,bicycling (be aware that some of the modes aren't available for some poi's ...)
$xml = file_get_contents("http://maps.googleapis.com/maps/api/distancematrix/xml?origins=$start&destinations=$destination&mode=$mode&language=en-EN&sensor=false");
$data = new SimpleXMLElement($xml);
$distance = $data->row->element->distance->text;
$time = $data->row->element->duration->text;
if(empty($distance) OR empty($time)){
echo "Oops, this mode ($mode) isn't available ...";
}else{
echo "The distance between $start and $destination is $distance and the travel duration while $mode is $time .";
}
?>
希望这有用:)