From 4116d1a906514bf1920e4450fc6868191fe93bac Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@163.com>
Date: 星期一, 18 十一月 2024 11:06:51 +0800
Subject: [PATCH] #

---
 zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/AgvDataService.java |   37 +++++++++++++++++++++----------------
 1 files changed, 21 insertions(+), 16 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 7725211..f3c07bb 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,13 +1,12 @@
 package com.zy.acs.manager.core.service;
 
 import com.alibaba.fastjson.JSON;
-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.utils.GsonUtils;
 import com.zy.acs.common.utils.RedisSupport;
 import com.zy.acs.framework.common.Cools;
-import com.zy.acs.manager.common.domain.WebsocketDto;
 import com.zy.acs.manager.core.domain.BackpackDto;
 import com.zy.acs.manager.manager.entity.Agv;
 import com.zy.acs.manager.manager.entity.AgvDetail;
@@ -83,16 +82,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));
             }
@@ -100,9 +97,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));
             }
@@ -136,6 +133,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());
@@ -147,8 +146,6 @@
         } else {
             log.error("Agv [{}] 鏇存柊瀹氫綅鏁版嵁澶辫触 锛侊紒锛佷笂浼犳潯鐮侊細{}", agvService.getById(detail.getAgvId()).getUuid(), mesBody.getQrCode());
         }
-
-        detail.setStatus(mesBody.getStatus());
 
         // 鍦伴潰鐮佸亸绉�
         detail.setCodeOffsert(JSON.toJSONString(Cools
@@ -184,14 +181,22 @@
 
     // 鏃犵爜瀹炴椂鏁版嵁鍖�
     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());
         }

--
Gitblit v1.9.1