From 1e8898f3fca605a9e8bd22b8e21829b3bb385f45 Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@63.com>
Date: 星期一, 21 二月 2022 15:53:24 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/core/thread/LedThread.java             |  266 ++++++++++++++++++++++++++++++----------------------
 src/main/java/com/zy/common/entity/Parameter.java           |   11 ++
 src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java |   10 +-
 3 files changed, 168 insertions(+), 119 deletions(-)

diff --git a/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
index e753cd9..19460b6 100644
--- a/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
@@ -7,7 +7,6 @@
 import com.core.common.Cools;
 import com.core.common.DateUtils;
 import com.core.exception.CoolException;
-import com.zy.asrs.domain.enums.WorkNoType;
 import com.zy.asrs.entity.*;
 import com.zy.asrs.mapper.BasCrnErrorMapper;
 import com.zy.asrs.mapper.WaitPakinMapper;
@@ -17,11 +16,11 @@
 import com.zy.asrs.utils.VersionUtils;
 import com.zy.common.model.LocTypeDto;
 import com.zy.common.model.MatDto;
+import com.zy.common.model.SearchLocParam;
 import com.zy.common.model.StartupDto;
 import com.zy.common.service.CommonService;
 import com.zy.common.utils.CollectionUtils;
 import com.zy.common.utils.HttpHandler;
-import com.zy.common.model.SearchLocParam;
 import com.zy.core.CrnThread;
 import com.zy.core.DevpThread;
 import com.zy.core.cache.MessageQueue;
@@ -1155,8 +1154,6 @@
                 StaProtocol staProtocol = devpThread.getStation().get(staNo);
                 if (staProtocol == null) {
                     continue;
-                } else {
-                    staProtocol = staProtocol.clone();
                 }
                 if (staProtocol.getWorkNo() != 0) {
                     reset = false;
@@ -1166,9 +1163,12 @@
             // 鑾峰彇led绾跨▼
             LedThread ledThread = (LedThread) SlaveConnection.get(SlaveType.Led, led.getDevpPlcId());
             // led鏄剧ず榛樿鍐呭
-            if (reset) {
+            if (reset && !ledThread.isLedMk()) {
+                ledThread.setLedMk(true);
                 if (!MessageQueue.offer(SlaveType.Led, led.getId(), new Task(2, new ArrayList<>()))) {
                     log.error("{}鍙稬ED鍛戒护涓嬪彂澶辫触锛侊紒锛乕ip锛歿}] [port锛歿}]", led.getId(), led.getIp(), led.getPort());
+                } else {
+
                 }
             }
         }
diff --git a/src/main/java/com/zy/common/entity/Parameter.java b/src/main/java/com/zy/common/entity/Parameter.java
index a5106b6..548158f 100644
--- a/src/main/java/com/zy/common/entity/Parameter.java
+++ b/src/main/java/com/zy/common/entity/Parameter.java
@@ -59,4 +59,15 @@
     public void setCodeSwitch(String codeSwitch) {
         this.codeSwitch = codeSwitch;
     }
+
+    private String ledDefaultMsg;
+
+    public String getLedDefaultMsg() {
+        return ledDefaultMsg;
+    }
+
+    public void setLedDefaultMsg(String ledDefaultMsg) {
+        this.ledDefaultMsg = ledDefaultMsg;
+    }
+
 }
diff --git a/src/main/java/com/zy/core/thread/LedThread.java b/src/main/java/com/zy/core/thread/LedThread.java
index d2a5d83..deb64fe 100644
--- a/src/main/java/com/zy/core/thread/LedThread.java
+++ b/src/main/java/com/zy/core/thread/LedThread.java
@@ -1,5 +1,8 @@
 package com.zy.core.thread;
 
+import com.alibaba.fastjson.JSON;
+import com.core.common.Cools;
+import com.zy.common.entity.Parameter;
 import com.zy.common.model.MatDto;
 import com.zy.core.Slave;
 import com.zy.core.ThreadHandler;
@@ -37,17 +40,14 @@
     TextCaptionBxArea area;
     DisplayStyleFactory.DisplayStyle[] styles = DisplayStyleFactory.getStyles().toArray(new DisplayStyleFactory.DisplayStyle[0]);
     private Set<Integer> workNos = new HashSet<>();
