From 0a6532305b842185c85afd4e8c670f64700f2a6d Mon Sep 17 00:00:00 2001
From: zjj <3272660260@qq.com>
Date: 星期三, 28 八月 2024 17:03:54 +0800
Subject: [PATCH] #

---
 zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/kernel/KernelService.java |  171 +++++++++++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 153 insertions(+), 18 deletions(-)

diff --git a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/kernel/KernelService.java b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/kernel/KernelService.java
index 99337f9..f5e1c54 100644
--- a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/kernel/KernelService.java
+++ b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/kernel/KernelService.java
@@ -5,6 +5,7 @@
 import com.zy.asrs.wcs.core.model.enums.MotionCtgType;
 import com.zy.asrs.wcs.core.entity.Motion;
 import com.zy.asrs.wcs.core.service.MotionService;
+import com.zy.asrs.wcs.core.utils.LiftDispatcher;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 
@@ -19,7 +20,8 @@
 
     @Autowired
     private MotionService motionService;
-
+    @Autowired
+    private LiftDispatcher liftDispatcher;
 
     // agv -----------------------------------------------------------------------------
     @Deprecated
@@ -50,16 +52,18 @@
             motion.setMotionCtg(MotionCtgType.LIFT_MOVE.val());
 
             if (null != origin) {
-                motion.setOrigin(String.valueOf(origin.getLev()));
+                motion.setOrigin(String.valueOf(liftDispatcher.getLiftLevOffset(target.getLiftNo(), origin.getLev())));
             }
-            motion.setTarget(String.valueOf(target.getLev()));
-        }));
+            motion.setTarget(String.valueOf(liftDispatcher.getLiftLevOffset(target.getLiftNo(), target.getLev())));
 
-//        if (target.getUpdateLiftNo() != null && target.getWrkNo() != null) {
-//            if (target.getUpdateLiftNo()) {
-//
-//            }
-//        }
+            if (target.getSync() != null) {
+                motion.setSync(target.getSync());
+            }
+
+            if (target.getReleaseLift() != null) {
+                motion.setReleaseLift(target.getReleaseLift());
+            }
+        }));
 
         return motionList;
     }
@@ -77,9 +81,23 @@
             motion.setMotionCtg(MotionCtgType.LIFT_WITH_GOODS.val());
 
             if (null != origin) {
-                motion.setOrigin(String.valueOf(origin.getLev()));
+                motion.setOrigin(String.valueOf(liftDispatcher.getLiftLevOffset(target.getLiftNo(), origin.getLev())));
+                motion.setOriDrt(origin.getStaNo());//婧愮珯
             }
-            motion.setTarget(String.valueOf(target.getLev()));
+            motion.setTarget(String.valueOf(liftDispatcher.getLiftLevOffset(target.getLiftNo(), target.getLev())));
+            motion.setTarDrt(target.getStaNo());//鐩爣绔�
+
+            if (target.getDevpNo() != null) {
+                motion.setDockNo(String.valueOf(target.getDevpNo()));//杈撻�佺嚎ID
+            }
+
+            if (target.getSync() != null) {
+                motion.setSync(target.getSync());
+            }
+
+            if (target.getReleaseLift() != null) {
+                motion.setReleaseLift(target.getReleaseLift());
+            }
         }));
 
         return motionList;
@@ -98,9 +116,14 @@
             motion.setMotionCtg(MotionCtgType.LIFT_WITH_SHUTTLE.val());
 
             if (null != origin) {
-                motion.setOrigin(String.valueOf(origin.getLev()));
+                motion.setOrigin(String.valueOf(liftDispatcher.getLiftLevOffset(target.getLiftNo(), origin.getLev())));
             }
-            motion.setTarget(String.valueOf(target.getLev()));
+
+            if (target.getTaskNo() != null) {
+                motion.setTaskNo(target.getTaskNo());
+            }
+
+            motion.setTarget(String.valueOf(liftDispatcher.getLiftLevOffset(target.getLiftNo(), target.getLev())));
         }));
 
         return motionList;
@@ -119,9 +142,9 @@
             motion.setMotionCtg(MotionCtgType.LIFT_WITH_GOODS_AND_SHUTTLE.val());
 
             if (null != origin) {
-                motion.setOrigin(String.valueOf(origin.getLev()));
+                motion.setOrigin(String.valueOf(liftDispatcher.getLiftLevOffset(target.getLiftNo(), origin.getLev())));
             }
-            motion.setTarget(String.valueOf(target.getLev()));
+            motion.setTarget(String.valueOf(liftDispatcher.getLiftLevOffset(target.getLiftNo(), target.getLev())));
         }));
 
         return motionList;
@@ -139,7 +162,7 @@
 
             motion.setMotionCtg(MotionCtgType.LIFT_TRANSPORT_TO_CONVEYOR.val());
 
-            motion.setOrigin(String.valueOf(origin.getLev()));
+            motion.setOrigin(String.valueOf(liftDispatcher.getLiftLevOffset(origin.getLiftNo(), origin.getLev())));
             motion.setDockNo(String.valueOf(target.getDevpNo()));
             motion.setTarget(String.valueOf(target.getStaNo()));
 
