From 85b2001c0ec2f1adc598db3bf47ad457dcca7074 Mon Sep 17 00:00:00 2001
From: dengzedong <dengzedong@email>
Date: 星期四, 19 十二月 2024 16:37:53 +0800
Subject: [PATCH] item-chart 空point校验

---
 iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/point/collection/handler/MeasureHandle.java |   29 ++++++++++++++++++-----------
 1 files changed, 18 insertions(+), 11 deletions(-)

diff --git a/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/point/collection/handler/MeasureHandle.java b/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/point/collection/handler/MeasureHandle.java
index cd4f668..c97aa8b 100644
--- a/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/point/collection/handler/MeasureHandle.java
+++ b/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/point/collection/handler/MeasureHandle.java
@@ -1,6 +1,7 @@
 package com.iailab.module.data.point.collection.handler;
 
-import com.iailab.module.data.channel.http.collector.ihdb.HttpCollectorForSS;
+import com.iailab.module.data.channel.http.collector.SourceApiEnum;
+import com.iailab.module.data.channel.http.collector.ihdb.HttpCollectorForIhd;
 import com.iailab.module.data.channel.opcda.collector.OpcDACollector;
 import com.iailab.module.data.common.enums.CommonConstant;
 import com.iailab.module.data.common.enums.DataSourceType;
@@ -52,7 +53,7 @@
     private OpcDACollector opcDACollector;
 
     @Autowired
-    private HttpCollectorForSS httpCollectorForSS;
+    private HttpCollectorForIhd httpCollectorForIhd;
 
     @Resource
     private DaPointService daPointService;
@@ -68,7 +69,7 @@
         List<String[]> opcDaTagIds = new ArrayList<>();
         List<String[]> modbusTagIds = new ArrayList<>();
         List<String[]> kioTagIds = new ArrayList<>();
-        List<Object[]> httpTagSS = new ArrayList<>();
+        List<Object[]> httpTagIhd = new ArrayList<>();
 
 
         dtos.stream().forEach(item -> {
@@ -81,8 +82,10 @@
             } else if (DataSourceType.KIO.getCode().equals(item.getSourceType())) {
                 kioTagIds.add(new String[]{item.getSourceId(), item.getTagNo()});
             } else if (DataSourceType.HTTP.getCode().equals(item.getSourceType())) {
-                if (CommonConstant.HTTP_API_SHASTEEL_IH.equals(item.getSourceName())) {
-                    httpTagSS.add(new Object[]{item.getSourceId(), item.getTagNo(), item.getDimension(), item.getValueType()});
+                if (SourceApiEnum.iHyperDB.getCode().equals(item.getSourceName())) {
+                    if (item.getTagNo() != null && item.getDimension() != null && item.getValueType() != null) {
+                        httpTagIhd.add(new Object[]{item.getSourceId(), item.getTagNo(), item.getDimension(), item.getValueType()});
+                    }
                 }
             }
         });
@@ -100,8 +103,8 @@
         if (!CollectionUtils.isEmpty(kioTagIds)) {
             tagValues.putAll(kingIOCollector.getTagValues(kioTagIds));
         }
-        if (!CollectionUtils.isEmpty(httpTagSS)) {
-            tagValues.putAll(httpCollectorForSS.getTagValues(httpTagSS));
+        if (!CollectionUtils.isEmpty(httpTagIhd)) {
+            tagValues.putAll(httpCollectorForIhd.getTagValues(httpTagIhd, collectTime));
         }
         this.toCommonResult(collectTime, dtos, tagValues, dataMap, result);
         log.info("测量点处理结束");
@@ -132,12 +135,17 @@
     private Object handleData(DaPointDTO dto, Object value) {
         Object result = value;
         try {
+            if (value == null) {
+                return CommonConstant.BAD_VALUE;
+            }
             if (DataTypeEnum.FLOAT.getCode().equals(dto.getDataType()) || DataTypeEnum.INT.getCode().equals(dto.getDataType())) {
                 BigDecimal rawValue = new BigDecimal(value.toString());
-
+                if(CommonConstant.BAD_VALUE.compareTo(rawValue) == 0) {
+                    return CommonConstant.BAD_VALUE;
+                }
                 // 异常值处理
                 if (rawValue.compareTo(maxValue) > 0 || rawValue.compareTo(minValue) < 0) {
-                    rawValue = CommonConstant.BAD_VALUE;
+                    return CommonConstant.BAD_VALUE;
                 }
                 BigDecimal coefficient = dto.getUnittransfactor() == null ? BigDecimal.ONE : dto.getUnittransfactor();
                 BigDecimal calValue = rawValue.multiply(coefficient);
@@ -156,7 +164,6 @@
             } else if (DataTypeEnum.BOOLEAN.getCode().equals(dto.getDataType())) {
                 result = Boolean.parseBoolean(value.toString());
             }
-
         } catch (Exception ex) {
             log.warn("handleData异常,PointNo=" + dto.getPointNo());
             ex.printStackTrace();
@@ -178,7 +185,7 @@
                         } else if (DataSourceType.KIO.getCode().equals(item.getSourceType())) {
                             value = kingIOCollector.getTagValue(item.getSourceId(), item.getTagNo());
                         } else if (DataSourceType.HTTP.getCode().equals(item.getSourceType())) {
-                            value = httpCollectorForSS.getTagValue(item.getSourceId(), item.getTagNo(), item.getDimension(), item.getValueType());
+                            value = httpCollectorForIhd.getTagValue(item.getSourceId(), item.getTagNo(), item.getDimension(), item.getValueType());
                         } else {
                             log.info("没有匹配的TagNo=" + item.getTagNo());
                         }

--
Gitblit v1.9.3