-//    private boolean resetStatus = false;    //  澶嶄綅鐘舵��
-
-    // 鏄剧ず鍣�
-    private StringBuffer stringBuffer = new StringBuffer();
+    private boolean ledMk = true;
+//    private boolean resetStatus = false;    // 澶嶄綅鐘舵��
 
     public LedThread(Slave slave) {
         this.slave = slave;
         try {
             Bx5GEnv.initial(3000);
             screen = new Bx5GScreenClient("my");
-            screen.turnOn();
         } catch (Exception e) {
             e.printStackTrace();
             log.info("led杩炴帴鏋勯�犲櫒閿欒 ===>> [id:{}] [ip:{}] [port:{}]", slave.getId(), slave.getIp(), slave.getPort());
@@ -57,7 +57,8 @@
     @Override
     @SuppressWarnings({"InfiniteLoopStatement", "unchecked"})
     public void run() {
-//        connect();
+        connect();
+        close();
         while (true) {
             try {
                 Task task = MessageQueue.poll(SlaveType.Led, slave.getId());
@@ -71,16 +72,124 @@
                         case 2:
                             reset();
                             break;
+                        // 璀﹀憡淇℃伅
+                        case 3:
+                            write(String.valueOf(task.getData()));
+                            break;
                         default:
                             break;
                     }
                 }
 
-                Thread.sleep(1000);
+                Thread.sleep(400);
             } catch (Exception e) {
                 e.printStackTrace();
             }
         }
+    }
+
+    private void write(List<LedCommand> list) 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();
+        for (LedCommand command : list) {
+            page.newLine(command.getTitle() +"锛�"+command.getWorkNo()+")");
+            page.newLine("婧愬簱浣嶏細"+command.getSourceLocNo());
+            page.newLine("鐩爣绔欙細"+command.getStaNo());
+            if (!command.isEmptyMk()) {
+                for (MatDto matDto : command.getMatDtos()) {
+                    page.newLine(matDto.getMaknx() + "銆愭暟閲�" + matDto.getCount() +"銆�");
+                }
+            }
+            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;
+        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;
+        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();
     }
 
     @Override
@@ -88,13 +197,14 @@
         boolean connRes = false;
         try {
             connRes = screen.connect(slave.getIp(),slave.getPort());
-        } catch (Exception ignore) {
-        }
-        if (connRes) {
-            log.info("led杩炴帴鎴愬姛 ===>> [id:{}] [ip:{}] [port:{}]", slave.getId(), slave.getIp(), slave.getPort());
-        } else {
-            log.error("led杩炴帴澶辫触锛侊紒锛� ===>> [id:{}] [ip:{}] [port:{}]", slave.getId(), 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());
+            }
+        } catch (Exception ignore) { }
         return connRes;
     }
 
@@ -103,79 +213,6 @@
         screen.disconnect();
     }
 
-
-    private void write(List<LedCommand> list) throws Bx5GException {
-//        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();
-//        for (LedCommand command : list) {
-//            page.newLine(command.getTitle() +"锛�"+command.getWorkNo()+")");
-//            page.newLine("婧愬簱浣嶏細"+command.getSourceLocNo());
-//            page.newLine("鐩爣绔欙細"+command.getStaNo());
-//            if (!command.isEmptyMk()) {
-//                for (MatDto matDto : command.getMatDtos()) {
-//                    page.newLine(matDto.getMaknx() + "銆愭暟閲�" + matDto.getCount() +"銆�");
-//                }
-//            }
-//            page.newLine("\n");
-//        }
-//
-//        // 璁剧疆瀛椾綋
-//        page.setFont(new Font("瀹嬩綋",Font.PLAIN,12));
-//        // 璁剧疆鏄剧ず鐗规妧涓哄揩閫熸墦鍑�
-//        page.setDisplayStyle(styles[6]);
-//        area.clearPages();
-//        area.addPage(page);
-//        pf.addArea(area);
-//        // 鏇存柊鑺傜洰
-//        screen.writeProgram(pf);
-//        resetStatus = false;
-
-        StringBuilder sb = new StringBuilder();
-        for (LedCommand command : list) {
-            sb.append(command.getTitle() +"锛�"+command.getWorkNo()+")").append("\n");
-            sb.append("婧愬簱浣嶏細"+command.getSourceLocNo()).append("\n");
-            sb.append("鐩爣绔欙細"+command.getStaNo()).append("\n");
-            if (!command.isEmptyMk()) {
-                for (MatDto matDto : command.getMatDtos()) {
-                    sb.append(matDto.getMaknx() + "銆愭暟閲�" + matDto.getCount() +"銆�").append("\n");
-                }
-            }
-            sb.append("\n");
-        }
-        stringBuffer.delete(0, stringBuffer.length());
-        stringBuffer.append(sb.toString());
-//        resetStatus = false;
-    }
-
-    private void reset() throws Bx5GException {
-//        if (!resetStatus) {
-//            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("骞垮痉涓壃鐗╂祦瑁呭鏈夐檺鍏徃");
-//            page.newLine("鑷姩鍖栫珛浣撲粨搴�");
-//            page.newLine("娴欐睙涓壃绔嬪簱鎶�鏈湁闄愬叕鍙�");
-//            // 璁剧疆瀛椾綋
-//            page.setFont(new Font("瀹嬩綋",Font.PLAIN,12));
-//            // 璁剧疆鏄剧ず鐗规妧涓哄揩閫熸墦鍑�
-//            page.setDisplayStyle(styles[6]);
-//            area.clearPages();
-//            area.addPage(page);
-//            pf.addArea(area);
-//            // 鏇存柊鑺傜洰
-//            screen.writeProgram(pf);
-
-            stringBuffer.delete(0, stringBuffer.length());
-//            resetStatus = true;
-//        }
-    }
 
 
     public static void main(String[] args) throws Exception {
@@ -187,34 +224,35 @@
             return;
         }
         screen.turnOn();
