PHP根据经纬度计算两地点间的直线距离

话不多说,直接上干货

//根据两点间的经纬度计算距离
//$lat1 地点1的纬度
//$lng1 地点1的经度
//$lat2 地点2的纬度
//$lng2 地点2的经度
function getDistance($lat1, $lng1, $lat2, $lng2) {
    //赤道半径(单位m)
    $earthRadius = 6378137;
    $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)));
    //米
    $calculatedDistance = abs(round(($earthRadius * $stepTwo),2));
    //千米
    $calculatedDistanceKm = abs(round(($calculatedDistance/1000), 2));
    if ($calculatedDistanceKm >= 1) {
        if ($calculatedDistanceKm > 999) {
            $distance_str = ">999 km";
        } else {
            $distance_str = $calculatedDistanceKm . " km";
        }
    } else {
        $distance_str = $calculatedDistance . " m";
    }
    return [
        'distance' => $calculatedDistance,
        'distance_str'=> $distance_str,
    ];
}
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值