From ee5046d151a858339aa137790bc830efe7f55980 Mon Sep 17 00:00:00 2001
From: zhang <zc857179121@qq.com>
Date: 星期三, 18 六月 2025 15:13:14 +0800
Subject: [PATCH] 1

---
 zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/AgvServiceImpl.java |   46 +++++++++++++++++++++++++++++++++++-----------
 1 files changed, 35 insertions(+), 11 deletions(-)

diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/AgvServiceImpl.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/AgvServiceImpl.java
index ef2bd79..e153887 100644
--- a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/AgvServiceImpl.java
+++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/AgvServiceImpl.java
@@ -80,7 +80,12 @@
     @Override
     public Long getAgvId(String uuid) {
         if (Cools.isEmpty(uuid)) {
-            return null;
+            Agv agv = this.selectByUuid(uuid);
+            if (agv != null) {
+                AGV_ID_MAP.put(uuid, agv.getId());
+            } else {
+                return null;
+            }
         }
         return AGV_ID_MAP.get(uuid);
     }
@@ -88,7 +93,12 @@
     @Override
     public String getAgvNo(Long agvId) {
         if (Cools.isEmpty(agvId)) {
-            return null;
+            Agv agv = this.getById(agvId);
+            if (agv != null) {
+                AGV_NO_MAP.put(agvId, agv.getUuid());
+            } else {
+                return null;
+            }
         }
         return AGV_NO_MAP.get(agvId);
     }
@@ -96,22 +106,29 @@
 
     @Override
     public Boolean judgeEnable(Long agvId) {
-        return this.judgeEnable(agvId, false);
+        return this.judgeEnable(agvId, false,false);
     }
 
+    /**
+     * 鍒ゆ柇AGV鏄惁鍙敤
+     * @param agvId
+     * @param isLowBattery 浣庣數閲忓垽鏂�
+     * @param force 鏄惁寮哄埗鎿嶄綔
+     * @return
+     */
     @Override
-    public Boolean judgeEnable(Long agvId, Boolean isLowBattery) {
+    public Boolean judgeEnable(Long agvId, Boolean isLowBattery, Boolean force) {
         String agvNo = this.getAgvNo(agvId);
         AgvModel agvModel = agvModelService.getByAgvId(agvId);
         if (0 < segmentService.count(new LambdaQueryWrapper<Segment>()
                         .eq(Segment::getAgvId, agvId)
                         .eq(Segment::getState, SegmentStateType.RUNNING.toString())
         )) {
-            log.warn("[{}]鍙稟gv姝e湪蹇欑 - segment......", agvNo);
+//            log.warn("[{}]鍙稟gv姝e湪蹇欑 - segment......", agvNo);
             return false;
         }
         if (!this.judgeOnline(agvId)) {
-            log.warn("[{}]鍙稟gv涓嶆槸鍦ㄧ嚎鐘舵��......", agvNo);
+//            log.warn("[{}]鍙稟gv涓嶆槸鍦ㄧ嚎鐘舵��......", agvNo);
             return false;
         }
         AgvDetail agvDetail = agvDetailService.selectMajorByAgvId(agvId);
@@ -127,8 +144,14 @@
             return false;
         }
         if (agvDetail.getAgvStatus().equals(AgvStatusType.CHARGE)) {
-            if (agvDetail.getVol() < agvModel.getQuaBattery()) {
-                return false;
+            if (force){
+                if (agvDetail.getVol() < agvModel.getLowBattery()) {
+                    return false;
+                }
+            }else {
+                if (agvDetail.getVol() < agvModel.getQuaBattery()) {
+                    return false;
+                }
             }
         }
         if (!agvDetail.getAgvStatus().equals(AgvStatusType.CHARGE)) {
@@ -152,6 +175,8 @@
 
         return true;
     }
+
+
 
     @Override
     public Boolean judgeOnline(Long agvId) {
@@ -210,9 +235,8 @@
 
     @Override
     public int getBackpackRemainingCapacity(Long agvId) {
-        int usedSlots = 0;
-        Integer backpackCache = CoreCache.AGV_BACKPACK_CACHE.get(agvId);
-        if (null != backpackCache) {
+        Integer usedSlots = CoreCache.AGV_BACKPACK_USED_CACHE.get(agvId);
+        if (null == usedSlots) {
             usedSlots = taskService.findTransportTasksCountByAgv(agvId);
         }
 

--
Gitblit v1.9.1