From b1084891961232e3c697ea9fc52f127cdccffb6b Mon Sep 17 00:00:00 2001
From: liusuyi <1951119284@qq.com>
Date: 星期四, 11 七月 2024 17:28:44 +0800
Subject: [PATCH] 优化:流媒体

---
 ard-work/src/main/java/com/ruoyi/utils/sdk/dhsdk/service/impl/DahuaSDK.java |   65 +++++++++++---------------------
 1 files changed, 22 insertions(+), 43 deletions(-)

diff --git a/ard-work/src/main/java/com/ruoyi/utils/sdk/dhsdk/service/impl/DahuaSDK.java b/ard-work/src/main/java/com/ruoyi/utils/sdk/dhsdk/service/impl/DahuaSDK.java
index 3957ce6..be1a771 100644
--- a/ard-work/src/main/java/com/ruoyi/utils/sdk/dhsdk/service/impl/DahuaSDK.java
+++ b/ard-work/src/main/java/com/ruoyi/utils/sdk/dhsdk/service/impl/DahuaSDK.java
@@ -104,7 +104,7 @@
             NetSDKLib.LLong loginId = LoginModule.login(camera.getIp(), camera.getPort(), camera.getUsername(), camera.getPassword(), m_stDeviceInfo);
             if (loginId.longValue() <= 0) {
                 camera.setChanNum(0);
-                camera.setLoginId(-1);
+                camera.setLoginId(-1l);
                 camera.setState("0");
                 ardCamerasService.updateArdCameras(camera);
                 //鍒犻櫎绠$悊閫氶亾
@@ -112,11 +112,11 @@
                 log.error("璁惧[" + camera.getIp() + ":" + camera.getPort() + "]鐧诲綍澶辫触:" + getErrorCodePrint());
                 return AjaxResult.warn(ErrorCode.getErrorCode(LoginModule.netsdk.CLIENT_GetLastError()));
             }
-
+            log.debug("璁惧[" + camera.getIp() + ":" + camera.getPort() + "]鐧诲綍鎴愬姛:" + (int) loginId.longValue());
             camera.setState("1");
             camera.setChanNum(m_stDeviceInfo.byChanNum);
-            camera.setStartDChan(1);
-            camera.setLoginId((int) loginId.longValue());
+            camera.setStartChan(1);
+            camera.setLoginId(loginId.longValue());
             GlobalVariable.loginMap.put(camera.getId(), loginId);
             //鑾峰彇鏈�鏂伴�氶亾
             List<ArdChannel> ardChannelList = getChannels(camera);
@@ -125,12 +125,11 @@
                 ardChannelList.stream().forEach(channel -> {
                     ardChannelService.insertArdChannel(channel);
                 });
-                camera.setChanNum(ardChannelList.size());
                 camera.setChannelList(ardChannelList);
-                ardCamerasService.updateArdCameras(camera);
-                //閰嶇疆鍒版祦濯掍綋
-                addVtdu(camera);
+                //閫氶亾鎵归噺娣诲姞鍒版祦濯掍綋
+                batchAddVtdu(camera);
             }
+            ardCamerasService.updateArdCameras(camera);
             //鍒涘缓寮曞闃熷垪
             createGuideQueue(camera);
             return AjaxResult.success("璁惧鐧诲綍鎴愬姛");
@@ -149,7 +148,7 @@
             NetSDKLib.LLong loginId = LoginModule.login(camera.getIp(), camera.getPort(), camera.getUsername(), camera.getPassword(), m_stDeviceInfo);
             if (loginId.longValue() <= 0) {
                 camera.setChanNum(0);
-                camera.setLoginId(-1);
+                camera.setLoginId(-1l);
                 camera.setState("0");
                 ardCamerasService.updateArdCameras(camera);
                 //鍒犻櫎绠$悊閫氶亾
@@ -157,10 +156,11 @@
                 log.error("璁惧[" + camera.getIp() + ":" + camera.getPort() + "]鐧诲綍澶辫触:" + getErrorCodePrint());
                 return AjaxResult.warn(getErrorCodePrint());
             }
