From 29b24b9f230e230bb9a394c8301484070d7de1a6 Mon Sep 17 00:00:00 2001
From: zwl <1051256694@qq.com>
Date: 星期五, 27 六月 2025 08:28:47 +0800
Subject: [PATCH] 新增中库位

---
 src/main/java/com/zy/core/thread/LedThread.java |  200 ++++++++++++++++++++++++-------------------------
 1 files changed, 98 insertions(+), 102 deletions(-)

diff --git a/src/main/java/com/zy/core/thread/LedThread.java b/src/main/java/com/zy/core/thread/LedThread.java
index deb64fe..f3d001a 100644
--- a/src/main/java/com/zy/core/thread/LedThread.java
+++ b/src/main/java/com/zy/core/thread/LedThread.java
@@ -2,11 +2,16 @@
 
 import com.alibaba.fastjson.JSON;
 import com.core.common.Cools;
+import com.core.common.SpringUtils;
+import com.zy.asrs.entity.CommandInfo;
+import com.zy.asrs.service.CommandInfoService;
+import com.zy.asrs.service.DeviceErrorService;
 import com.zy.common.entity.Parameter;
 import com.zy.common.model.MatDto;
 import com.zy.core.Slave;
 import com.zy.core.ThreadHandler;
 import com.zy.core.cache.MessageQueue;
+import com.zy.core.enums.CommandStatusType;
 import com.zy.core.enums.SlaveType;
 import com.zy.core.model.Task;
 import com.zy.core.model.command.LedCommand;
@@ -23,6 +28,9 @@
 import onbon.bx05.utils.DisplayStyleFactory;
 
 import java.awt.*;
+import java.io.IOException;
+import java.net.InetAddress;
+import java.util.Date;
 import java.util.HashSet;
 import java.util.List;
 import java.util.Set;
@@ -40,25 +48,17 @@
     TextCaptionBxArea area;
     DisplayStyleFactory.DisplayStyle[] styles = DisplayStyleFactory.getStyles().toArray(new DisplayStyleFactory.DisplayStyle[0]);
     private Set<Integer> workNos = new HashSet<>();