-        ProgramBxFile pf = new ProgramBxFile( 0, screen.getProfile());
-        pf.setFrameShow(false);
-        // 鍒嗗埆杈撳叆X锛孻锛寃idth锛宧eigth
-        TextCaptionBxArea area = new TextCaptionBxArea( 0,0,192,128,screen.getProfile());
-        // 鍒涘缓涓�涓暟鎹〉
-        // 绗竴琛屾暟鎹�
-        TextBxPage page = new TextBxPage("鍏ㄦ澘鍏ュ簱");
-        page.newLine("鐩爣搴撲綅锛�0100204");
-        // 绗簩琛屾暟鎹�
-        page.newLine("鎺ユ敹鍣� RX18 XH 6V 銆愭暟閲忥細2銆�");
-        page.newLine("涓帶 BM钃濈墮 鑻辨枃 6V 銆愭暟閲忥細1銆�");
-        page.newLine("绾挎潫 S2588-1-XX 鏃犲疄鐗┿�愭暟閲忥細5銆�");
-        page.newLine("鎺ユ敹鍣� RX18 XH 6V 銆愭暟閲忥細2銆�");
-        page.newLine("涓帶 BM钃濈墮 鑻辨枃 6V 銆愭暟閲忥細1銆�");
-        page.newLine("绾挎潫 S2588-1-XX 鏃犲疄鐗┿�愭暟閲忥細5銆�");
-        page.newLine("鎺ユ敹鍣� RX18 XH 6V 銆愭暟閲忥細2銆�");
-        page.newLine("涓帶 BM钃濈墮 鑻辨枃 6V 銆愭暟閲忥細1銆�");
-        page.newLine("绾挎潫 S2588-1-XX 鏃犲疄鐗┿�愭暟閲忥細5銆�");
-        // 璁剧疆瀛椾綋
-        page.setFont( new Font("瀹嬩綋",Font.PLAIN,12));
-        // 璁剧疆鏄剧ず鐗规妧涓哄揩閫熸墦鍑�
-        page.setDisplayStyle(styles[6]);
-        area.addPage(page);
-        pf.addArea( area );
-        // 鏇存柊鑺傜洰
-        screen.writeProgram(pf);
+
+
+        while (true) {
+            Thread.sleep(5000L);
+
+            ProgramBxFile pf = new ProgramBxFile( 0, screen.getProfile());
+            pf.setFrameShow(false);
+            // 鍒嗗埆杈撳叆X锛孻锛寃idth锛宧eigth
+            TextCaptionBxArea area = new TextCaptionBxArea(  0,0,192,128,screen.getProfile());
+
+            // 鍒涘缓涓�涓暟鎹〉
+            // 绗竴琛屾暟鎹�
+            TextBxPage page = new TextBxPage("鍑哄簱浠诲姟锛�303锛�");
+            page.newLine("婧愬簱浣嶏細0100204");
+            page.newLine("鐩爣绔欙細1000");
+            // 璁剧疆瀛椾綋
+            page.setFont( new Font("瀹嬩綋",Font.PLAIN,12));
+            // 璁剧疆鏄剧ず鐗规妧涓哄揩閫熸墦鍑�
+            page.setDisplayStyle(styles[6]);
+            area.clearPages();
+            area.addPage(page);
+            pf.addArea( area );
+
+            // 鏇存柊鑺傜洰
+            screen.writeProgram(pf);
+        }
+
         // 缁у紑涓庢帶鍒跺櫒涔嬮棿鐨勯摼鎺�
-        screen.disconnect();
+//        screen.disconnect();
     }
 
 

--
Gitblit v1.9.1