Bootstrap

php多个经纬度合并

//start----------------------合并多个经纬度点--------------------------------

/**
 * 求两个已知经纬度之间的距离,单位为米
 * @param lng1 $ ,lng2 经度
 * @param lat1 $ ,lat2 纬度
 * @return float 距离,单位米
 */
function getDistance($lng1, $lat1, $lng2, $lat2) {
    // 将角度转为狐度
    $radLat1 = deg2rad($lat1); //deg2rad()函数将角度转换为弧度
    $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))) * 6378.137 * 1000;
    return $s;
}


/*
 * 合并多个经纬度点,获取中心坐标
 * @param   data        需要合并的经纬度点数组
 * @param   latName     data中纬度的键名
 * @param   lngName     data中经度的键名
 * @return  newData     合并后的经纬度
 *              num为原本坐标数
 *      形式 :
 *          Array (['count']=>num, [$latName] => 45.813538469271, [$lngName] => 75.682996448603 )
 * */
func
;