@@ -148,8 +171,100 @@
         return motionList;
     }
 
+    /**
+     * 鎻愬崌鏈洪攣瀹�
+     */
+    public List<Motion> liftLock(MotionDto origin, MotionDto target) {
+        List<Motion> motionList = new ArrayList<>();
+
+        motionList.add(Motion.build(motion -> {
+            motion.setDeviceCtg(DeviceCtgType.LIFT.val());
+            motion.setDevice(String.valueOf(target.getLiftNo()));
+            motion.setMotionCtg(MotionCtgType.LIFT_LOCK.val());
+
+            if (target.getSync() != null) {
+                motion.setSync(target.getSync());
+            }
+
+            if (target.getReleaseLift() != null) {
+                motion.setReleaseLift(target.getReleaseLift());
+            }
+        }));
+
+        return motionList;
+    }
+
+    /**
+     * 鎻愬崌鏈鸿В閿�
+     */
+    public List<Motion> liftUnlock(MotionDto origin, MotionDto target) {
+        List<Motion> motionList = new ArrayList<>();
+
+        motionList.add(Motion.build(motion -> {
+            motion.setDeviceCtg(DeviceCtgType.LIFT.val());
+            motion.setDevice(String.valueOf(target.getLiftNo()));
+            motion.setMotionCtg(MotionCtgType.LIFT_UNLOCK.val());
+
+            if (target.getSync() != null) {
+                motion.setSync(target.getSync());
+            }
+
+            if (target.getReleaseLift() != null) {
+                motion.setReleaseLift(target.getReleaseLift());
+            }
+        }));
+
+        return motionList;
+    }
+
+    /**
+     * 鎻愬崌鏈�-灏忚溅宸插埌浣�
+     */
+    public List<Motion> liftShuttleArrival(MotionDto origin, MotionDto target) {
+        List<Motion> motionList = new ArrayList<>();
+
+        motionList.add(Motion.build(motion -> {
+            motion.setDeviceCtg(DeviceCtgType.LIFT.val());
+            motion.setDevice(String.valueOf(target.getLiftNo()));
+            motion.setMotionCtg(MotionCtgType.LIFT_SHUTTLE_ARRIVAL.val());
+        }));
+
+        return motionList;
+    }
+
+    /**
+     * 鎻愬崌鏈�-灏忚溅宸查┒绂�
+     */
+    public List<Motion> liftShuttleLeave(MotionDto origin, MotionDto target) {
+        List<Motion> motionList = new ArrayList<>();
+
+        motionList.add(Motion.build(motion -> {
+            motion.setDeviceCtg(DeviceCtgType.LIFT.val());
+            motion.setDevice(String.valueOf(target.getLiftNo()));
+            motion.setMotionCtg(MotionCtgType.LIFT_SHUTTLE_LEAVE.val());
+        }));
+
+        return motionList;
+    }
 
     // shuttle -----------------------------------------------------------------------------
+
+    /**
+     * 灏忚溅鍧愭爣鏇存柊
+     */
+    public List<Motion> shuttleUpdateLocation(MotionDto origin, MotionDto target) {
+        List<Motion> motionList = new ArrayList<>();
+
+        motionList.add(Motion.build(motion -> {
+            motion.setDeviceCtg(DeviceCtgType.SHUTTLE.val());
+            motion.setDevice(String.valueOf(target.getShuttleNo()));
+            motion.setMotionCtg(MotionCtgType.SHUTTLE_UPDATE_LOCATION.val());
+
+            motion.setTarget(target.getLocNo());
+        }));
+
+        return motionList;
+    }
 
     /**
      * 绌挎杞︾┖杞界Щ鍔�
@@ -228,14 +343,34 @@
         return motionList;
     }
 
-    public List<Motion> shuttleCharge(MotionDto origin, MotionDto target) {
+    /**
+     * 绌挎杞﹀姩浣�
+     */
+    public List<Motion> shuttleAction(MotionDto origin, MotionDto target, MotionCtgType motionCtgType) {
         List<Motion> motionList = new ArrayList<>();
 
         motionList.add(Motion.build(motion -> {
             motion.setDeviceCtg(DeviceCtgType.SHUTTLE.val());
             motion.setDevice(String.valueOf(target.getShuttleNo()));
 
-            motion.setMotionCtg(MotionCtgType.SHUTTLE_CHARGE_ON.val());
+            motion.setMotionCtg(motionCtgType.val());
+
+            switch (motionCtgType) {
+                case SHUTTLE_PALLET_LIFT://鎵樼洏椤跺崌
+
+                    break;
+                case SHUTTLE_PALLET_DOWN://鎵樼洏涓嬮檷
+
+                    break;
+                case SHUTTLE_CHARGE_ON://鍏呯數寮�
+
+                    break;
+                case SHUTTLE_CHARGE_OFF://鍏呯數鍏�
+
+                    break;
+                default:
+                    break;
+            }
 
         }));
 

--
Gitblit v1.9.1