/* 計算兩組經(jīng)緯度坐標(biāo)之間的距離
* @param $lat1 緯度1
* @param $lng1 經(jīng)度1
* @param $lat2 緯度2
* @param $lng2 經(jīng)度2
* @param int $len_type 返回值類型(1-m 2-km)
* @param int $decimal 保留小數(shù)位數(shù)
* @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);
}
/**
* 將角度換算為弧度
* @param d 角度
* @return 弧度
*/
private static double rad(double d) {
return d * Math.PI / 180.0;
}
/**
* 先通過經(jīng)緯度獲取距離(單位:米),再判斷一個點是否在圓形區(qū)域內(nèi)(根據(jù)所給的半徑坐比較)
* @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;//將計算出來的距離千米轉(zhuǎn)為米
double r = Double.parseDouble(radius);
//判斷一個點是否在圓形區(qū)域內(nèi)
if (distance > r) {
return false;
}
return true;
}
以上所述是小編給大家介紹的定位地理位置PHP判斷員工打卡簽到經(jīng)緯度是否在打卡之內(nèi),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!