From 4f6aa1ec356dac1e676cc8e66712058953901e5f Mon Sep 17 00:00:00 2001
From: zjj <3272660260@qq.com>
Date: 星期五, 30 八月 2024 17:15:30 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/asrs/controller/MonitorController.java |   90 ++++++++++++++++++++++++++-------------------
 1 files changed, 52 insertions(+), 38 deletions(-)

diff --git a/src/main/java/com/zy/asrs/controller/MonitorController.java b/src/main/java/com/zy/asrs/controller/MonitorController.java
index 32f943a..a5b5631 100644
--- a/src/main/java/com/zy/asrs/controller/MonitorController.java
+++ b/src/main/java/com/zy/asrs/controller/MonitorController.java
@@ -11,7 +11,10 @@
 import com.zy.core.CrnThread;
 import com.zy.core.cache.SlaveConnection;
 import com.zy.core.enums.SlaveType;
+import com.zy.core.model.LedSlave;
+import com.zy.core.model.command.LedCommand;
 import com.zy.core.model.protocol.CrnProtocol;
+import com.zy.core.properties.SlaveProperties;
 import com.zy.core.thread.LedThread;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.GetMapping;
@@ -33,6 +36,8 @@
 
     @Autowired
     private ReportQueryMapper reportQueryMapper;
+    @Autowired
+    private SlaveProperties slaveProperties;
 
     /**
      * 鑾峰彇褰撳墠鏃堕棿
@@ -57,42 +62,17 @@
      * 鑾峰彇鍏朵粬淇℃伅
      */
     @GetMapping("/other")
-    public R monitorOther(@RequestParam("crnId") Integer crnId, @RequestParam("ledId") Integer ledId) {
-        switch (ledId){
-            case 101:
-                ledId=1;
-                break;
-            case 107:
-                ledId=2;
-                break;
-            case 117:
-                ledId=3;
-                break;
-            case 126:
-                ledId=4;
-                break;
-            case 134:
-                ledId=5;
-                break;
-            case 201:
-                ledId=6;
-                break;
-            case 205:
-                ledId=7;
-                break;
-            case 207:
-                ledId=8;
-                break;
-            case 211:
-                ledId=9;
-                break;
-            case 213:
-                ledId=10;
-                break;
-            case 217:
-                ledId=11;
-                break;
+    public R monitorOther(@RequestParam("crnId") Integer crnId, @RequestParam("ledId") Integer sta) {
+        Integer ledId = 0;
+        for (LedSlave led : slaveProperties.getLed()) {
+            for (Integer staNo : led.getStaArr()) {
+                if (staNo.equals(sta)) {
+                    ledId = led.getId();
+                    break;
+                }
+            }
         }
+
         Double xSpeed = 0.0D;
         Double ySpeed = 0.0D;
         Double zSpeed = 0.0D;
@@ -134,7 +114,7 @@
 
         // 鑾峰彇杈撻�佺嚎plc绾跨▼
         LedThread ledThread = (LedThread) SlaveConnection.get(SlaveType.Led, ledId);
-        String ledContent = ledThread.getWorkNos().toString();
+        String ledContent = Cools.isEmpty(ledThread) ? "" : ledThread.getWorkNos().toString();
 //        ledContent = "ask鐨勬ā鍧楄惃婊″ぇ绠椾簡钀ㄦ弧澶т簡\n 鏄獦澧冨埌鍩冨強鍡插鍡瞈n 钀ㄨ揪濮嗘墦寮�钀ㄦ弧澶у嚡鎾掗害褰撳姵钀ㄦ弧澶ц�佸笀";
 
         return R.ok(
@@ -250,13 +230,13 @@
         // 浣跨敤涓�
         Integer used = locUseRate.getFqty() + locUseRate.getUqty();
         // 搴撲綅浣跨敤鐜�
-        double usedDivides = Arith.divides(3, used, total);
+        double usedDivides = Arith.divides(3, used, 11200);
         double usedPr = Arith.multiplys(1, usedDivides, 100);
 
         return R.ok(
                 Cools.add("pie", pie)
                 .add("stockCunt", locUseRate.getFqty())
-                .add("emptyCount", locUseRate.getOqty())
+                .add("emptyCount", 11200-used)
                 .add("noneCount", locUseRate.getXqty())
                 .add("total", total)
                 .add("used", used)
@@ -264,7 +244,41 @@
         );
     }
 
+    /**
+     * 鑾峰彇鍏朵粬淇℃伅
+     */
+    @GetMapping("/led")
+    public R monitorLed(@RequestParam("ledId") Integer ledId) {
+        String ledContent = "";
+        List<LedCommand> commandList = null;
+        for (LedSlave slave : slaveProperties.getLed()) {
+            if (slave.getStaArr().contains(ledId)) {
+                LedThread ledThread = (LedThread) SlaveConnection.get(SlaveType.Led, slave.getId());
+                if (null != ledThread) {
+                    ledContent = ledThread.getStringBuffer().toString();
+                    commandList = ledThread.getCommandList();
+                }
+            }
+        }
+        return R.ok().add(commandList);
+    }
 
+    /**
+     * 寮傚父閫氱煡
+     */
+    @GetMapping("/led/error")
+    public R monitorLedError(@RequestParam("ledId") Integer ledId) {
+        String errorMsg = "";
+        for (LedSlave slave : slaveProperties.getLed()) {
+            if (slave.getStaArr().contains(ledId)) {
+                LedThread ledThread = (LedThread) SlaveConnection.get(SlaveType.Led, slave.getId());
+                if (null != ledThread) {
+                    errorMsg = ledThread.getErrorMsg().toString();
+                }
+            }
+        }
+        return R.ok().add(errorMsg);
+    }
 
 
 

--
Gitblit v1.9.1