定位地理位置PHP判断员工打卡签到经纬度是否在打卡之内
程序员文章站
2022-06-16 18:49:35
具体代码如下所述:
/* 计算两组经纬度坐标之间的距离
* @param $lat1 纬度1
* @param $lng1 经度1
* @pa...
具体代码如下所述:
/* 计算两组经纬度坐标之间的距离 * @param $lat1 纬度1 * @param $lng1 经度1 * @param $lat2 纬度2 * @param $lng2 经度2 * @param int $len_type 返回值类型(1-m 2-km) * @param int $decimal 保留小数位数 * @return float */ public function getdistance($lat1, $lng1, $lat2, $lng2, $len_type = 1, $decimal = 2) { $radlat1 = $lat1 * 3.1415926 / 180.0; $radlat2 = $lat2 * 3.1415926 / 180.0; $a = $radlat1 - $radlat2; $b = ($lng1 * 3.1415926 / 180.0) - ($lng2 * 3.1415926 / 180.0); $s = 2 * asin(sqrt(pow(sin($a / 2), 2) + cos($radlat1) * cos($radlat2) * pow(sin($b / 2), 2))); $s = $s * 6378.137; $s = round($s * 1000); if ($len_type > 1) { $s /= 1000; } return round($s, $decimal); }
ps:下面看下根据经纬度判断签到范围是否在指定范围内
/** * 将角度换算为弧度 * @param d 角度 * @return 弧度 */ private static double rad(double d) { return d * math.pi / 180.0; } /** * 先通过经纬度获取距离(单位:米),再判断一个点是否在圆形区域内(根据所给的半径坐比较) * @param n1=>app * @param n2=>仓库 * @param radius * @return */ public static boolean isincircle(zjpoint n1 ,zjpoint n2,string radius){ final double earth_radius = 6378.137;////地球半径 (千米) double radlat1 = rad(n1.getx()!=null ? n1.getx().doublevalue():0); double radlat2 = rad(n2.getx()!=null ? n2.getx().doublevalue():0); double radlon1 = rad(n1.gety()!=null ? n1.gety().doublevalue():0); double radlon2 = rad(n2.gety()!=null ? n2.gety().doublevalue():0); //两点之间的差值 double jddistance = radlat1 - radlat2; double wddistance = radlon1 - radlon2; double distance = 2 * math.asin(math.sqrt(math.pow(math.sin(jddistance / 2), 2) + math.cos(radlat1) * math.cos(radlat2) * math.pow(math.sin(wddistance / 2), 2))); distance = distance * earth_radius; distance = math.round(distance * 10000d) / 10000d; distance = distance*1000;//将计算出来的距离千米转为米 double r = double.parsedouble(radius); //判断一个点是否在圆形区域内 if (distance > r) { return false; } return true; }
总结
以上所述是小编给大家介绍的定位地理位置php判断员工打卡签到经纬度是否在打卡之内,希望对大家有所帮助