這篇文章主要介紹了定位地理位置PHP判斷員工打卡簽到經緯度是否在打卡之內,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑑價值,需要的朋友可以參考下
具體代碼如下所述:
/* 計算兩組經緯度座標之間的距離 * @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判斷員工打卡簽到經緯度是否在打卡之內,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。在此也非常感謝大家對神馬文庫網站的支持!