From 5c82602d54928cc414177084ab6d81cef4c11d15 Mon Sep 17 00:00:00 2001 From: zxl <763096477@qq.com> Date: 星期二, 11 三月 2025 09:33:25 +0800 Subject: [PATCH] getosd数组下标越界问题 以及 离线时间 --- ycl-server/src/main/java/com/ycl/api/YS/YSApi.java | 80 +++++++++++++++++++++++++-------------- 1 files changed, 51 insertions(+), 29 deletions(-) diff --git a/ycl-server/src/main/java/com/ycl/api/YS/YSApi.java b/ycl-server/src/main/java/com/ycl/api/YS/YSApi.java index e36f651..40fd8f6 100644 --- a/ycl-server/src/main/java/com/ycl/api/YS/YSApi.java +++ b/ycl-server/src/main/java/com/ycl/api/YS/YSApi.java @@ -3,21 +3,16 @@ import com.sun.jna.Pointer; import com.sun.jna.ptr.IntByReference; -import com.ycl.api.DH.lib.ToolKits; -import com.ycl.api.DH.utils.DHApi; import com.ycl.api.YS.lib.NetDEVSDKLib; import com.ycl.api.YS.login.Login; -import com.ycl.api.YS.util.Common; import com.ycl.platform.domain.result.OSDResult; import com.ycl.utils.StringUtils; +import enumeration.DeviceType; import lombok.extern.slf4j.Slf4j; -import javax.swing.*; -import javax.swing.table.DefaultTableModel; import java.nio.charset.StandardCharsets; -import java.text.ParseException; import java.text.SimpleDateFormat; -import java.util.Vector; +import java.util.Date; import static com.ycl.api.YS.lib.NetDEVSDKLib.NETDEV_LOGIN_PROTO_E.NETDEV_LOGIN_PROTO_ONVIF; @@ -25,7 +20,6 @@ public class YSApi { public static OSDResult getOsd(String ip, String userName, String password) { - log.info("ip:{},鐢ㄦ埛:{}锛屽瘑鐮�:{}", ip, userName, password); //鐧诲綍 NetDEVSDKLib.NETDEV_DEVICE_LOGIN_INFO_S stDevLoginInfo = new NetDEVSDKLib.NETDEV_DEVICE_LOGIN_INFO_S(); NetDEVSDKLib.NETDEV_SELOG_INFO_S stSELogInfo = new NetDEVSDKLib.NETDEV_SELOG_INFO_S(); @@ -44,15 +38,17 @@ NetDEVSDKLib.NETDEV_VIDEO_CHL_DETAIL_INFO_EX_S[] stVideoChlList = (NetDEVSDKLib.NETDEV_VIDEO_CHL_DETAIL_INFO_EX_S[]) new NetDEVSDKLib.NETDEV_VIDEO_CHL_DETAIL_INFO_EX_S().toArray(nMaxChlCount); boolean bRe = YSInit.netdevsdk.NETDEV_QueryVideoChlDetailListEx(lpUserID, dwChlCount, stVideoChlList); if (!bRe) { - log.error("error code" + YSInit.netdevsdk.NETDEV_GetLastError()); +// log.error("error code" + YSInit.netdevsdk.NETDEV_GetLastError()); return null; } //鑾峰彇鏃堕棿 NetDEVSDKLib.NETDEV_TIME_CFG_S stTimeCfg = new NetDEVSDKLib.NETDEV_TIME_CFG_S(); stTimeCfg.write(); boolean bRetime = NetDemo.netdevsdk.NETDEV_GetSystemTimeCfg(lpUserID, stTimeCfg); + Date checkTime = new Date(); + osdResult.setCheckTime(checkTime); if (!bRetime) { - log.error("error code" + YSInit.netdevsdk.NETDEV_GetLastError()); +// log.error("error code" + YSInit.netdevsdk.NETDEV_GetLastError()); return null; } else { stTimeCfg.read(); @@ -82,7 +78,7 @@ try { osdResult.setOsdTime(format.parse(strTime)); } catch (Exception e) { - log.error(ip + "鏃堕棿瑙f瀽鏈夎"); +// log.error(ip + "鏃堕棿瑙f瀽鏈夎"); } } //鑾峰彇osd @@ -92,34 +88,60 @@ boolean bRet = YSInit.netdevsdk.NETDEV_GetDevConfig(lpUserID, stVideoChlList[0].dwChannelID, NetDEVSDKLib.NETDEV_CONFIG_COMMAND_E.NETDEV_GET_OSDCFG, stOSDInfo.getPointer(), 616, dwBytesReturned); if (!bRet) { - log.error("error code" + YSInit.netdevsdk.NETDEV_GetLastError()); +// log.error("error code" + YSInit.netdevsdk.NETDEV_GetLastError()); return null; } stOSDInfo.read(); - //鐪佷唤 - String name = new String(stOSDInfo.stNameOSD.szOSDText, StandardCharsets.UTF_8); - osdResult.setOSD1(name); - int num = 0; - for (NetDEVSDKLib.NETDEV_OSD_TEXT_OVERLAY_S osd : stOSDInfo.astTextOverlay) { - String text = new String(osd.szOSDText, StandardCharsets.UTF_8).trim(); - if (num == 0) { - osdResult.setOSD2(text); - } else if (num == 1) { - osdResult.setOSD3(text); - } else if (num == 2) { - osdResult.setName(text); - } else if (num == 3) { - osdResult.setOSD4(text); + + + String name = new String(stOSDInfo.stNameOSD.szOSDText, StandardCharsets.UTF_8).trim(); + log.error("YSname:{}" , name); + if (StringUtils.isNotEmpty(name) && name.contains("|")){ + String[] osdNames = name.split("\\|"); + for (int i = 0; i < osdNames.length; i++) { + if (i == 0) { + osdResult.setOSD1(osdNames[i]); + } + if (i == 1) { + osdResult.setOSD2(osdNames[i]); + } + if (i == 2) { + osdResult.setOSD3(osdNames[i]); + } + if (i == 3) { + osdResult.setName(osdNames[i]); + } } - num++; + }else { + //鐪佷唤 + osdResult.setOSD1(name); +// log.info("YSname"+name); + int num = 0; + for (NetDEVSDKLib.NETDEV_OSD_TEXT_OVERLAY_S osd : stOSDInfo.astTextOverlay) { + String text = new String(osd.szOSDText, StandardCharsets.UTF_8).trim(); + log.info("YSnum:"+num+",YStexr:"+text); + if (num == 0) { + osdResult.setOSD2(text); + } else if (num == 1) { + osdResult.setOSD3(text); + } else if (num == 2) { + osdResult.setName(text); + } else if (num == 3) { + osdResult.setOSD4(text); + } + num++; + } } + + //鐧诲嚭 YSInit.netdevsdk.NETDEV_Logout(lpUserID); + osdResult.setDeviceBrand(DeviceType.YS.getType()); return osdResult; } else { - log.error("error code" + YSInit.netdevsdk.NETDEV_GetLastError()); +// log.error("ip:"+ip+",error code" + YSInit.netdevsdk.NETDEV_GetLastError()); + return null; } - return null; } public static void demo() { -- Gitblit v1.8.0