From 190bec9d5950a76e62b3bb1663f979a644695279 Mon Sep 17 00:00:00 2001
From: zwl <1051256694@qq.com>
Date: 星期六, 09 八月 2025 15:22:27 +0800
Subject: [PATCH] 完善wcs'主控图地图显示
---
src/main/java/com/zy/core/thread/LedThread.java | 114 ++++++++++++++++++++++++++-------------------------------
1 files changed, 52 insertions(+), 62 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..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;
@@ -42,23 +50,15 @@
private Set<Integer> workNos = new HashSet<>();
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,6 +71,10 @@
// 澶嶄綅
case 2:
reset();
+// this.ledMk = false;
+ break;
+ case 5:
+ error((String) task.getData());
break;
default:
break;
@@ -96,7 +100,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()) {
@@ -111,6 +115,12 @@
}
}
page.newLine("\n");
+
+ //鏇存柊鎸囦护鐘舵��
+ CommandInfoService commandInfoService = SpringUtils.getBean(CommandInfoService.class);
+ CommandInfo commandInfo = command.getCommandInfo();
+ commandInfo.setCommandStatus(CommandStatusType.COMPLETE.id);
+ commandInfoService.updateById(commandInfo);
}
// 璁剧疆瀛椾綋
@@ -133,70 +143,47 @@
}
private void reset() throws Bx5GException {
- if (!connect()) {
- return;
- }
-// if (resetStatus) {
-// 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();
-
-// 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.newLine("");
-
- // 璁剧疆瀛椾綋
- page.setFont(new Font("瀹嬩綋",Font.PLAIN,13));
- // 璁剧疆鏂囨湰棰滆壊
- 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 = true;
- }
- close();
+ 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) {
+ InetAddress address = InetAddress.getByName(slave.getIp());
+ if (!address.isReachable(2000)) {
+ log.warn("璁惧涓嶅彲杈撅紝璺宠繃杩炴帴: {}", slave.getIp());
+ return false; // 鎻愬墠杩斿洖锛岄伩鍏嶆棤鎰忎箟杩炴帴灏濊瘯
+ }
+ } 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() {
@@ -444,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