From 8e7c727183f83bb734238e97b64a11ba5588c9c1 Mon Sep 17 00:00:00 2001 From: zjj <3272660260@qq.com> Date: 星期五, 05 一月 2024 17:45:33 +0800 Subject: [PATCH] # --- src/main/java/com/zy/core/thread/LedThread.java | 121 +++++++++++++++++++++++++--------------- 1 files changed, 76 insertions(+), 45 deletions(-) diff --git a/src/main/java/com/zy/core/thread/LedThread.java b/src/main/java/com/zy/core/thread/LedThread.java index cdc583a..c272ffb 100644 --- a/src/main/java/com/zy/core/thread/LedThread.java +++ b/src/main/java/com/zy/core/thread/LedThread.java @@ -4,6 +4,7 @@ import com.core.common.Cools; import com.zy.common.entity.Parameter; import com.zy.common.model.MatDto; +import com.zy.common.utils.News; import com.zy.core.Slave; import com.zy.core.ThreadHandler; import com.zy.core.cache.MessageQueue; @@ -43,21 +44,27 @@ private boolean ledMk = false; private boolean resetStatus = false; // 澶嶄綅鐘舵�� + // 鏄剧ず鍣� + private StringBuffer stringBuffer = new StringBuffer(); + private List<LedCommand> commandList; + + private StringBuffer errorMsg = new StringBuffer(); + public LedThread(Slave slave) { this.slave = slave; try { - Bx5GEnv.initial(3000); - screen = new Bx5GScreenClient("my"); +// Bx5GEnv.initial(3000); +// screen = new Bx5GScreenClient("my"); } catch (Exception e) { e.printStackTrace(); - log.info("led杩炴帴鏋勯�犲櫒閿欒 ===>> [id:{}] [ip:{}] [port:{}]", slave.getId(), slave.getIp(), slave.getPort()); + News.info("led杩炴帴鏋勯�犲櫒閿欒 ===>> [id:{}] [ip:{}] [port:{}]", slave.getId(), slave.getIp(), slave.getPort()); } } @Override @SuppressWarnings({"InfiniteLoopStatement", "unchecked"}) public void run() { - connect(); +// connect(); close(); while (true) { try { @@ -72,6 +79,22 @@ case 2: reset(); break; + // 鍐欐暟鎹� 娑叉櫠 + case 3: + error((String)task.getData()); + break; + // 澶嶄綅 娑叉櫠 + case 4: + reset7(); + break; + case 5: + error((String) task.getData()); + break; + case 6: + errorReset(); + break; + case 7: + write7((List<LedCommand>) task.getData()); default: break; } @@ -96,7 +119,7 @@ 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()) { @@ -123,7 +146,7 @@ area.addPage(page); pf.addArea(area); if (pf.validate() != null) { - log.info("pf out of range"); + News.info("pf out of range"); } else { // 鏇存柊鑺傜洰 screen.writeProgram(pf); @@ -160,7 +183,7 @@ // page.newLine("鑷姩鍖栫珛浣撲粨搴�"); // page.newLine("瑗挎牸杩堣偂浠芥湁闄愬叕鍙�"); // } - page.newLine(""); + page.newLine("鍔涙簮鏅鸿兘浠撳偍"); // 璁剧疆瀛椾綋 page.setFont(new Font("瀹嬩綋",Font.PLAIN,13)); @@ -173,7 +196,7 @@ pf.addArea(area); // 鏇存柊鑺傜洰 if (pf.validate() != null) { - log.info("pf out of range"); + News.info("pf out of range"); } else { // 鏇存柊鑺傜洰 screen.writeProgram(pf); @@ -181,9 +204,50 @@ } close(); } + private void write7(List<LedCommand> list) { + + commandList = list; + + StringBuilder sb = new StringBuilder(); + for (LedCommand command : list) { + sb.append(command.getTitle()).append("锛�").append(command.getWorkNo()).append(")").append("\n"); + sb.append("婧愬簱浣嶏細").append(command.getSourceLocNo()).append("\n"); + sb.append("鐩爣绔欙細").append(command.getStaNo()).append("\n"); + if (!command.isEmptyMk()) { + for (MatDto matDto : command.getMatDtos()) { + sb.append("鐗╂枡缂栫爜锛�").append(matDto.getMatNo()).append("\n"); + sb.append("鏁伴噺锛�").append(matDto.getCount()).append("\n"); + } + } + sb.append("\n"); + } + stringBuffer.delete(0, stringBuffer.length()); + stringBuffer.append(sb.toString()); + + errorReset(); + } + + + private void reset7() { + commandList = null; + + stringBuffer.delete(0, stringBuffer.length()); + } + + + private void error(String msg) { + errorMsg.delete(0, errorMsg.length()); + errorMsg.append(msg); + } + + public void errorReset() { + this.errorMsg.delete(0, errorMsg.length()); + } @Override public boolean connect() { + String methodName = Thread.currentThread().getStackTrace()[1].getMethodName(); + boolean connRes = false; try { connRes = screen.connect(slave.getIp(),slave.getPort()); @@ -191,19 +255,17 @@ } catch (Exception ignore) { } if (connRes) { - log.info("led杩炴帴鎴愬姛 ===>> [id:{}] [ip:{}] [port:{}]", slave.getId(), slave.getIp(), slave.getPort()); + News.info(methodName + ":led杩炴帴鎴愬姛 ===>> [id:{}] [ip:{}] [port:{}]", slave.getId(), slave.getIp(), slave.getPort()); } else { - log.error("led杩炴帴澶辫触锛侊紒锛� ===>> [id:{}] [ip:{}] [port:{}]", slave.getId(), slave.getIp(), slave.getPort()); + News.error(methodName + ":led杩炴帴澶辫触锛侊紒锛� ===>> [id:{}] [ip:{}] [port:{}]", slave.getId(), slave.getIp(), slave.getPort()); } return connRes; } @Override public void close() { - screen.disconnect(); + } - - public static void main(String[] args) throws Exception { String strQty = "1234"; @@ -250,7 +312,7 @@ // 鏇存柊鑺傜洰 if (pf.validate() != null) { System.out.println("pf out of range"); - log.info("pf out of range"); + News.info("pf out of range"); } else { // 鏇存柊鑺傜洰 screen.writeProgram(pf); @@ -260,37 +322,6 @@ // 缁у紑涓庢帶鍒跺櫒涔嬮棿鐨勯摼鎺� // screen.disconnect(); } - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - public static void main1(String[] args) throws Exception { Bx5GEnv.initial(3000); -- Gitblit v1.9.1