溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

PHP實(shí)現(xiàn)判斷員工打卡簽到經(jīng)緯度是否在打卡之內(nèi)

發(fā)布時(shí)間:2021-09-02 09:49:12 來源:億速云 閱讀:211 作者:chen 欄目:開發(fā)技術(shù)

本篇內(nèi)容介紹了“PHP實(shí)現(xiàn)判斷員工打卡簽到經(jīng)緯度是否在打卡之內(nèi)”的有關(guān)知識,在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

具體代碼如下所述:

 /* 計(jì)算兩組經(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);
  }

ps:下面看下根據(jù)經(jīng)緯度判斷簽到范圍是否在指定范圍內(nèi)

/**
  * 將角度換算為弧度
  * @param d 角度
  * @return 弧度
  */
 private static double rad(double d) {
     return d * Math.PI / 180.0;
 }
 
 /**
  * 先通過經(jīng)緯度獲取距離(單位:米),再判斷一個(gè)點(diǎn)是否在圓形區(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);
   //兩點(diǎn)之間的差值
   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;//將計(jì)算出來的距離千米轉(zhuǎn)為米
   double r = Double.parseDouble(radius);
   //判斷一個(gè)點(diǎn)是否在圓形區(qū)域內(nèi)
   if (distance > r) {
       return false;
    }
  return true;
 }

“PHP實(shí)現(xiàn)判斷員工打卡簽到經(jīng)緯度是否在打卡之內(nèi)”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI