From 0fc62ab3d5d038235b328d91cda0192a34617fb9 Mon Sep 17 00:00:00 2001
From: Junjie <fallin.jie@qq.com>
Date: 星期一, 19 五月 2025 20:17:30 +0800
Subject: [PATCH] #
---
 zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/kernel/command/LiftCommandService.java |  163 ++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 151 insertions(+), 12 deletions(-)
diff --git a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/kernel/command/LiftCommandService.java b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/kernel/command/LiftCommandService.java
index 6cace00..c8680e1 100644
--- a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/kernel/command/LiftCommandService.java
+++ b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/kernel/command/LiftCommandService.java
@@ -12,10 +12,13 @@
 import com.zy.asrs.wcs.core.model.enums.MotionStsType;
 import com.zy.asrs.wcs.core.service.MotionService;
 import com.zy.asrs.wcs.core.service.TaskService;
+import com.zy.asrs.wcs.core.utils.Utils;
 import com.zy.asrs.wcs.rcs.cache.SlaveConnection;
 import com.zy.asrs.wcs.rcs.model.enums.LiftProtocolStatusType;
 import com.zy.asrs.wcs.rcs.model.enums.SlaveType;
 import com.zy.asrs.wcs.rcs.model.protocol.LiftProtocol;
+import com.zy.asrs.wcs.rcs.model.protocol.StaProtocol;
+import com.zy.asrs.wcs.rcs.thread.DevpThread;
 import com.zy.asrs.wcs.rcs.thread.LiftThread;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
@@ -59,6 +62,14 @@
             return false;
         }
 
+        //妫�娴嬫彁鍗囨満鏄惁鏈変换鍔$粦瀹�
+        boolean liftResult = Utils.checkLiftHasBinding(liftProtocol.getLiftNo(), String.valueOf(motion.getTaskNo()));
+        if (liftResult) {
+            //瀛樺湪浠诲姟锛岀姝㈡墽琛�
+            return false;
+        }
+
+        //姣忔鎵ц鎻愬崌鏈烘寚浠ら兘缁戝畾鎻愬崌鏈�
         Task task = taskService.getOne(new LambdaQueryWrapper<Task>().eq(Task::getTaskNo, motion.getTaskNo()));
         if (task == null) {
             return false;
@@ -73,6 +84,7 @@
         LiftAssignCommand assignCommand = new LiftAssignCommand();
         assignCommand.setLiftNo(liftProtocol.getLiftNo());
         assignCommand.setTaskNo(motion.getTaskNo());
+        assignCommand.setDeviceTaskNo(liftThread.generateDeviceTaskNo(motion.getTaskNo(), MotionCtgType.get(motion.getMotionCtgEl())));
         assignCommand.setCommands(list);
 
         List<LiftCommand> command = new ArrayList<>();
@@ -89,7 +101,7 @@
                     break;
                 }
 
-                command = liftThread.getMoveCommand(motion.getTaskNo(), 0, Integer.parseInt(motion.getTarget()), LiftCommandModeType.MOVE);
+                command = liftThread.getMoveCommand(assignCommand.getDeviceTaskNo(), 0, Integer.parseInt(motion.getTarget()), LiftCommandModeType.MOVE);
                 list.addAll(command);
                 return liftAction.assignWork(liftThread.getDevice(), assignCommand);
             case LIFT_WITH_GOODS:
@@ -101,8 +113,57 @@
 //                    return false;
 //                }
 
-                command = liftThread.getPalletInOutCommand(motion.getTaskNo(), Integer.parseInt(motion.getOrigin()), Integer.parseInt(motion.getTarget()), motion.getOriDrt(), motion.getTarDrt(), LiftCommandModeType.PALLET_INOUT);
+                //鍒ゆ柇鐩爣绔欐槸鍚︽湁鎵樼洏
+                Integer conveyorDeviceId = Integer.parseInt(motion.getDockNo());
+                DevpThread devpThread = (DevpThread) SlaveConnection.get(SlaveType.Conveyor, conveyorDeviceId);
+                if (devpThread == null) {
+                    return false;
+                }
+//                //*************鏍囧噯绯荤粺浠g爜********************
+//                StaProtocol staProtocol = devpThread.getStation().get(motion.getTarDrt());
+//                if (staProtocol == null) {
+//                    return false;
+//                }
+//                if (!staProtocol.isAutoing()) {
+//                    return false;
+//                }
+//                if (staProtocol.isLoading()) {
+//                    return false;
+//                }
+//                if (staProtocol.getWorkNo().intValue() != 0) {
+//                    return false;
+//                }
+//                //*************************************************
+
+
+                //*************姝や唬鐮佷负鍏夋嘲瀹氬埗浠g爜********************
+                Integer tarDrt = motion.getTarDrt();
+                if (tarDrt == 31001) {
+                    tarDrt = 31004;
+                }
+
+                StaProtocol staProtocol = devpThread.getStation().get(tarDrt);
+                if (staProtocol == null) {
+                    return false;
+                }
+                if (!staProtocol.isAutoing()) {
+                    return false;
+                }
+                if (staProtocol.isLoading()) {
+                    return false;
+                }
+                if (staProtocol.getWorkNo().intValue() != 0) {
+                    return false;
+                }
+                //*************************************************
+
+                command = liftThread.getPalletInOutCommand(assignCommand.getDeviceTaskNo(), Integer.parseInt(motion.getOrigin()), Integer.parseInt(motion.getTarget()), motion.getOriDrt(), motion.getTarDrt(), LiftCommandModeType.PALLET_INOUT);
                 list.addAll(command);
+
+                motion.setTemp(String.valueOf(assignCommand.getDeviceTaskNo()));
+                motion.setUpdateTime(new Date());
+                motionService.updateById(motion);
+
                 return liftAction.assignWork(liftThread.getDevice(), assignCommand);
             case LIFT_WITH_SHUTTLE:
                 //鍒ゆ柇鎻愬崌鏈烘槸鍚﹁嚜鍔�
@@ -114,7 +175,7 @@
                     return false;
                 }
 
-                command = liftThread.getMoveWithShuttleCommand(motion.getTaskNo(), Integer.parseInt(motion.getOrigin()), Integer.parseInt(motion.getTarget()), LiftCommandModeType.MOVE_CAR);
+                command = liftThread.getMoveWithShuttleCommand(assignCommand.getDeviceTaskNo(), Integer.parseInt(motion.getOrigin()), Integer.parseInt(motion.getTarget()), LiftCommandModeType.MOVE_CAR);
                 list.addAll(command);
                 return liftAction.assignWork(liftThread.getDevice(), assignCommand);
             case LIFT_WITH_GOODS_AND_SHUTTLE:
@@ -133,7 +194,7 @@
                     return false;
                 }
 
-                command = liftThread.getLockCommand(motion.getTaskNo(), true);//鑾峰彇鎻愬崌鏈洪攣瀹氬懡浠�
+                command = liftThread.getLockCommand(assignCommand.getDeviceTaskNo(), true);//鑾峰彇鎻愬崌鏈洪攣瀹氬懡浠�
                 list.addAll(command);
                 return liftAction.assignWork(liftThread.getDevice(), assignCommand);
             case LIFT_UNLOCK:
@@ -143,7 +204,7 @@
                     return false;
                 }
 
-                command = liftThread.getLockCommand(motion.getTaskNo(), false);//鑾峰彇鎻愬崌鏈鸿В瀹氬懡浠�
+                command = liftThread.getLockCommand(assignCommand.getDeviceTaskNo(), false);//鑾峰彇鎻愬崌鏈鸿В瀹氬懡浠�
                 list.addAll(command);
                 return liftAction.assignWork(liftThread.getDevice(), assignCommand);
             case LIFT_SHUTTLE_ARRIVAL:
@@ -153,7 +214,7 @@
                     return false;
                 }
 
-                command = liftThread.getShuttleSignalCommand(motion.getTaskNo(), true);//鑾峰彇灏忚溅宸插埌浣嶅懡浠�
+                command = liftThread.getShuttleSignalCommand(assignCommand.getDeviceTaskNo(), true);//鑾峰彇灏忚溅宸插埌浣嶅懡浠�
                 list.addAll(command);
                 return liftAction.assignWork(liftThread.getDevice(), assignCommand);
             default:
