From d046fe01d52bc9ab423647db7af0591fd3a36259 Mon Sep 17 00:00:00 2001
From: ‘liusuyi’ <1951119284@qq.com>
Date: 星期六, 17 六月 2023 14:08:51 +0800
Subject: [PATCH] 增加获取附近相机接口 增加相机报警引导开关 增加日夜切换变换通道

---
 ard-work/src/main/java/com/ruoyi/device/camera/controller/ArdCamerasController.java |   50 ++++++++++++++++++++++----------------------------
 1 files changed, 22 insertions(+), 28 deletions(-)

diff --git a/ard-work/src/main/java/com/ruoyi/device/camera/controller/ArdCamerasController.java b/ard-work/src/main/java/com/ruoyi/device/camera/controller/ArdCamerasController.java
index eca36f8..1d423f6 100644
--- a/ard-work/src/main/java/com/ruoyi/device/camera/controller/ArdCamerasController.java
+++ b/ard-work/src/main/java/com/ruoyi/device/camera/controller/ArdCamerasController.java
@@ -3,12 +3,15 @@
 import javax.annotation.Resource;
 import javax.servlet.http.HttpServletResponse;
 
+import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
 import com.ruoyi.device.camera.domain.ArdCameras;
+import com.ruoyi.device.camera.domain.CameraCmd;
 import com.ruoyi.device.camera.service.IArdCamerasService;
 import com.ruoyi.device.hiksdk.service.impl.HikClientServiceImpl;
 import com.ruoyi.common.utils.SecurityUtils;
 import com.ruoyi.common.utils.poi.ExcelUtil;
 import com.ruoyi.system.service.ISysDeptService;
+import com.ruoyi.inspect.service.IArdVideoInspectTaskService;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
 import lombok.extern.slf4j.Slf4j;
@@ -27,10 +30,7 @@
 import com.ruoyi.common.enums.BusinessType;
 import com.ruoyi.common.core.page.TableDataInfo;
 
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
 
 /**
  * 鐩告満璁惧Controller
@@ -47,6 +47,8 @@
     private HikClientServiceImpl sdk;
     @Resource
     private IArdCamerasService ardCamerasService;
+    @Resource
+    private IArdVideoInspectTaskService ardVideoInspectTaskService;
 
     /**
      * 鏌ヨ鐩告満璁惧鍒楄〃
@@ -94,16 +96,7 @@
         //娉ㄩ攢
         sdk.loginOut(camera.getId());
         //鐧诲綍
-        camera = sdk.login(camera);
-        if (camera.getLoginId() >= 0) {
-            log.info("鐩告満" + camera.getIp() + ":" + camera.getPort() + "鐧诲綍鎴愬姛锛�" + camera.getLoginId());
-            camera.setUpdateBy(SecurityUtils.getUsername());
-            ardCamerasService.updateArdCameras(camera);
-        }
-        else
-        {
-            log.info("鐩告満" + camera.getIp() + ":" + camera.getPort() + "鐧诲綍澶辫触锛�" + camera.getLoginId());
-        }
+        sdk.login(camera);
         return toAjax(ardCamerasService.insertArdCameras(camera));
     }
 
@@ -116,19 +109,10 @@
     @PutMapping
     public AjaxResult edit(@RequestBody ArdCameras camera) {
         int i = ardCamerasService.updateArdCameras(camera);
-        if(i>0)
-        {
+        if (i > 0) {
             ArdCameras cameras = ardCamerasService.selectArdCamerasById(camera.getId());
             sdk.loginOut(cameras.getId());
-            camera = sdk.login(cameras);
-            if (camera.getLoginId() >= 0) {
-                log.info("鐩告満" + camera.getIp() + ":" + camera.getPort() + "鐧诲綍鎴愬姛锛�" + camera.getLoginId());
-                ardCamerasService.updateArdCameras(camera);
-            }
-            else
-            {
-                log.info("鐩告満" + camera.getIp() + ":" + camera.getPort() + "鐧诲綍澶辫触锛�" + camera.getLoginId());
-            }
+            sdk.login(cameras);
         }
         return toAjax(i);
     }
@@ -142,10 +126,11 @@
     @DeleteMapping("/{ids}")
     public AjaxResult remove(@PathVariable String[] ids) {
         for (String id : ids) {
-               sdk.loginOut(id);
-            }
+            sdk.loginOut(id);
+        }
         return toAjax(ardCamerasService.deleteArdCamerasByIds(ids));
     }
+
     @GetMapping("/options")
     @ApiOperation("閫夋嫨鐩告満鏁版嵁")
     public List options(ArdCameras ardCameras) {
@@ -156,7 +141,8 @@
             option.put("value", item.getId());
             option.put("label", item.getName());
             option.put("channel", item.getChannel());
-           // option.put("description", item.getOilProduction());
+            List timeList = ardVideoInspectTaskService.getCameraIdleTimeList(item.getId());
+            option.put("idleTimeList", timeList);//绌洪棽鏃堕棿娈�
             options.add(option);
         }
         return options;
@@ -168,4 +154,12 @@
         Map deptAndCamera = ardCamerasService.getChildDeptAndCamera();
         return AjaxResult.success(deptAndCamera);
     }
+    @PostMapping("/getNearCamerasBycoordinate")
+    @ApiOperation("鑾峰彇闄勮繎鐨勭浉鏈�")
+    @ApiOperationSupport(includeParameters = {"targetPosition"})
+    public AjaxResult getNearCamerasBycoordinate(@RequestBody CameraCmd cmd)
+    {
+        TreeMap nearCamerasBycoordinate = ardCamerasService.getNearCamerasBycoordinate(cmd);
+        return AjaxResult.success(nearCamerasBycoordinate);
+    }
 }

--
Gitblit v1.9.3