From 145f3c2fa994f7fdc37248fa0e2222a14ac5c7d9 Mon Sep 17 00:00:00 2001
From: 潘志宝 <979469083@qq.com>
Date: 星期二, 06 五月 2025 18:15:13 +0800
Subject: [PATCH] 功率因数-电网拓扑 增加有功无功预警

---
 ansteel-biz/src/main/java/com/iailab/module/ansteel/api/controller/admin/PowerController.java |   97 ++++++++++++++++++++++++++++++++----------------
 1 files changed, 64 insertions(+), 33 deletions(-)

diff --git a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/controller/admin/PowerController.java b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/controller/admin/PowerController.java
index bcbe359..e80f133 100644
--- a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/controller/admin/PowerController.java
+++ b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/controller/admin/PowerController.java
@@ -84,7 +84,7 @@
     @Operation(summary = "功率因数-电网拓扑")
     public CommonResult<List<PowerNetFactorDTO>> getPowerNetFactorList(@RequestParam Map<String, Object> params) {
         List<PowerNetFactorEntity> list = powerNetFactorService.list(params);
-        List<PowerNetFactorDTO> result = ConvertUtils.sourceToTarget(list, PowerNetFactorDTO.class);
+        List<PowerNetFactorDTO> result = new ArrayList<>();
         if (CollectionUtils.isEmpty(result)) {
             return success(result);
         }
@@ -94,72 +94,102 @@
         calendar.set(Calendar.MINUTE, 0);
         calendar.set(Calendar.HOUR_OF_DAY, 0);
 
-        for (PowerNetFactorDTO dto : result) {
+        for (PowerNetFactorEntity entity : list) {
+            PowerNetFactorDTO powerNetFactorDTO = new PowerNetFactorDTO();
+            powerNetFactorDTO.setId(entity.getId());
+            powerNetFactorDTO.setGroupName(entity.getGroupName());
+            powerNetFactorDTO.setNodeCode(entity.getNodeCode());
+            powerNetFactorDTO.setNodeName(entity.getNodeName());
             boolean cosFlag = false;
             try {
                 List<String> points = new ArrayList<>();
-                if (StringUtils.isNotBlank(dto.getCurP())) {
-                    points.add(dto.getCurP());
+                if (StringUtils.isNotBlank(entity.getCurP())) {
+                    points.add(entity.getCurP());
                 }
-                if (StringUtils.isNotBlank(dto.getCurQ())) {
-                    points.add(dto.getCurQ());
+                if (StringUtils.isNotBlank(entity.getCurQ())) {
+                    points.add(entity.getCurQ());
                 }
                 if (!CollectionUtils.isEmpty(points)) {
                     Map<String, Object> pointsRealValue = dataPointApi.queryPointsRealValue(points);
-                    if (pointsRealValue.get(dto.getCurP()) != null) {
-                        dto.setCurP(pointsRealValue.get(dto.getCurP()).toString());
+                    if (pointsRealValue.get(entity.getCurP()) != null) {
+                        powerNetFactorDTO.setCurP(new BigDecimal(pointsRealValue.get(entity.getCurP()).toString()));
                     }
-                    if (pointsRealValue.get(dto.getCurQ()) != null) {
-                        dto.setCurQ(pointsRealValue.get(dto.getCurQ()).toString());
+                    if (pointsRealValue.get(entity.getCurQ()) != null) {
+                        powerNetFactorDTO.setCurQ(new BigDecimal(pointsRealValue.get(entity.getCurQ()).toString()));
                     }
-                    if (pointsRealValue.get(dto.getCurCos()) != null) {
-                        dto.setCurCos(pointsRealValue.get(dto.getCurCos()).toString());
+                    if (pointsRealValue.get(entity.getCurCos()) != null) {
+                        powerNetFactorDTO.setCurCos(new BigDecimal(pointsRealValue.get(entity.getCurCos()).toString()));
                         cosFlag = true;
                     }
                 }
             } catch (Exception ex) {
-                log.info(dto.getNodeName() + "获取当前值异常" + ex.getMessage());
+                log.info(entity.getNodeName() + "获取当前值异常" + ex.getMessage());
             }
 
             try {
                 PredictLastValueReqVO reqVO = new PredictLastValueReqVO();
                 reqVO.setPredictTime(calendar.getTime());
                 List<String[]> itemNos = new ArrayList<>();
-                if (StringUtils.isNotBlank(dto.getPreP())) {
-                    itemNos.add(dto.getPreP().split(","));
+                if (StringUtils.isNotBlank(entity.getPreP())) {
+                    itemNos.add(entity.getPreP().split(","));
                 }
-                if (StringUtils.isNotBlank(dto.getPreQ())) {
-                    itemNos.add(dto.getPreQ().split(","));
+                if (StringUtils.isNotBlank(entity.getPreQ())) {
+                    itemNos.add(entity.getPreQ().split(","));
                 }
-                if (StringUtils.isNotBlank(dto.getPreCos())) {
-                    itemNos.add(dto.getPreCos().split(","));
+                if (StringUtils.isNotBlank(entity.getPreCos())) {
+                    itemNos.add(entity.getPreCos().split(","));
                 }
                 if (!CollectionUtils.isEmpty(itemNos)) {
                     reqVO.setItemNos(itemNos);
                     log.info("reqVO=" + JSONObject.toJSONString(reqVO));
                     Map<String, BigDecimal> preValues = mcsApi.getPredictValueByTime(reqVO);
-                    if (StringUtils.isNotBlank(dto.getPreP()) && preValues.get(dto.getPreP()) != null) {
-                        dto.setPreP(preValues.get(dto.getPreP()).toString());
+                    if (StringUtils.isNotBlank(entity.getPreP()) && preValues.get(entity.getPreP()) != null) {
+                        powerNetFactorDTO.setPreP(new BigDecimal(preValues.get(entity.getPreP()).toString()));
                     }
-                    if (StringUtils.isNotBlank(dto.getPreQ()) && preValues.get(dto.getPreQ()) != null) {
-                        dto.setPreQ(preValues.get(dto.getPreQ()).toString());
+                    if (StringUtils.isNotBlank(entity.getPreQ()) && preValues.get(entity.getPreQ()) != null) {
+                        powerNetFactorDTO.setPreQ(new BigDecimal(preValues.get(entity.getPreQ()).toString()));
                     }
-                    if (StringUtils.isNotBlank(dto.getPreCos()) && preValues.get(dto.getPreCos()) != null) {
-                        dto.setPreCos(preValues.get(dto.getPreCos()).toString());
+                    if (StringUtils.isNotBlank(entity.getPreCos()) && preValues.get(entity.getPreCos()) != null) {
+                        powerNetFactorDTO.setPreCos(new BigDecimal(preValues.get(entity.getPreCos()).toString()));
                     }
                 }
             } catch (Exception ex) {
-                log.info(dto.getNodeName() + "获取预测值异常," + ex.getMessage());
+                log.info(entity.getNodeName() + "获取预测值异常," + ex.getMessage());
             }
 
-            // 设置状态
-            if (cosFlag && StringUtils.isNotBlank(dto.getCurCos()) && NumberUtil.isNumber(dto.getCurCos())) {
-                BigDecimal curCos = new BigDecimal(dto.getCurCos());
-                if (dto.getLimitL() != null && dto.getLimitH() != null &&
-                        curCos.compareTo(dto.getLimitL()) < 0 || curCos.compareTo(dto.getLimitH()) > 0) {
-                    dto.setStatus(1);
+            // 设置功率因数状态
+            if (cosFlag && powerNetFactorDTO.getCurCos() != null) {
+                BigDecimal curCos = powerNetFactorDTO.getCurCos();
+                if (entity.getLimitL() != null && curCos.compareTo(entity.getLimitL()) < 0) {
+                    powerNetFactorDTO.setStatus(1);
+                } else if (entity.getLimitH() != null && curCos.compareTo(entity.getLimitH()) > 0) {
+                    powerNetFactorDTO.setStatus(1);
                 } else {
-                    dto.setStatus(0);
+                    powerNetFactorDTO.setStatus(0);
+                }
+            }
+
+            // 设置有功预警状态
+            if (powerNetFactorDTO.getCurP() != null) {
+                BigDecimal curP = powerNetFactorDTO.getCurP();
+                if (entity.getPLimitH() != null && curP.compareTo(entity.getPLimitL()) < 0) {
+                    powerNetFactorDTO.setStatus(1);
+                } else if (entity.getPLimitH() != null && curP.compareTo(entity.getPLimitH()) > 0) {
+                    powerNetFactorDTO.setStatus(1);
+                } else {
+                    powerNetFactorDTO.setStatus(0);
+                }
+            }
+
+            // 设置无功预警状态
+            if (powerNetFactorDTO.getCurQ() != null) {
+                BigDecimal curQ = powerNetFactorDTO.getCurQ();
+                if (entity.getQLimitH() != null && curQ.compareTo(entity.getQLimitL()) < 0) {
+                    powerNetFactorDTO.setStatus(1);
+                } else if (entity.getQLimitH() != null && curQ.compareTo(entity.getQLimitH()) > 0) {
+                    powerNetFactorDTO.setStatus(1);
+                } else {
+                    powerNetFactorDTO.setStatus(0);
                 }
             }
         }
@@ -920,6 +950,7 @@
             if (value.compareTo(entity.getLimitH()) > 0) {
                 dto.setStatus(1);
             }
+            dto.setVoltage(value);
             result.add(dto);
         }
         return success(result);

--
Gitblit v1.9.3