@@ -194,6 +255,14 @@
                     return false;
                 }
 
+                if (motion.getReleaseLift() == 1) {//閲婃斁鎻愬崌鏈�
+                    task.setLiftNo(0);
+                    task.setUpdateTime(new Date());
+                    if (!taskService.updateById(task)) {
+                        return false;
+                    }
+                }
+
                 break;
             case LIFT_WITH_GOODS:
                 // 鍒ゆ柇鎻愬崌鏈烘槸鍚︾┖闂�
@@ -205,16 +274,78 @@
                     return false;
                 }
 
-                if (task.getTaskSts() < 100) {//鍏ュ簱鍒ゆ柇鎵樼洏鏄惁杩涘叆鎻愬崌鏈�
-                    if (!liftProtocol.getHasTray()) {
-                        return false;
+                //鍒ゆ柇鎻愬崌鏈烘墭鐩樻槸鍚﹀瓨鍦�
+                if (liftProtocol.getHasTray()) {
+                    return false;
+                }
+
+                //鍒ゆ柇鐩爣绔欐槸鍚︽湁鎵樼洏
+                Integer conveyorDeviceId = Integer.parseInt(motion.getDockNo());
+                DevpThread devpThread = (DevpThread) SlaveConnection.get(SlaveType.Conveyor, conveyorDeviceId);
+                if (devpThread == null) {
+                    return false;
+                }
+
+//                //*************姝や唬鐮佷负鏍囧噯鐗堟湰浠g爜********************
+//                StaProtocol staProtocol = devpThread.getStation().get(motion.getTarDrt());
+//                if(staProtocol == null) {
+//                    return false;
+//                }
+//                if (!staProtocol.isAutoing()) {
+//                    return false;
+//                }
+//                if (!staProtocol.isLoading()) {
+//                    return false;
+//                }
+//                if (!motion.getTaskNo().equals(staProtocol.getWorkNo().intValue())) {
+//                    if (motion.getTemp() == null) {
+//                        return false;
+//                    }
+//
+//                    if (Integer.parseInt(motion.getTemp()) != staProtocol.getWorkNo().intValue()) {
+//                        return false;
+//                    }
+//                }
+//                //*************************************************
+
+                //*************姝や唬鐮佷负鍏夋嘲瀹氬埗浠g爜********************
+                ArrayList<Integer> staList = new ArrayList<>();
+                staList.add(motion.getTarDrt());
+                staList.add(31003);
+                staList.add(31002);
+                staList.add(31001);
+
+                boolean check = false;
+                for (Integer sta : staList) {
+                    StaProtocol staProtocol = devpThread.getStation().get(sta);
+                    if (staProtocol == null) {
+                        continue;
                     }
-                } else if (task.getTaskSts() >= 100 && task.getTaskSts() < 200) {//鍑哄簱鍒ゆ柇鎵樼洏鏄惁绂诲紑鎻愬崌鏈�
-                    if (liftProtocol.getHasTray()) {
-                        return false;
+                    if (!staProtocol.isAutoing()) {
+                        continue;
+                    }
+                    if (!staProtocol.isLoading()) {
+                        continue;
+                    }
+                    if (Integer.parseInt(motion.getTemp()) == staProtocol.getWorkNo().intValue()) {
+                        check = true;
+                        break;
                     }
                 }
 
+                if (!check) {
+                    return false;
+                }
+                //*************************************************
+
+
+                if (motion.getReleaseLift() == 1) {//閲婃斁鎻愬崌鏈�
+                    task.setLiftNo(0);
+                    task.setUpdateTime(new Date());
+                    if (!taskService.updateById(task)) {
+                        return false;
+                    }
+                }
 
                 break;
             case LIFT_WITH_SHUTTLE:
@@ -263,6 +394,14 @@
                 if (liftThread.isLock(null)) {
                     return false;
                 }
+
+                if (motion.getReleaseLift() == 1) {//閲婃斁鎻愬崌鏈�
+                    task.setLiftNo(0);
+                    task.setUpdateTime(new Date());
+                    if (!taskService.updateById(task)) {
+                        return false;
+                    }
+                }
                 break;
             case LIFT_SHUTTLE_ARRIVAL:
 
--
Gitblit v1.9.1