直接代码了。很好理解。
/**
* 根据经纬度计算距离
*
*/
public function getDistance($lat1=32.052639218124, $lng1=118.78637828936, $lat2=31.906570901919, $lng2=118.91701861624)
{
$earthRadius = 6367000; //approximate radius of earth in meters lat1纬度 经度118.91701861624
// print_r($lat2);
// echo "<br>";
// print_r($lng1);
// echo "<br>";
$lat1 = ($lat1 * pi() ) / 180;
$lng1 = ($lng1 * pi() ) / 180;
$lat2 = ($lat2 * pi() ) / 180;
$lng2 = ($lng2 * pi() ) / 180;
$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)));
// print_r($stepTwo);
$calculatedDistance = $earthRadius * $stepTwo;
// echo "<br>";
// print_r($calculatedDistance);
return round($calculatedDistance);
}
/**
* 根据地址获取经纬度
*
*/
public function getLatng($prepAddr)
{
// $prepAddr = "上海徐汇区漕宝70号";
$geocode=file_get_contents("http://api.map.baidu.com/geocoder/v2/?address=$prepAddr&output=json&ak=自己的ak");
$output= json_decode($geocode,true);
// print_r($output);die;
$latng = $output['result']['location'];
return $latng;
}