From f6a88f721b58a8f97759c0c1542608ff68b0fb5c Mon Sep 17 00:00:00 2001 From: zhangjian <zhangjianrock@163.com> Date: 星期二, 24 十月 2023 10:56:29 +0800 Subject: [PATCH] 视频巡检任务,加入通道管理 --- ard-work/src/main/java/com/ruoyi/device/dhsdk/service/impl/DhClientServiceImpl.java | 265 +++++++++++++++++++++++++++++++--------------------- 1 files changed, 156 insertions(+), 109 deletions(-) diff --git a/ard-work/src/main/java/com/ruoyi/device/dhsdk/service/impl/DhClientServiceImpl.java b/ard-work/src/main/java/com/ruoyi/device/dhsdk/service/impl/DhClientServiceImpl.java index ed12a00..1a41ec9 100644 --- a/ard-work/src/main/java/com/ruoyi/device/dhsdk/service/impl/DhClientServiceImpl.java +++ b/ard-work/src/main/java/com/ruoyi/device/dhsdk/service/impl/DhClientServiceImpl.java @@ -3,35 +3,29 @@ import com.ruoyi.common.annotation.SdkOperate; import com.ruoyi.common.utils.file.FileUtils; import com.ruoyi.common.utils.file.MimeTypeUtils; -import com.ruoyi.common.utils.spring.SpringUtils; import com.ruoyi.common.utils.uuid.IdUtils; 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.channel.domain.ArdChannel; import com.ruoyi.device.channel.service.IArdChannelService; -import com.ruoyi.device.dhsdk.common.Res; import com.ruoyi.device.dhsdk.lib.NetSDKLib; import com.ruoyi.device.dhsdk.lib.NetSDKLib.LLong; -import com.ruoyi.device.dhsdk.lib.enumeration.EM_FOCUS_LIMIT_SELECT_MODE; import com.ruoyi.device.dhsdk.lib.enumeration.EM_NEW_CONFIG; +import com.ruoyi.device.dhsdk.lib.enumeration.NET_EM_CFG_OPERATE_TYPE; import com.ruoyi.device.dhsdk.lib.structure.CFG_VIDEO_IN_FOCUS; -import com.ruoyi.device.dhsdk.lib.structure.CFG_VIDEO_IN_FOCUS_UNIT; -import com.ruoyi.device.dhsdk.lib.structure.NET_ENCODE_VIDEO_INFO; +import com.ruoyi.device.dhsdk.lib.structure.DH_OUT_PTZ_VIEW_RANGE_STATUS; import com.ruoyi.device.dhsdk.module.*; import com.ruoyi.device.dhsdk.service.IDhClientService; import com.ruoyi.device.hiksdk.common.GlobalVariable; -import com.ruoyi.device.hiksdk.sdk.HCNetSDK; +import com.ruoyi.device.camera.service.impl.AsyncLogin; import com.ruoyi.media.domain.Vtdu; import com.ruoyi.media.service.IVtduService; -import com.ruoyi.media.service.impl.VtduServiceImpl; import com.ruoyi.utils.gis.GisUtil; import com.ruoyi.utils.minio.MinioUtil; -import com.ruoyi.utils.tools.ArdTool; import com.sun.jna.Pointer; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Value; -import org.springframework.scheduling.annotation.Async; import org.springframework.stereotype.Service; import javax.annotation.Resource; @@ -65,41 +59,12 @@ @Value("${minio.endpoint}") private String minioEndPoint; + // 璁惧鏂嚎閫氱煡鍥炶皟 private static DisConnect disConnect = new DisConnect(); // 缃戠粶杩炴帴鎭㈠ private static HaveReConnect haveReConnect = new HaveReConnect(); - /** - * 鐧诲綍鎵�鏈夌浉鏈� - * 鍒樿嫃涔� - * 2023/10/17 8:28:13 - */ - @Override - public void loginAll() { - try { - ArdCameras ardCamera = new ArdCameras(); - ardCamera.setFactory("2");//鑾峰彇澶у崕鐩告満 - List<ArdCameras> ardCameras = ardCamerasService.selectArdCamerasListNoDataScope(ardCamera); - for (ArdCameras camera : ardCameras) { - Thread.sleep(500); - //寮傛鐧诲綍 - login(camera); - } - } catch (Exception ex) { - log.error("鍒濆鍖栫櫥褰曠浉鏈哄紓甯革細" + ex.getMessage()); - } - } - - /** - * sdk鍒濆鍖� - * 鍒樿嫃涔� - * 2023/10/17 8:28:13 - */ - @Override - public Boolean init() { - return LoginModule.init(disConnect, haveReConnect); // 鎵撳紑宸ョ▼锛屽垵濮嬪寲 - } /** * 鐧诲綍 @@ -107,9 +72,10 @@ * 2023/10/17 8:28:13 */ @Override - @Async public Boolean login(ArdCameras camera) { - LLong loginId = LoginModule.login(camera.getIp(), camera.getPort(), camera.getUsername(), camera.getPassword()); + LoginModule.init(disConnect, haveReConnect); + NetSDKLib.NET_DEVICEINFO_Ex m_stDeviceInfo = new NetSDKLib.NET_DEVICEINFO_Ex(); + LLong loginId = LoginModule.login(camera.getIp(), camera.getPort(), camera.getUsername(), camera.getPassword(), m_stDeviceInfo); if (loginId.longValue() > 0) { //log.debug(camera.getIp() + ":" + camera.getPort() + "鐧诲綍鎴愬姛"); if (GlobalVariable.loginMap.containsKey(camera.getId())) { @@ -118,13 +84,14 @@ //鍒犻櫎绠$悊閫氶亾 ardChannelService.deleteArdChannelByDeviceId(camera.getId()); camera.setState("1"); - camera.setChanNum(LoginModule.m_stDeviceInfo.byChanNum); + camera.setChanNum(m_stDeviceInfo.byChanNum); camera.setStartDChan(1); camera.setLoginId((int) loginId.longValue()); ardCamerasService.updateArdCameras(camera); GlobalVariable.loginMap.put(camera.getId(), loginId); + //鑾峰彇鏈�鏂伴�氶亾 - for (int i = 1; i < LoginModule.m_stDeviceInfo.byChanNum + 1; i++) { + for (int i = 1; i < m_stDeviceInfo.byChanNum + 1; i++) { ArdChannel channel = new ArdChannel(); AV_CFG_ChannelName av_cfg_channelName = new AV_CFG_ChannelName(); boolean b = ConfigModule.GetNewDevConfig(loginId, i - 1, CFG_CMD_CHANNELTITLE, av_cfg_channelName); @@ -151,10 +118,16 @@ vtduService.deleteVtduByName(name); } //娣诲姞鍒版祦濯掍綋 + CameraCmd cmd = new CameraCmd(camera.getId(), channel.getChanNo()); + Map<String, Object> videoCompressionCfg = getVideoCompressionCfg(cmd); vtdu = new Vtdu(); + if (videoCompressionCfg.get("videoEncType").equals("鏍囧噯h264")) { + vtdu.setIsCode("0");//榛樿涓嶈浆鐮� + } else { + vtdu.setIsCode("1");//榛樿杞爜 + } vtdu.setRtspSource(rtspSource); vtdu.setName(camera.getId() + "_" + channel.getChanNo()); - vtdu.setIsCode("0");//榛樿涓嶈浆鐮� vtdu.setMode("1");//榛樿CPU杞В鐮� vtdu.setCameraId(camera.getId()); vtduService.insertVtdu(vtdu); @@ -167,7 +140,6 @@ ardCamerasService.updateArdCameras(camera); return false; } - return true; } @@ -216,6 +188,7 @@ * 2023/10/17 8:28:13 */ @Override + @SdkOperate public boolean pTZControl(CameraCmd cmd) { String cameraId = cmd.getCameraId(); boolean enable = cmd.isEnable(); @@ -312,7 +285,8 @@ if (b) { DecimalFormat df = new DecimalFormat("0.0");//璁剧疆淇濈暀浣嶆暟 String nPTZPan = df.format((float) dh_ptz_location_info.nPTZPan / 10); - String nPTZTilt = df.format((float) dh_ptz_location_info.nPTZTilt / 10); + float t = (float) dh_ptz_location_info.nPTZTilt / 10; + String nPTZTilt = df.format(t < 0 ? t + 360 : t); String nPTZZoom = df.format((float) dh_ptz_location_info.nPTZZoom); ptzMap.put("p", nPTZPan); ptzMap.put("t", nPTZTilt); @@ -366,7 +340,6 @@ * @淇敼浜哄拰鍏跺畠淇℃伅 娉ㄦ剰淇话瑙掑害璐熷�奸渶瑕佸姞涓�360寰楀埌鐨勬鍊艰繘琛岃缃� */ @Override - @SdkOperate public boolean setZeroPtz(CameraCmd cmd) { String cameraId = cmd.getCameraId(); Integer chanNo = cmd.getChanNo(); @@ -390,7 +363,6 @@ * @淇敼浜哄拰鍏跺畠淇℃伅 */ @Override - @SdkOperate public String picCutCate(CameraCmd cmd) { String cameraId = cmd.getCameraId(); Integer chanNo = cmd.getChanNo(); @@ -648,10 +620,12 @@ cfg_video_in_focus.stVideoInFocusUnit[i].nFocusLimit = 10000;//鑱氱劍鏋侀檺鍊�, 鍗曚綅姣背 if (enable) {//鑱氱劍妯″紡, 0-鍏抽棴, 1-杈呭姪鑱氱劍, 2-鑷姩鑱氱劍, 3-鍗婅嚜鍔ㄨ仛鐒�, 4-鎵嬪姩鑱氱劍 cfg_video_in_focus.stVideoInFocusUnit[i].nMode = 4;//鎵嬪姩鑱氱劍 - cfg_video_in_focus.stVideoInFocusUnit[i].emFocusMode = 1;//鑱氱劍鏋侀檺Manual + cfg_video_in_focus.stVideoInFocusUnit[i].emFocusMode = 0;//鑱氱劍鏋侀檺Manual + log.debug("褰撳墠涓烘墜鍔ㄨ仛鐒︽ā寮�"); } else { cfg_video_in_focus.stVideoInFocusUnit[i].nMode = 2;//鑷姩鑱氱劍 - cfg_video_in_focus.stVideoInFocusUnit[i].emFocusMode = 0;//鑱氱劍鏋侀檺Auto + cfg_video_in_focus.stVideoInFocusUnit[i].emFocusMode = 1;//鑱氱劍鏋侀檺Auto + log.debug("褰撳墠涓鸿嚜鍔ㄨ仛鐒︽ā寮�"); } } cfg_video_in_focus.nChannelIndex = chanNo - 1; @@ -666,6 +640,49 @@ } } + @Override + public String getFocusMode(CameraCmd cmd) { + String mode = ""; + String cameraId = cmd.getCameraId(); + Integer chanNo = cmd.getChanNo(); + if (!GlobalVariable.loginMap.containsKey(cameraId)) { + return ""; + } + LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId); + try { + NET_VIDEOIN_FOCUSMODE_INFO focusModeInfo = new NET_VIDEOIN_FOCUSMODE_INFO(); + int emCfgOpType = NET_EM_CFG_OPERATE_TYPE.NET_EM_CFG_VIDEOIN_FOCUSMODE; + boolean bool = ConfigModule.GetConfig(loginId, chanNo - 1, emCfgOpType, focusModeInfo); + if (!bool) { + log.error("鑾峰彇澶辫触,璇风◢鍚庨噸璇�" + getErrorCodePrint()); + } + System.out.println("閰嶇疆绫诲瀷:" + focusModeInfo.emCfgType); // 鍏蜂綋淇℃伅锛屽弬鑰冨簱閲岀殑鏋氫妇 + System.out.println("鑱氱劍妯″紡:" + focusModeInfo.emFocusMode); + switch (focusModeInfo.emFocusMode) { + case 0: + mode = "鍏抽棴"; + break; + case 1: + mode = "杈呭姪鑱氱劍"; + break; + case 2: + mode = "鑷姩鑱氱劍"; + break; + case 3: + mode = "鍗婅嚜鍔ㄨ仛鐒�"; + break; + case 4: + mode = "鎵嬪姩鑱氱劍"; + break; + } + + } catch (Exception ex) { + log.error("鑾峰彇鑱氱劍妯″紡寮傚父:" + ex.getMessage()); + + } + return mode; + } + //閫忛浘 @Override public boolean controlDefogcfg(CameraCmd cmd) { @@ -677,9 +694,9 @@ } LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId); try { - EM_NEW_CONFIG config = EM_NEW_CONFIG.CFG_CMD_VIDEOINDEFOG; + String command = EM_NEW_CONFIG.CFG_CMD_VIDEOINDEFOG.getValue(); //CFG_VIDEOINDEFOG_LIST cfg_videoindefog_list=new CFG_VIDEOINDEFOG_LIST(); - boolean bool = ConfigModule.SetDevConfig(loginId, chanNo - 1, config.getValue(), null); + boolean bool = ConfigModule.SetDevConfig(loginId, chanNo - 1, command, null); if (!bool) { log.error("鎺у埗澶辫触,璇风◢鍚庨噸璇�" + getErrorCodePrint()); } @@ -776,62 +793,92 @@ @Override public Map<String, Object> getVideoCompressionCfg(CameraCmd cmd) { Map<String, Object> map = new HashMap<>(); - String cameraId = cmd.getCameraId(); - Integer chanNo = cmd.getChanNo(); - if (!GlobalVariable.loginMap.containsKey(cameraId)) { - return null; - } - LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId); - CFG_ENCODE_INFO cfg_encode_info = new CFG_ENCODE_INFO(); - cfg_encode_info.nChannelID = chanNo - 1; - boolean b = ConfigModule.GetNewDevConfig(loginId, chanNo - 1, CFG_CMD_ENCODE, cfg_encode_info); - if (b) { - int emCompression = cfg_encode_info.stuMainStream[0].stuVideoFormat.emCompression;//瑙嗛鏍煎紡 - String videoEncType = ""; - switch (emCompression) { - case 0: - videoEncType = "MPEG4"; - break; - case 1: - videoEncType = "MS-MPEG4"; - break; - case 2: - videoEncType = "MPEG2"; - break; - case 3: - videoEncType = "MPEG1"; - break; - case 4: - videoEncType = "H.263"; - break; - case 5: - videoEncType = "MJPG"; - break; - case 6: - videoEncType = "FCC-MPEG4"; - break; - case 7: - videoEncType = "鏍囧噯h264"; - break; - case 8: - videoEncType = "鏍囧噯h265"; - break; - case 9: - videoEncType = "SVAC"; - break; - default: - videoEncType = "鏈煡"; - break; + try { + String cameraId = cmd.getCameraId(); + Integer chanNo = cmd.getChanNo(); + if (!GlobalVariable.loginMap.containsKey(cameraId)) { + return null; } - int nBitRate = cfg_encode_info.stuMainStream[0].stuVideoFormat.nBitRate; - int nWidth = cfg_encode_info.stuMainStream[0].stuVideoFormat.nWidth; - int nHeight = cfg_encode_info.stuMainStream[0].stuVideoFormat.nHeight; - String resolution = nWidth + "*" + nHeight; - float nFrameRate = cfg_encode_info.stuMainStream[0].stuVideoFormat.nFrameRate; - map.put("resolution", resolution);//鍒嗚鲸鐜� - map.put("videoBitrate", String.valueOf(nBitRate));//姣旂壒鐜� - map.put("videoEncType", videoEncType);//缂栫爜 - map.put("nFrameRate", String.valueOf(nFrameRate));//甯х巼 + LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId); + CFG_ENCODE_INFO cfg_encode_info = new CFG_ENCODE_INFO(); + cfg_encode_info.nChannelID = chanNo - 1; + boolean b = ConfigModule.GetNewDevConfig(loginId, chanNo - 1, CFG_CMD_ENCODE, cfg_encode_info); + if (b) { + int emCompression = cfg_encode_info.stuMainStream[0].stuVideoFormat.emCompression;//瑙嗛鏍煎紡 + String videoEncType = ""; + switch (emCompression) { + case 0: + videoEncType = "MPEG4"; + break; + case 1: + videoEncType = "MS-MPEG4"; + break; + case 2: + videoEncType = "MPEG2"; + break; + case 3: + videoEncType = "MPEG1"; + break; + case 4: + videoEncType = "H.263"; + break; + case 5: + videoEncType = "MJPG"; + break; + case 6: + videoEncType = "FCC-MPEG4"; + break; + case 7: + videoEncType = "鏍囧噯h264"; + break; + case 8: + videoEncType = "鏍囧噯h265"; + break; + case 9: + videoEncType = "SVAC"; + break; + default: + videoEncType = "鏈煡"; + break; + } + int nBitRate = cfg_encode_info.stuMainStream[0].stuVideoFormat.nBitRate; + int nWidth = cfg_encode_info.stuMainStream[0].stuVideoFormat.nWidth; + int nHeight = cfg_encode_info.stuMainStream[0].stuVideoFormat.nHeight; + String resolution = nWidth + "*" + nHeight; + float nFrameRate = cfg_encode_info.stuMainStream[0].stuVideoFormat.nFrameRate; + map.put("resolution", resolution);//鍒嗚鲸鐜� + map.put("videoBitrate", String.valueOf(nBitRate));//姣旂壒鐜� + map.put("videoEncType", videoEncType);//缂栫爜 + map.put("nFrameRate", String.valueOf(nFrameRate));//甯х巼 + } + } catch (Exception ex) { + log.error("鍙栫爜娴佸帇缂╁弬鏁板紓甯�:" + ex.getMessage()); + } + return map; + } + + //鑾峰彇GIS淇℃伅鏁版嵁 + @Override + public Map<String, Object> getGisInfo(CameraCmd cmd) { + Map<String, Object> map = new HashMap<>(); + try { + String cameraId = cmd.getCameraId(); + Integer chanNo = cmd.getChanNo(); + if (!GlobalVariable.loginMap.containsKey(cameraId)) { + return null; + } + LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId); + DH_OUT_PTZ_VIEW_RANGE_STATUS dh_out_ptz_view_range_status = new DH_OUT_PTZ_VIEW_RANGE_STATUS(); + boolean b = ConfigModule.queryDevState(loginId, NET_DEVSTATE_PTZ_VIEW_RANGE, dh_out_ptz_view_range_status); + if (b) { + float nAngelH = (float) dh_out_ptz_view_range_status.nAngelH / 10; + float nAngelV = (float) dh_out_ptz_view_range_status.nAngelV / 10; + map = getPtz(cmd);//鑾峰彇ptz + map.put("fHorFieldAngle", nAngelH);// 姘村钩瑙嗗満瑙� + map.put("fVerFieldAngle", nAngelV);// 鍨傜洿瑙嗗満瑙� + } + } catch (Exception ex) { + log.error("鑾峰彇浜戝彴鍙鍩熷紓甯�" + ex.getMessage()); } return map; } @@ -839,7 +886,7 @@ // 璁惧鏂嚎鍥炶皟: 褰撹澶囧嚭鐜版柇绾挎椂锛孲DK浼氳皟鐢ㄨ鍑芥暟 private static class DisConnect implements NetSDKLib.fDisConnect { public void invoke(LLong m_hLoginHandle, String pchDVRIP, int nDVRPort, Pointer dwUser) { - System.out.printf("Device[%s] Port[%d] DisConnect!\n", pchDVRIP, nDVRPort); + log.warn("Device[" + pchDVRIP + "] Port[" + nDVRPort + "] DisConnect!"); } } @@ -847,7 +894,7 @@ private static class HaveReConnect implements NetSDKLib.fHaveReConnect { @Override public void invoke(LLong lLoginID, String pchDVRIP, int nDVRPort, Pointer dwUser) { - System.out.printf("ReConnect Device[%s] Port[%d]\n", pchDVRIP, nDVRPort); + log.warn("ReConnect Device[" + pchDVRIP + "] Port[" + nDVRPort + "]"); } } -- Gitblit v1.9.3