+            log.debug("璁惧[" + camera.getIp() + ":" + camera.getPort() + "]鐧诲綍鎴愬姛:" + loginId);
             camera.setState("1");
             camera.setChanNum(m_stDeviceInfo.byChanNum);
-            camera.setStartDChan(1);
-            camera.setLoginId((int) loginId.longValue());
+            camera.setStartChan(1);
+            camera.setLoginId((Long) loginId.longValue());
             ardCamerasService.updateArdCameras(camera);
             GlobalVariable.loginMap.put(camera.getId(), loginId);
 
@@ -171,12 +171,11 @@
                 ardChannelList.stream().forEach(channel -> {
                     ardChannelService.insertArdChannel(channel);
                 });
-                camera.setChanNum(ardChannelList.size());
                 camera.setChannelList(ardChannelList);
-                ardCamerasService.updateArdCameras(camera);
-                //閰嶇疆鍒版祦濯掍綋
-                addVtdu(camera);
+                //閫氶亾鎵归噺娣诲姞鍒版祦濯掍綋
+                batchAddVtdu(camera);
             }
+            ardCamerasService.updateArdCameras(camera);
             //鍒涘缓寮曞闃熷垪
             createGuideQueue(camera);
             return AjaxResult.success("鐧诲綍鎴愬姛");
@@ -186,35 +185,13 @@
         }
     }
 
-    //娣诲姞鍒版祦濯掍綋
-    private void addVtdu(ArdCameras camera) {
+    //閫氶亾鎵归噺娣诲姞鍒版祦濯掍綋
+    public void batchAddVtdu(ArdCameras camera) {
         camera.getChannelList().stream().forEach(channel -> {
-            String name = camera.getId() + "_" + channel.getChanNo();
-            String rtspSource = "rtsp://" + camera.getUsername() + ":" + camera.getPassword() + "@" + camera.getIp() + ":" + camera.getRtspPort() + "/cam/realmonitor?channel=" + channel.getChanNo() + "&subtype=0";
-             //鍒犻櫎娴佸獟浣�
-            if (vtduService.selectVtduByName(name) != null) {
-                vtduService.deleteVtduByName(name);
-            }
-            //娣诲姞鍒版祦濯掍綋
-            CameraCmd cmd = new CameraCmd(camera.getId(), channel.getChanNo());
-            Map<String, Object> videoCompressionCfg = getVideoCompressionCfg(cmd);
-            Vtdu vtdu = new Vtdu();
-            if (videoCompressionCfg.get("videoEncType") != null) {
-                if (videoCompressionCfg.get("videoEncType").equals("鏍囧噯h264")) {
-                    vtdu.setIsCode("0");//榛樿涓嶈浆鐮�
-                } else {
-                    vtdu.setIsCode("1");//榛樿杞爜
-                }
-            } else {
-                vtdu.setIsCode("0");//榛樿涓嶈浆鐮�
-            }
-            vtdu.setRtspSource(rtspSource);
-            vtdu.setName(name);
-            vtdu.setMode("1");//榛樿CPU杞В鐮�
-            vtdu.setCameraId(camera.getId());
-            vtduService.insertVtdu(vtdu);
+            vtduService.addChanToVtdu(camera, channel);
         });
     }
+
 
     //鍒涘缓寮曞闃熷垪
     private void createGuideQueue(ArdCameras camera) {
@@ -231,12 +208,14 @@
 
     //鑾峰彇閫氶亾
     public List<ArdChannel> getChannels(ArdCameras camera) {
+        if (camera.getLoginId().equals(-1)) {
+            return new ArrayList<>();
+        }
         LLong loginId = new LLong(camera.getLoginId());
         List<ArdChannel> ardChannelList = new ArrayList<>();
         for (int i = 1; i < camera.getChanNum() + 1; i++) {
             ArdChannel channel = new ArdChannel();
-            String chanName = ConfigModule.getChannelName(loginId, i - 1).trim();
-            log.debug("鑾峰彇閫氶亾鍚嶇О锛�" + chanName);
+            String chanName = ConfigModule.getChannelName(loginId, i).trim();
             channel.setName(chanName.equals("") ? "閫氶亾" + i : chanName);
             channel.setDeviceId(camera.getId());
             channel.setChanNo(i);

--
Gitblit v1.9.3