早睡早起,方能养生
Sleep early rise early, way to keep healthy

PHP 计算两个经纬度之间的距离

super
2022-07-06 11:45
views 1625

 

 

/**
 * 计算两个经纬度之间的距离 单位km
 * @param float | string $lat1 纬度1
 * @param float | string $lng1 经度1
 * @param float | string $lat2 纬度2
 * @param float | string $lng2 经度2
 * @return float 两点距离 单位km
 **/
function calculateDistance($lat1, $lng1, $lat2, $lng2) {
    // deg2rad()函数将角度转换为弧度
    $radLat1 = deg2rad($lat1); 
    $radLat2 = deg2rad($lat2);
    $radLng1 = deg2rad($lng1);
    $radLng2 = deg2rad($lng2);
    $a       = $radLat1 - $radLat2;
    $b       = $radLng1 - $radLng2;
    $s       = 2 * asin(sqrt(pow(sin($a / 2), 2) + cos($radLat1) * cos($radLat2) * pow(sin($b / 2), 2))) * 6371;
    return round($s, 1);
}


分享
0 条讨论
top