From 1a56f6f4a0c2b8fc61bfde8bd3418a9731b87647 Mon Sep 17 00:00:00 2001 From: 野心家 <1051256694@qq.com> Date: 星期五, 25 十月 2024 12:38:43 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/tzhtwcs' into tzhtwcs --- src/main/java/com/zy/core/thread/LedThread.java | 133 ++++++++++++++++++++++++++++++++++++++----- 1 files changed, 116 insertions(+), 17 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..2e77421 100644 --- a/src/main/java/com/zy/core/thread/LedThread.java +++ b/src/main/java/com/zy/core/thread/LedThread.java @@ -43,11 +43,17 @@ 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()); @@ -57,8 +63,8 @@ @Override @SuppressWarnings({"InfiniteLoopStatement", "unchecked"}) public void run() { - connect(); - close(); +// connect(); +// close(); while (true) { try { Task task = MessageQueue.poll(SlaveType.Led, slave.getId()); @@ -68,9 +74,27 @@ case 1: write((List<LedCommand>)task.getData()); break; + // 鍐欐暟鎹� + case 9: + write9((List<LedCommand>)task.getData()); + break; // 澶嶄綅 case 2: reset(); + break; + // 鍐欐暟鎹� 娑叉櫠 + case 3: + write7((List<LedCommand>)task.getData()); + break; + // 澶嶄綅 娑叉櫠 + case 4: + reset7(); + break; + case 5: + error((String) task.getData()); + break; + case 6: + errorReset(); break; default: break; @@ -96,7 +120,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()) { @@ -110,6 +134,40 @@ // page.newLine(matDto.getMaknx() + "銆愭暟閲�" + matDto.getCount() +"銆�"); } } + page.newLine("\n"); + } + + // 璁剧疆瀛椾綋 + page.setFont(new Font("瀹嬩綋",Font.PLAIN,12)); + // 璁剧疆鏂囨湰棰滆壊 + page.setForeground(Color.red); + // 璁剧疆鏄剧ず鐗规妧涓哄揩閫熸墦鍑� + page.setDisplayStyle(styles[6]); + area.clearPages(); + area.addPage(page); + pf.addArea(area); + if (pf.validate() != null) { + log.info("pf out of range"); + } else { + // 鏇存柊鑺傜洰 + screen.writeProgram(pf); +// resetStatus = false; + } + close(); + } + + private void write9(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,96,48, screen.getProfile()); + // 鍒涘缓涓�涓暟鎹〉 + TextBxPage page = new TextBxPage(); + for (LedCommand command : list) { + page.newLine(command.getTitle()); page.newLine("\n"); } @@ -160,7 +218,7 @@ // page.newLine("鑷姩鍖栫珛浣撲粨搴�"); // page.newLine("瑗挎牸杩堣偂浠芥湁闄愬叕鍙�"); // } - page.newLine(""); + page.newLine("鍔涙簮鏅鸿兘浠撳偍"); // 璁剧疆瀛椾綋 page.setFont(new Font("瀹嬩綋",Font.PLAIN,13)); @@ -181,26 +239,67 @@ } 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.getMatnr()).append("\n"); + sb.append("鍚嶇О锛�").append(matDto.getMaknx()).append("\n"); + sb.append("鏁伴噺锛�").append(matDto.getCount()).append("\n"); + sb.append("瑙勬牸锛�").append(matDto.getSpecs()).append("\n"); + sb.append("鍥惧彿锛�").append(matDto.getModel()).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() { boolean connRes = false; - try { - connRes = screen.connect(slave.getIp(),slave.getPort()); - screen.turnOn(); - } 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()); - } +// try { +// connRes = screen.connect(slave.getIp(),slave.getPort()); +// screen.turnOn(); +// } 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()); +// } return connRes; } @Override public void close() { - screen.disconnect(); +// screen.disconnect(); } -- Gitblit v1.9.1