From 7c4d3d957c431aad12f90511770e2fe429bcd380 Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@163.com>
Date: 星期二, 24 十二月 2024 16:38:25 +0800
Subject: [PATCH] #
---
zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/AgvDataService.java | 84 +++++++++++++++++++++++++++++++++---------
1 files changed, 66 insertions(+), 18 deletions(-)
diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/AgvDataService.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/AgvDataService.java
index b98d2ab..d6805f7 100644
--- a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/AgvDataService.java
+++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/AgvDataService.java
@@ -1,12 +1,17 @@
package com.zy.acs.manager.core.service;
import com.alibaba.fastjson.JSON;
-import com.zy.acs.framework.common.Cools;
-import com.zy.acs.common.constant.RedisConstant;
import com.zy.acs.common.domain.AgvProtocol;
import com.zy.acs.common.domain.protocol.*;
+import com.zy.acs.common.enums.AgvStatusType;
+import com.zy.acs.common.enums.error.AgvErrorType;
+import com.zy.acs.common.utils.GsonUtils;
import com.zy.acs.common.utils.RedisSupport;
-import com.zy.acs.manager.common.domain.WebsocketDto;
+import com.zy.acs.framework.common.Cools;
+import com.zy.acs.framework.common.DateUtils;
+import com.zy.acs.manager.core.constant.MapDataConstant;
+import com.zy.acs.manager.core.domain.BackpackDto;
+import com.zy.acs.manager.core.domain.VehicleFaultDto;
import com.zy.acs.manager.manager.entity.Agv;
import com.zy.acs.manager.manager.entity.AgvDetail;
import com.zy.acs.manager.manager.entity.Code;
@@ -16,7 +21,9 @@
import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Service;
+import java.util.ArrayList;
import java.util.Date;
+import java.util.List;
/**
* Created by vincent on 2023/6/16
@@ -79,16 +86,14 @@
// unlock path
threadPoolRegulator.getInstance().execute(() -> {
-// avoidWaveCalculator.syncWaveBySingleVeh(protocol.getAgvNo(), agv_12_up.getQrCode());
mapService.unlockPath(protocol.getAgvNo(), agv_12_up.getQrCode());
-// mapService.unlockPath(protocol.getAgvNo(), Utils.singletonList(agv_12_up.getQrCode()));
});
// finish jam
threadPoolRegulator.getInstance().execute(() -> jamService.checkIfFinish(agv.getId(), agv_12_up.getQrCode()));
- websocketService.agvInfoBroadcastOnPos(new WebsocketDto<AGV_12_UP>("agv", agv.getUuid(), agv_12_up));
+// websocketService.agvInfoBroadcastOnPos(new WebsocketDto<AGV_12_UP>("agv", agv.getUuid(), agv_12_up));
this.sync(agv_12_up, detail);
- redis.setObject(RedisConstant.DIGITAL_AGV_FLAG, agv.getUuid(), agv_12_up);
+// redis.setObject(RedisConstant.DIGITAL_AGV_FLAG, agv.getUuid(), agv_12_up);
if (PRINT_LOG) {
log.info("Agv [{}] 鏈夌爜瀹炴椂鏁版嵁鍖� ===>> {}", protocol.getAgvNo(), JSON.toJSONString(agv_12_up));
}
@@ -96,9 +101,9 @@
// 鏃犵爜瀹炴椂鏁版嵁鍖�
if (msgBody instanceof AGV_13_UP) {
AGV_13_UP agv_13_up = (AGV_13_UP) msgBody;
- websocketService.agvInfoBroadcastWithOutPos(new WebsocketDto<AGV_13_UP>("agv", agv.getUuid(), agv_13_up));
+// websocketService.agvInfoBroadcastWithOutPos(new WebsocketDto<AGV_13_UP>("agv", agv.getUuid(), agv_13_up));
this.sync(agv_13_up, detail);
-// redis.setObject(RedisConstant.DIGITAL_AGV_FLAG, agv.getUuid(), agv_13_up); // todo
+// redis.setObject(RedisConstant.DIGITAL_AGV_FLAG, agv.getUuid(), agv_13_up);
if (PRINT_LOG) {
log.info("Agv [{}] 鏃犵爜瀹炴椂鏁版嵁鍖� ===>> {}", protocol.getAgvNo(), JSON.toJSONString(agv_13_up));
}
@@ -120,10 +125,25 @@
// 鏁呴殰鏁版嵁鍖�
if (msgBody instanceof AGV_04_UP) {
AGV_04_UP agv_04_up = (AGV_04_UP) msgBody;
+ AgvErrorType errorType = AgvErrorType.query(agv_04_up.getHexFaultId());
log.info("Agv [{}] 鏁呴殰鏁版嵁鍖� ===>> {}", protocol.getAgvNo(), JSON.toJSONString(agv_04_up));
-// faultProcessor.execute(new VehicleFaultDto());
+
+ // save
+ faultProcessor.execute(new VehicleFaultDto<>(protocol.getAgvNo(), protocol.getTimestamp(), agv_04_up));
+
+ // detail
+ String errorMSg = errorType != null ? errorType.getMsg() : agv_04_up.getHexFaultId();
+ detail.setError(errorMSg);
+ detail.setErrorTime(new Date());
}
+ // 鏁呴殰澶嶄綅
+ if (!Cools.isEmpty(detail.realError())) {
+ assert detail.getErrorTime() != null;
+ if (DateUtils.diffToSeconds(detail.getErrorTime(), new Date()) > 20) {
+ detail.setError(MapDataConstant.EMPTY_OF_ERROR);
+ }
+ }
if (!agvDetailService.updateById(detail)) {
log.error("Agv [{}] 璇︽儏鏇存柊澶辫触 锛侊紒锛�", protocol.getAgvNo());
}
@@ -132,6 +152,8 @@
// 鏈夌爜瀹炴椂鏁版嵁鍖�
private void sync(AGV_12_UP mesBody, AgvDetail detail) {
+ detail.setStatus(mesBody.getStatus());
+
Code code = codeService.selectByData(mesBody.getQrCode());
if (null != code) {
detail.setCode(code.getId());
@@ -143,8 +165,6 @@
} else {
log.error("Agv [{}] 鏇存柊瀹氫綅鏁版嵁澶辫触 锛侊紒锛佷笂浼犳潯鐮侊細{}", agvService.getById(detail.getAgvId()).getUuid(), mesBody.getQrCode());
}
-
- detail.setStatus(mesBody.getStatus());
// 鍦伴潰鐮佸亸绉�
detail.setCodeOffsert(JSON.toJSONString(Cools
@@ -166,18 +186,36 @@
detail.setSensorSts((long) mesBody.getSensorStatusFlags());
+ List<BackpackDto> backpackDtoList = new ArrayList<>();
+ backpackDtoList.add(new BackpackDto(1, mesBody.isTempLoc1()));
+ backpackDtoList.add(new BackpackDto(2, mesBody.isTempLoc2()));
+ backpackDtoList.add(new BackpackDto(3, mesBody.isTempLoc3()));
+ backpackDtoList.add(new BackpackDto(4, mesBody.isTempLoc4()));
+ backpackDtoList.add(new BackpackDto(5, mesBody.isTempLoc5()));
+ backpackDtoList.add(new BackpackDto(6, mesBody.isTempLoc6()));
+ backpackDtoList.add(new BackpackDto(7, mesBody.isTempLoc7()));
+ detail.setBackpack(GsonUtils.toJson(backpackDtoList));
+
}
// 鏃犵爜瀹炴椂鏁版嵁鍖�
private void sync(AGV_13_UP mesBody, AgvDetail detail) {
+ detail.setStatus(mesBody.getStatus());
+
Code code = codeService.selectByData(mesBody.getQrCode());
if (null != code) {
- detail.setCode(null);
- detail.setLastCode(code.getId());
- detail.setPos(0);
-// if (!agvDetailService.updateUnPosCode(detail.getId(), code.getId())) {
-// log.error("Agv [{}] 鏇存柊瀹氫綅鏁版嵁澶辫触 锛侊紒锛�", agvService.getById(detail.getAgvId()).getUuid());
-// }
+
+ if (!detail.getAgvStatus().equals(AgvStatusType.CHARGE)) {
+ detail.setCode(null);
+ detail.setLastCode(code.getId());
+ detail.setPos(0);
+ } else {
+ detail.setCode(code.getId());
+ detail.setLastCode(null);
+ detail.setPos(1);
+ }
+
+
} else {
log.error("Agv [{}] 鏇存柊瀹氫綅鏁版嵁澶辫触 锛侊紒锛佷笂浼犳潯鐮侊細{}", agvService.getById(detail.getAgvId()).getUuid(), mesBody.getQrCode());
}
@@ -194,6 +232,16 @@
detail.setSensorSts((long) mesBody.getSensorStatusFlags());
+ List<BackpackDto> backpackDtoList = new ArrayList<>();
+ backpackDtoList.add(new BackpackDto(1, mesBody.isTempLoc1()));
+ backpackDtoList.add(new BackpackDto(2, mesBody.isTempLoc2()));
+ backpackDtoList.add(new BackpackDto(3, mesBody.isTempLoc3()));
+ backpackDtoList.add(new BackpackDto(4, mesBody.isTempLoc4()));
+ backpackDtoList.add(new BackpackDto(5, mesBody.isTempLoc5()));
+ backpackDtoList.add(new BackpackDto(6, mesBody.isTempLoc6()));
+ backpackDtoList.add(new BackpackDto(7, mesBody.isTempLoc7()));
+ detail.setBackpack(GsonUtils.toJson(backpackDtoList));
+
}
// 蹇冭烦鍖�
--
Gitblit v1.9.1