From ebd2f4397a92c6a5096de1b86d59154363344720 Mon Sep 17 00:00:00 2001 From: vincentlu <t1341870251@gmail.com> Date: 星期二, 13 五月 2025 08:48:15 +0800 Subject: [PATCH] # --- zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/AgvDataService.java | 68 ++++++++++++++++++++++++---------- 1 files changed, 48 insertions(+), 20 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 27a4948..c63c585 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 @@ -3,11 +3,15 @@ import com.alibaba.fastjson.JSON; 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.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.manager.entity.Agv; +import com.zy.acs.manager.core.domain.VehicleFaultDto; import com.zy.acs.manager.manager.entity.AgvDetail; import com.zy.acs.manager.manager.entity.Code; import com.zy.acs.manager.manager.service.*; @@ -59,15 +63,15 @@ IMessageBody msgBody = protocol.getMessageBody(); assert msgBody != null; - Agv agv = agvService.selectByUuid(protocol.getAgvNo()); - if (null == agv) { + Long agvId = agvService.getAgvId(protocol.getAgvNo()); + if (null == agvId) { log.warn("Agv [{}] 灏氭湭閴存潈 锛侊紒锛�", protocol.getAgvNo()); return; } - AgvDetail detail = agvDetailService.selectByAgvId(agv.getId()); + AgvDetail detail = agvDetailService.selectByAgvId(agvId); if (null == detail) { detail = new AgvDetail(); - detail.setAgvId(agv.getId()); + detail.setAgvId(agvId); if (!agvDetailService.save(detail)) { log.error("Agv [{}] 璇︽儏鏇存柊澶辫触 锛侊紒锛�", protocol.getAgvNo()); return; @@ -80,11 +84,12 @@ AGV_12_UP agv_12_up = (AGV_12_UP) msgBody; // unlock path - threadPoolRegulator.getInstance().execute(() -> { - mapService.unlockPath(protocol.getAgvNo(), agv_12_up.getQrCode()); - }); + mapService.unlockPath(protocol.getAgvNo(), agv_12_up.getQrCode()); +// threadPoolRegulator.getInstance().execute(() -> { +// +// }); // finish jam - threadPoolRegulator.getInstance().execute(() -> jamService.checkIfFinish(agv.getId(), agv_12_up.getQrCode())); + threadPoolRegulator.getInstance().execute(() -> jamService.checkIfFinish(agvId, agv_12_up.getQrCode())); // websocketService.agvInfoBroadcastOnPos(new WebsocketDto<AGV_12_UP>("agv", agv.getUuid(), agv_12_up)); this.sync(agv_12_up, detail); @@ -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,7 +152,9 @@ // 鏈夌爜瀹炴椂鏁版嵁鍖� private void sync(AGV_12_UP mesBody, AgvDetail detail) { - Code code = codeService.selectByData(mesBody.getQrCode()); + detail.setStatus(mesBody.getStatus()); + + Code code = codeService.getCacheByData(mesBody.getQrCode()); if (null != code) { detail.setCode(code.getId()); detail.setLastCode(null); @@ -143,8 +165,6 @@ } else { log.error("Agv [{}] 鏇存柊瀹氫綅鏁版嵁澶辫触 锛侊紒锛佷笂浼犳潯鐮侊細{}", agvService.getById(detail.getAgvId()).getUuid(), mesBody.getQrCode()); } - - detail.setStatus(mesBody.getStatus()); // 鍦伴潰鐮佸亸绉� detail.setCodeOffsert(JSON.toJSONString(Cools @@ -180,14 +200,22 @@ // 鏃犵爜瀹炴椂鏁版嵁鍖� private void sync(AGV_13_UP mesBody, AgvDetail detail) { - Code code = codeService.selectByData(mesBody.getQrCode()); + detail.setStatus(mesBody.getStatus()); + + Code code = codeService.getCacheByData(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()); } -- Gitblit v1.9.1