From 289c3501e04d2781c4b1592c5430a1c648307749 Mon Sep 17 00:00:00 2001
From: vincentlu <t1341870251@gmail.com>
Date: 星期一, 09 三月 2026 14:41:20 +0800
Subject: [PATCH] #

---
 zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/MainService.java |   18 +++++++++++++++---
 1 files changed, 15 insertions(+), 3 deletions(-)

diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/MainService.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/MainService.java
index d58843f..d4acffc 100644
--- a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/MainService.java
+++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/MainService.java
@@ -895,8 +895,9 @@
      */
     @Transactional
     public synchronized List<PathDto> generateAction(Long agvId, List<Segment> segmentList, List<String> pathList, Date algoStartTime) {
+        List<PathDto> pathTrace = new ArrayList<>();
         try {
-            if (Cools.isEmpty(agvId, segmentList)) { return; }
+            if (Cools.isEmpty(agvId, segmentList)) { return pathTrace; }
             Date now = new Date();
             long actionPrepareSts = ActionStsType.PREPARE.val();
 //            JSONObject storeDirection = configService.getVal("storeDirection", JSONObject.class);
@@ -925,6 +926,7 @@
             if (!lastCode.getData().equals(pathList.get(0))) {
                 throw new CoolException("AGV[" + agvNo + "]瀹氫綅鍋忕Щ...");
             }
+            pathTrace.add(new PathDto(lastCode.getData(), lastDirection, false));
 
             boolean first = true;
             for (Segment segment : segmentList) {
@@ -990,6 +992,7 @@
                                         now    // 宸ヤ綔鏃堕棿
                                 ));
                                 lastDirection = nextLaneDir;
+                                PathDto.markTurn(pathTrace, lastDirection);
                             }
 
                             if (nextDirection.equals(oppNextLaneDir)) {
@@ -1058,6 +1061,7 @@
                                         ));
 
                                         lastDirection = nextDirection;
+                                        PathDto.markTurn(pathTrace, lastDirection);
                                     }
                                 }
                             }
@@ -1083,6 +1087,7 @@
                             ));
 
                             lastDirection = nextDirection;
+                            PathDto.markTurn(pathTrace, lastDirection);
                         }
 
                         // run
@@ -1105,6 +1110,7 @@
                         ));
 
                         lastCode = nextCode;
+                        pathTrace.add(new PathDto(lastCode.getData(), lastDirection, false));
 
                     }
 
@@ -1150,6 +1156,7 @@
                         ));
 
                         lastDirection = firstTurnDir;
+                        PathDto.markTurn(pathTrace, lastDirection);
 
                     }
                     first = false;
@@ -1277,6 +1284,7 @@
                                     now    // 宸ヤ綔鏃堕棿
                             ));
                             lastDirection = oriStaWorkDirection;
+                            PathDto.markTurn(pathTrace, lastDirection);
                         }
                         // 璁$畻璐у弶宸ヤ綔鏂瑰悜
                         actuatorDirectionType = ActuatorDirectionType.fromVal(oriSta.getActDir());
@@ -1342,6 +1350,7 @@
                                     now    // 宸ヤ綔鏃堕棿
                             ));
                             lastDirection = destStaWorkDirection;
+                            PathDto.markTurn(pathTrace, lastDirection);
                         }
                         // 鑳岀瘬鍙栬揣
                         if (backupAction) {
@@ -1402,6 +1411,7 @@
                                     now    // 宸ヤ綔鏃堕棿
                             ));
                             lastDirection = chargeDirection;
+                            PathDto.markTurn(pathTrace, lastDirection);
                         }
 
                         // charge
@@ -1556,6 +1566,7 @@
             }
 
             log.info("{}鍙稟gv鍔ㄤ綔缁勮瀹屾垚锛屾寚浠ゆ暟閲忥細{}", agvNo, newActionList.size());
+            return pathTrace;
         } catch (Exception e) {
             log.error("mainService.generateAction", e);
             TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
@@ -1611,8 +1622,9 @@
                     task.setUpdateTime(now);
                     if (!taskService.updateById(task)) {
                         throw new BusinessException(task.getSeqNum() + "浠诲姟鏇存柊澶辫触");
-                    }
-                }
+    }
+
+}
             }
 
             AgvAction agvAction = new AgvAction(agvNo, actionGroupId);

--
Gitblit v1.9.1