佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > 定位地理位置PHP判斷員工打卡簽到經(jīng)緯度是否在打卡之內(nèi)

定位地理位置PHP判斷員工打卡簽到經(jīng)緯度是否在打卡之內(nèi)

熱門標(biāo)簽:Mysql連接數(shù)設(shè)置 銀行業(yè)務(wù) Linux服務(wù)器 團購網(wǎng)站 服務(wù)器配置 電子圍欄 科大訊飛語音識別系統(tǒng) 阿里云

具體代碼如下所述:

 /* 計算兩組經(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)緯度獲取距離(單位:米),再判斷一個點是否在圓形區(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;
 }

總結(jié)

以上所述是小編給大家介紹的定位地理位置PHP判斷員工打卡簽到經(jīng)緯度是否在打卡之內(nèi),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

您可能感興趣的文章:
  • php根據(jù)地址獲取百度地圖經(jīng)緯度的實例方法
  • golang與php實現(xiàn)計算兩個經(jīng)緯度之間距離的方法
  • PHP計算當(dāng)前坐標(biāo)3公里內(nèi)4個角落的最大最小經(jīng)緯度實例
  • php獲取指定(訪客)IP所有信息(地址、郵政編碼、國家、經(jīng)緯度等)的方法
  • PHP根據(jù)兩點間的經(jīng)緯度計算距離
  • PHP計算2點經(jīng)緯度之間的距離代碼
  • 如何用php根據(jù)地址獲取經(jīng)緯度

標(biāo)簽:衢州 蚌埠 萍鄉(xiāng) 廣元 大理 棗莊 衡水 江蘇

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《定位地理位置PHP判斷員工打卡簽到經(jīng)緯度是否在打卡之內(nèi)》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    和林格尔县| 长海县| 东海县| 南岸区| 闻喜县| 藁城市| 枣强县| 安西县| 镇雄县| 崇义县| 台南市| 博湖县| 来安县| 正定县| 广德县| 二手房| 郧西县| 宾川县| 绥中县| 北京市| 霍林郭勒市| 色达县| 麦盖提县| 秦安县| 图们市| 安达市| 邯郸县| 唐山市| 平塘县| 云浮市| 丰城市| 滦南县| 芒康县| 衡阳市| 六安市| 泸西县| 平湖市| 桐梓县| 阿坝| 柘荣县| 古浪县|