From bab376712985ae408f4886dc004be53e6eb46ff3 Mon Sep 17 00:00:00 2001
From: Junjie <xjj@123>
Date: 星期五, 14 三月 2025 14:56:48 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/core/dispatcher/ShuttleDispatchUtils.java |   33 ++++++++++++++++++++++++---------
 1 files changed, 24 insertions(+), 9 deletions(-)

diff --git a/src/main/java/com/zy/core/dispatcher/ShuttleDispatchUtils.java b/src/main/java/com/zy/core/dispatcher/ShuttleDispatchUtils.java
index 46e5a64..d8d6497 100644
--- a/src/main/java/com/zy/core/dispatcher/ShuttleDispatchUtils.java
+++ b/src/main/java/com/zy/core/dispatcher/ShuttleDispatchUtils.java
@@ -226,11 +226,21 @@
             return false;
         }
 
+        //鑾峰彇涓诲伐浣滄。淇℃伅
+        WrkMast mainWrkMast = wrkMastService.selectByWorkNo(wrkNo);
+
         //鍒ゆ柇鏄惁鏈夊叾浠栦换鍔℃鍦ㄤ娇鐢ㄧ┛姊溅
         WrkMast wrkMast2 = wrkMastService.selectShuttleWorking(shuttleNo);
         if (wrkMast2 != null) {//灏忚溅瀛樺湪鍏朵粬宸ヤ綔妗d换鍔★紝绛夊緟鎵ц瀹屾垚鍚庡啀鐢熸垚鏂扮殑浠诲姟
-            News.info("{}鍙峰皬杞︼紝瀛樺湪鍏朵粬宸ヤ綔妗d换鍔★紝绛夊緟鎵ц瀹屾垚鍐嶇敓鎴愭柊鐨勪换鍔�", shuttleNo);
-            return false;
+            if (mainWrkMast == null) {
+                News.info("{}鍙峰皬杞︼紝瀛樺湪鍏朵粬宸ヤ綔妗d换鍔★紝绛夊緟鎵ц瀹屾垚鍐嶇敓鎴愭柊鐨勪换鍔�", shuttleNo);
+                return false;
+            }else {
+                if (!mainWrkMast.getShuttleNo().equals(shuttleNo)) {
+                    News.info("{}鍙峰皬杞︼紝瀛樺湪鍏朵粬宸ヤ綔妗d换鍔★紝绛夊緟鎵ц瀹屾垚鍐嶇敓鎴愭柊鐨勪换鍔�", shuttleNo);
+                    return false;
+                }
+            }
         }
 
         Integer sourceStaNo = null;//灏忚溅鎹㈠眰婧愮珯鐐�
@@ -244,12 +254,18 @@
                 return false;//娌℃湁鍙敤涓旂┖闂茬殑杈撻�佺珯鐐�
             }
             sourceStaNo = liftSta.getStaNo();//婧愮珯鐐�
-            //鎻愬崌鏈哄彿*100+鐩爣妤煎眰=鐩爣绔欑偣
-            staNo = liftSta.getLiftNo() * 100 + Utils.getLev(locNo);//鐩爣绔�
+
+            ForkLiftStaProtocol targetLiftSta = ForkLiftUtils.getLiftStaByLev(liftSta.getLiftNo(), Utils.getLev(locNo));
+            if (targetLiftSta == null) {
+                News.info("{}鍙峰皬杞︼紝{}鐩爣搴撲綅锛屾病鏈夌洰鏍囩珯鐐�", shuttleNo, locNo);
+                return false;//娌℃湁鎵惧埌鐩爣绔欑偣
+            }
+            //鐩爣绔欑偣
+            staNo = targetLiftSta.getStaNo();//鐩爣绔�
         }
 
         // 鑾峰彇宸ヤ綔鍙�
-        int workNo = commonService.getWorkNo(0);
+        int workNo = commonService.getWorkNo(WrkIoType.SHUTTLE_MOVE.id);
         // 淇濆瓨宸ヤ綔妗�
         WrkMast wrkMast = new WrkMast();
         wrkMast.setWrkNo(workNo);
@@ -271,10 +287,9 @@
         }
 
         //缁欏伐浣滄。缁戝畾灏忚溅鍙�
-        WrkMast wrkMast1 = wrkMastService.selectByWorkNo(wrkNo);
-        if (wrkMast1 != null) {
-            wrkMast1.setShuttleNo(shuttleNo);
-            wrkMastService.updateById(wrkMast1);
+        if (mainWrkMast != null) {
+            mainWrkMast.setShuttleNo(shuttleNo);
+            wrkMastService.updateById(mainWrkMast);
         }
 
         return true;

--
Gitblit v1.9.1