-    private boolean ledMk = true;
-//    private boolean resetStatus = false;    // 澶嶄綅鐘舵��
+    private boolean ledMk = false;
+    private boolean resetStatus = false;    // 澶嶄綅鐘舵��
+    private StringBuffer errorMsg = new StringBuffer();
 
     public LedThread(Slave slave) {
         this.slave = slave;
-        try {
-            Bx5GEnv.initial(3000);
-            screen = new Bx5GScreenClient("my");
-        } catch (Exception e) {
-            e.printStackTrace();
-            log.info("led杩炴帴鏋勯�犲櫒閿欒 ===>> [id:{}] [ip:{}] [port:{}]", slave.getId(), slave.getIp(), slave.getPort());
-        }
     }
 
     @Override
     @SuppressWarnings({"InfiniteLoopStatement", "unchecked"})
     public void run() {
-        connect();
-        close();
         while (true) {
             try {
                 Task task = MessageQueue.poll(SlaveType.Led, slave.getId());
@@ -71,10 +71,10 @@
                         // 澶嶄綅
                         case 2:
                             reset();
+//                            this.ledMk = false;
                             break;
-                        // 璀﹀憡淇℃伅
-                        case 3:
-                            write(String.valueOf(task.getData()));
+                        case 5:
+                            error((String) task.getData());
                             break;
                         default:
                             break;
@@ -89,29 +89,42 @@
     }
 
     private void write(List<LedCommand> list) throws Bx5GException {
-//        if (!connect()) {
-//            return;
-//        }
+        if (!connect()) {
+            return;
+        }
         pf = new ProgramBxFile( 0, screen.getProfile());
         pf.setFrameShow(false);
         // 鍒嗗埆杈撳叆X锛孻锛寃idth锛宧eight
-        area = new TextCaptionBxArea( 0,0,192,128, screen.getProfile());
+        area = new TextCaptionBxArea( 0,0,96,48, screen.getProfile());
         // 鍒涘缓涓�涓暟鎹〉
         TextBxPage page = new TextBxPage();
         for (LedCommand command : list) {
             page.newLine(command.getTitle() +"锛�"+command.getWorkNo()+")");
-            page.newLine("婧愬簱浣嶏細"+command.getSourceLocNo());
+            page.newLine("搴撲綅锛�"+ (command.getIoType() < 100 ? command.getLocNo() : command.getSourceLocNo()));
             page.newLine("鐩爣绔欙細"+command.getStaNo());
             if (!command.isEmptyMk()) {
                 for (MatDto matDto : command.getMatDtos()) {
-                    page.newLine(matDto.getMaknx() + "銆愭暟閲�" + matDto.getCount() +"銆�");
+                    //鍘绘帀灏忔暟鐐�
+                    String strQty = matDto.getCount().toString();
+                    int idx = strQty.lastIndexOf(".");
+                    if(idx >= 0){
+                        strQty.substring(0,idx);
+                    }
+                    page.newLine(matDto.getMaknx() + "[鏁伴噺" + strQty +"]");
+//                    page.newLine(matDto.getMaknx() + "銆愭暟閲�" + matDto.getCount() +"銆�");
                 }
             }
             page.newLine("\n");
+
+            //鏇存柊鎸囦护鐘舵��
+            CommandInfoService commandInfoService = SpringUtils.getBean(CommandInfoService.class);
+            CommandInfo commandInfo = command.getCommandInfo();
+            commandInfo.setCommandStatus(CommandStatusType.COMPLETE.id);
+            commandInfoService.updateById(commandInfo);
         }
 
         // 璁剧疆瀛椾綋
-        page.setFont(new Font("瀹嬩綋",Font.PLAIN,14));
+        page.setFont(new Font("瀹嬩綋",Font.PLAIN,12));
         // 璁剧疆鏂囨湰棰滆壊
         page.setForeground(Color.red);
         // 璁剧疆鏄剧ず鐗规妧涓哄揩閫熸墦鍑�
@@ -119,94 +132,58 @@
         area.clearPages();
         area.addPage(page);
         pf.addArea(area);
-        // 鏇存柊鑺傜洰
-        screen.writeProgram(pf);
-//        resetStatus = false;
-        close();
-    }
-
-    private void write(String str) throws Bx5GException {
-//        if (!connect() || Cools.isEmpty(str)) {
-//            return;
-//        }
-        pf = new ProgramBxFile( 0, screen.getProfile());
-        pf.setFrameShow(false);
-        // 鍒嗗埆杈撳叆X锛孻锛寃idth锛宧eight
-        area = new TextCaptionBxArea( 0,0,192,128, screen.getProfile());
-        // 鍒涘缓涓�涓暟鎹〉
-        TextBxPage page = new TextBxPage();
-        page.newLine(str);
-        page.newLine("\n");
-        // 璁剧疆瀛椾綋
-        page.setFont(new Font("瀹嬩綋",Font.PLAIN,14));
-        // 璁剧疆鏂囨湰棰滆壊
-        page.setForeground(Color.red);
-        // 璁剧疆鏄剧ず鐗规妧涓哄揩閫熸墦鍑�
-        page.setDisplayStyle(styles[6]);
-        area.clearPages();
-        area.addPage(page);
-        pf.addArea(area);
-        // 鏇存柊鑺傜洰
-        screen.writeProgram(pf);
-//        resetStatus = false;
+        if (pf.validate() != null) {
+            log.info("pf out of range");
+        } else {
+            // 鏇存柊鑺傜洰
+            screen.writeProgram(pf);
+//            resetStatus = false;
+        }
         close();
     }
 
     private void reset() throws Bx5GException {
-//        if (!connect()) {
-//            return;
-//        }
-        pf = new ProgramBxFile( 0, screen.getProfile());
-        pf.setFrameShow(false);
-        // 鍒嗗埆杈撳叆X锛孻锛寃idth锛宧eight
-        area = new TextCaptionBxArea( 0,0,192,128, screen.getProfile());
-        // 鍒涘缓涓�涓暟鎹〉
-        TextBxPage page = new TextBxPage();
-
-        List<String> list = null;
-        try {
-            String ledDefaultMsg = Parameter.get().getLedDefaultMsg();
-            list = JSON.parseArray(ledDefaultMsg, String.class);
-        } catch (Exception ignore) {
-        }
-        if (!Cools.isEmpty(list)) {
-            for (String str : list) {
-                page.newLine(str);
-            }
-        } else {
-            page.newLine("鑷姩鍖栫珛浣撲粨搴�");
-            page.newLine("娴欐睙涓壃绔嬪簱鎶�鏈湁闄愬叕鍙�");
-        }
-
-        // 璁剧疆瀛椾綋
-        page.setFont(new Font("瀹嬩綋",Font.PLAIN,15));
-        // 璁剧疆鏂囨湰棰滆壊
-        page.setForeground(Color.red);
-        // 璁剧疆鏄剧ず鐗规妧涓哄揩閫熸墦鍑�
-        page.setDisplayStyle(styles[6]);
-        area.clearPages();
-        area.addPage(page);
-        pf.addArea(area);
-        // 鏇存柊鑺傜洰
-        screen.writeProgram(pf);
-        close();
+        errorMsg.delete(0, errorMsg.length());
     }
+
 
     @Override
     public boolean connect() {
         boolean connRes = false;
+
+        // ======= 馃寪 娣诲姞缃戠粶鍙揪鎬ф娴� =======
         try {
-            connRes = screen.connect(slave.getIp(),slave.getPort());
-            screen.turnOn();
-            if (connRes) {
-                log.info("led杩炴帴鎴愬姛 ===>> [id:{}] [ip:{}] [port:{}]", slave.getId(), slave.getIp(), slave.getPort());
-                reset();
-            } else {
-                log.error("led杩炴帴澶辫触锛侊紒锛� ===>> [id:{}] [ip:{}] [port:{}]", slave.getId(), slave.getIp(), slave.getPort());
+            InetAddress address = InetAddress.getByName(slave.getIp());
+            if (!address.isReachable(2000)) {
+                log.warn("璁惧涓嶅彲杈撅紝璺宠繃杩炴帴: {}", slave.getIp());
+                return false;  // 鎻愬墠杩斿洖锛岄伩鍏嶆棤鎰忎箟杩炴帴灏濊瘯
             }
-        } catch (Exception ignore) { }
+        } catch (IOException e) {
+            log.error("IP妫�娴嬪紓甯�: {}", e.getMessage());
+            return false; // 鍙鎯呭喌鍐冲畾鏄惁 return
+        }
+
+        // ======= 灏濊瘯杩炴帴璁惧 =======
+        try {
+            connRes = screen.connect(slave.getIp(), slave.getPort());
+            screen.turnOn(); // 濡傛灉 connect 鎴愬姛鍐嶅紑灞�
+        } catch (Exception e) {
+            log.error("杩炴帴寮傚父: {}", e.getMessage(), e); // 閬垮厤鎹曡幏鍚庢棤鎻愮ず
+        }
+
+        // ======= 璁惧閿欒鐘舵�佸鐞� =======
+        DeviceErrorService deviceErrorService = SpringUtils.getBean(DeviceErrorService.class);
+        if (connRes) {
+            log.info("led杩炴帴鎴愬姛 ===>> [id:{}] [ip:{}] [port:{}]", slave.getId(), slave.getIp(), slave.getPort());
+            deviceErrorService.deleteDeviceError("led", slave.getId());
+        } else {
+            log.error("led杩炴帴澶辫触锛侊紒锛� ===>> [id:{}] [ip:{}] [port:{}]", slave.getId(), slave.getIp(), slave.getPort());
+            deviceErrorService.addDeviceError("led", slave.getId(), "led杩炴帴澶辫触");
+        }
+
         return connRes;
     }
+
 
     @Override
     public void close() {
@@ -216,10 +193,17 @@
 
 
     public static void main(String[] args) throws Exception {
+        String strQty = "1234";
+        int index = strQty.lastIndexOf(".");
+        if(index>=0) {
+            strQty=strQty.substring(0, index);
+        }
+        System.out.println("2==>>"+strQty);
+
         Bx5GEnv.initial(3000);
         Bx5GScreenClient screen = new Bx5GScreenClient("my");
         DisplayStyleFactory.DisplayStyle[] styles = DisplayStyleFactory.getStyles().toArray(new DisplayStyleFactory.DisplayStyle[0]);
-        if (!screen.connect("192.168.10.61",5005)) {
+        if (!screen.connect("192.168.10.101",5005)) {
             System.err.println("杩炴帴澶辫触锛侊紒锛侊紒");
             return;
         }
@@ -232,7 +216,7 @@
             ProgramBxFile pf = new ProgramBxFile( 0, screen.getProfile());
             pf.setFrameShow(false);
             // 鍒嗗埆杈撳叆X锛孻锛寃idth锛宧eigth
-            TextCaptionBxArea area = new TextCaptionBxArea(  0,0,192,128,screen.getProfile());
+            TextCaptionBxArea area = new TextCaptionBxArea(  0,0,192,96,screen.getProfile());
 
             // 鍒涘缓涓�涓暟鎹〉
             // 绗竴琛屾暟鎹�
@@ -240,7 +224,9 @@
             page.newLine("婧愬簱浣嶏細0100204");
             page.newLine("鐩爣绔欙細1000");
             // 璁剧疆瀛椾綋
-            page.setFont( new Font("瀹嬩綋",Font.PLAIN,12));
+            page.setFont( new Font("瀹嬩綋",Font.PLAIN,15));
+            // 璁剧疆鏂囨湰棰滆壊
+            page.setForeground(Color.red);
             // 璁剧疆鏄剧ず鐗规妧涓哄揩閫熸墦鍑�
             page.setDisplayStyle(styles[6]);
             area.clearPages();
@@ -248,7 +234,14 @@
             pf.addArea( area );
 
             // 鏇存柊鑺傜洰
-            screen.writeProgram(pf);
+            // 鏇存柊鑺傜洰
+            if (pf.validate() != null) {
+                System.out.println("pf out of range");
+                log.info("pf out of range");
+            } else {
+                // 鏇存柊鑺傜洰
+                screen.writeProgram(pf);
+            }
         }
 
         // 缁у紑涓庢帶鍒跺櫒涔嬮棿鐨勯摼鎺�
@@ -438,8 +431,11 @@
         //
         // 缁у紑涓庢帶鍒跺櫒涔嬮棿鐨勯摼鎺�
         screen.disconnect();
-
-
+    }
+    private void error(String msg) {
+        log.error("閿欒淇℃伅涓猴細{}",msg);
+        errorMsg.delete(0, errorMsg.length());
+        errorMsg.append(msg);
     }
 
 }

--
Gitblit v1.9.1