在php直播平台源码中,“发现同城主播”的功能是如何开发出来的?下面给大家介绍附近功能中的距离之间的换算,通过本文,你可以:
/** * 求两个已知经纬度之间的距离,单位为米 * * @param lng1 $ ,lng2 经度 * @param lat1 $ ,lat2 纬度 * @return float 距离,单位米 */ function getdistance($lng1, $lat1, $lng2, $lat2) { // 将角度转为狐度 $radLat1 = deg2rad($lat1); //deg2rad()函数将角度转换为弧度(当前纬度) $radLat2 = deg2rad($lat2); //deg2rad()函数将角度转换为弧度(当前经度) $radLng1 = deg2rad($lng1); //deg2rad()函数将角度转换为弧度(其他纬度) $radLng2 = deg2rad($lng2); //deg2rad()函数将角度转换为弧度(其他经度) $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; }
/** * <p>Description: 计算两点之间距离</p> * @param slng 起始经度 * @param slat 起始纬度 * @param elng 结束经度 * @param elat 结束纬度 * @return 千米 * */ function getDistanceByGaoDe($slng, $slat, $elng, $elat,$decimal=2) { $earth_radius = 6378.137; //地球半径 $lng1 = (M_PI / 180) * $slng; $lng2 = (M_PI / 180) * $elng; $lat1 = (M_PI / 180) * $slat; $lat2 = (M_PI / 180) * $elat; // 两点间距离 km,如果想要米的话,结果*1000就可以了 $d = acos(sin($lat1) * sin($lat2) + cos($lat1) * cos($lat2) * cos($lng2 - $lng1)) * $earth_radius; // 精度2位小数 $d = round($d,$decimal); return $d; }
总结:这串代码是根据圆周率和地球半径系数与两点坐标的经纬度,计算两点之间的球面距离,最终通过当前用户与其他用户之间经纬度调用的方法进行换算,获得多用户之间实际距离,以此实现“发现同城主播”功能的。
声明:以上内容为作者本人原创,未经作者本人同意,禁止转载,否则将追究相关法律责任,作者:云豹科技官方号