From 4d8bb57c9eb3fda399fd7b9e9de7ecbf754244f7 Mon Sep 17 00:00:00 2001
From: Junjie <xjj@123>
Date: 星期一, 20 五月 2024 08:53:26 +0800
Subject: [PATCH] #

---
 zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/kernel/command/LiftCommandService.java |  166 +++----------------------------------------------------
 1 files changed, 10 insertions(+), 156 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 9f876c1..cd41492 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
@@ -6,6 +6,7 @@
 import com.zy.asrs.wcs.core.model.command.LiftAssignCommand;
 import com.zy.asrs.wcs.core.model.command.LiftCommand;
 import com.zy.asrs.wcs.core.model.enums.DeviceCtgType;
+import com.zy.asrs.wcs.core.model.enums.LiftCommandModeType;
 import com.zy.asrs.wcs.core.model.enums.MotionCtgType;
 import com.zy.asrs.wcs.core.model.enums.MotionStsType;
 import com.zy.asrs.wcs.core.service.MotionService;
@@ -70,29 +71,27 @@
             case LIFT_MOVE:
                 // 濡傛灉宸茬粡鍦ㄧ洰鏍囧眰锛岄偅杈瑰眰杩囨护
                 if (liftProtocol.getLev().equals(Integer.valueOf(motion.getTarget()))) {
-                    liftProtocol.setTaskNo(motion.getTaskNo());
+                    liftThread.setSyncTaskNo(motion.getTaskNo());
                     break;
                 }
 
-                command = liftThread.getMoveCommand(motion.getTaskNo(), 0, Integer.parseInt(motion.getTarget()), null);
+                command = liftThread.getMoveCommand(motion.getTaskNo(), 0, Integer.parseInt(motion.getTarget()), LiftCommandModeType.MOVE);
                 list.add(command);
                 return liftAction.assignWork(liftThread.getDevice(), assignCommand);
             case LIFT_WITH_GOODS:
-                return false;
-//                if (!liftProtocol.getLineFrontHasStock() || !liftProtocol.getLineEndHasStock()) {
+//                if (liftProtocol.getHasTray()) {
 //                    return false;
 //                }
-//
-//                command = liftThread.getLiftUpDownCommand(Integer.parseInt(motion.getTarget()));
-//                command.setLiftNo(deviceNo.shortValue());
-//                command.setTaskNo(motion.getWrkNo().shortValue());
-//                return liftThread.assignWork(command);
+
+                command = liftThread.getPalletInOutCommand(motion.getTaskNo(), Integer.parseInt(motion.getOrigin()), Integer.parseInt(motion.getTarget()), motion.getOriDrt(), motion.getTarDrt(), LiftCommandModeType.PALLET_INOUT);
+                list.add(command);
+                return liftAction.assignWork(liftThread.getDevice(), assignCommand);
             case LIFT_WITH_SHUTTLE:
                 if (!liftProtocol.getHasCar()) {
                     return false;
                 }
 
-                command = liftThread.getMoveWithShuttleCommand(motion.getTaskNo(), Integer.parseInt(motion.getOrigin()), Integer.parseInt(motion.getTarget()), null);
+                command = liftThread.getMoveWithShuttleCommand(motion.getTaskNo(), Integer.parseInt(motion.getOrigin()), Integer.parseInt(motion.getTarget()), LiftCommandModeType.MOVE_CAR);
                 list.add(command);
                 return liftAction.assignWork(liftThread.getDevice(), assignCommand);
             case LIFT_WITH_GOODS_AND_SHUTTLE:
@@ -107,88 +106,6 @@
 //                return liftThread.assignWork(command);
             case LIFT_TRANSPORT_TO_CONVEYOR:
                 return false;
-//                // 鍒ゆ柇杈撻�佺嚎鐘舵��
-//                int staNo = Integer.parseInt(motion.getTarget());
-//                WorkZoneType zoneType = WorkZoneType.query(staNo);
-//
-//                SiemensDevpThread devpThread = (SiemensDevpThread) SlaveConnection.get(SlaveType.Devp, zoneType.devpPlcId);
-//
-//                StaProtocol staProtocol = devpThread.getStation().get(staNo);
-//                if (staProtocol == null) {
-//                    return false;
-//                }
-//
-//                if (!staProtocol.isAutoing()
-//                    || staProtocol.isLoading()
-////                    || !staProtocol.isOutEnable()
-//                    || staProtocol.getWorkNo() != 0) {
-//                    return false;
-//                }
-//
-//                // 鍒ゆ柇鎻愬崌鏈虹姸鎬�
-//                if (!liftProtocol.getLev().equals(Short.parseShort(motion.getOrigin()))) {  // 鏄惁澶勪簬浠诲姟灞�
-//                    return false;
-//                }
-//
-//                // 涓嬪彂鍛戒护 ---------------------------------------------------
-//
-//                // 1.椹卞姩杈撻�佺嚎鐢垫満
-//                StaMotorType staMotorType = null;
-//                StaMotorType reqStaMotorType = null;
-//                LiftInteractiveModeType liftInteractiveModeType = null;
-//                LiftNeighborType neighborType = LiftNeighborType.query(staNo);
-//                StaProtocol staProtocol1 = staProtocol.clone();
-//                staProtocol1.setWorkNo(motion.getWrkNo().shortValue());
-//                staProtocol1.setStaNo(neighborType.finalStaNo.shortValue());
-//                switch (neighborType) {
-//                    case LIFT_2_NEIGHBOR_OUTBOUND_LEV_1:
-//                        staMotorType = StaMotorType.FORWARD;
-//                        reqStaMotorType = StaMotorType.REQ_FORWARD;
-//                        liftInteractiveModeType = LiftInteractiveModeType.ENGINE_LOADING_TURN_REVERSE;
-//                        break;
-//                    case LIFT_1_NEIGHBOR_INBOUND_LEV_2:
-//                    case LIFT_1_NEIGHBOR_INBOUND_LEV_3:
-//                    case LIFT_1_NEIGHBOR_INBOUND_LEV_4:
-//                        staMotorType = StaMotorType.FORWARD;
-//                        reqStaMotorType = StaMotorType.REQ_FORWARD;
-//                        liftInteractiveModeType = LiftInteractiveModeType.ENGINE_LOADING_TURN_REVERSE;
-//                        break;
-//                    case LIFT_1_NEIGHBOR_OUTBOUND_LEV_1_FINAL_8:
-//                        staMotorType = StaMotorType.FORWARD;
-//                        reqStaMotorType = StaMotorType.REQ_FORWARD;
-//                        liftInteractiveModeType = LiftInteractiveModeType.ENGINE_LOADING_TURN_REVERSE;
-//                        break;
-//                    default:
-//                        break;
-//                }
-//
-//                MessageQueue.offer(SlaveType.Devp, devpThread.getSlave().getId(), new Task(2, staProtocol1));
-//                try {
-//                    Thread.sleep(1000);
-//                } catch (InterruptedException ignore) {}
-////                int times = 0;boolean staProtocolMotorRes = false;
-////                while (times < 5) {
-////                    if (staProtocol.getStaMotorType().equals(staMotorType)) {
-////                        staProtocolMotorRes = true;
-////                        break;
-////                    }
-////                    if (!devpThread.controlMotor(staNo, reqStaMotorType)) {
-////                        continue;
-////                    }
-////                    try {
-////                        Thread.sleep(500);
-////                    } catch (InterruptedException ignore) {}
-////                    times++;
-////                }
-////                if (!staProtocolMotorRes) {
-////                    return false;
-////                }
-//
-//                // 2.椹卞姩鎻愬崌鏈虹數鏈�
-//                command = liftThread.getLiftTurnCommand(liftInteractiveModeType.id);
-//                command.setLiftNo(deviceNo.shortValue());
-//                command.setTaskNo(motion.getWrkNo().shortValue());
-//                return liftThread.assignWork(command);
             default:
                 break;
 
@@ -269,76 +186,13 @@
 
                 break;
             case LIFT_TRANSPORT_TO_CONVEYOR:
-//                // 鍒ゆ柇鎻愬崌鏈烘槸鍚﹁嚜鍔ㄣ�佺┖闂层�佸噯澶囧氨缁�佸墠鍏夌數鏃犺揣銆侀摼鏉℃病鏈夎浆鍔�
-//                if (!liftProtocol.getModel()
-//                        || liftProtocol.getRun()
-//                        || !liftProtocol.getReady()
-//                        || liftProtocol.getLineFxrontHasStock()
-//                        || liftProtocol.getLineEndHasStock()
-//                        || liftProtocol.getForwardRotationFeedback()
-//                        || liftProtocol.getReverseFeedback()
-//                ) {
-//                    return false;
-//                }
-//
-//                if (liftProtocol.getTaskNo().intValue() != motion.getWrkNo()) {
-//                    return false;
-//                }
-//
-//                // 鍒ゆ柇杈撻�佺嚎鐘舵��
-//                int staNo = Integer.parseInt(motion.getTarget());
-//                WorkZoneType zoneType = WorkZoneType.query(staNo);
-//
-//                SiemensDevpThread devpThread = (SiemensDevpThread) SlaveConnection.get(SlaveType.Devp, zoneType.devpPlcId);
-//
-//                StaProtocol staProtocol = devpThread.getStation().get(staNo);
-//                if (staProtocol == null) {
-//                    return false;
-//                }
-//
-//                if (!staProtocol.getStaMotorType().equals(StaMotorType.STANDBY)) {
-//                    return false;
-//                }
-//
-////                // 鍒ゆ柇杈撻�佺嚎鐘舵��
-////                int staNo = Integer.parseInt(motion.getTarget());
-////                WorkZoneType zoneType = WorkZoneType.query(staNo);
-////
-////                SiemensDevpThread devpThread = (SiemensDevpThread) SlaveConnection.get(SlaveType.Devp, zoneType.devpPlcId);
-////
-////                StaProtocol staProtocol = devpThread.getStation().get(staNo);
-////                if (staProtocol == null) {
-////                    return false;
-////                }
-////
-////                if (!staProtocol.isAutoing() || !staProtocol.isLoading() || staProtocol.getWorkNo() != motion.getWrkNo().intValue()) {
-////                    return false;
-////                }
-//
-////                if (!staProtocol.getStaMotorType().equals(StaMotorType.STANDBY)) {
-////                    return false;
-////                }
-//
-////                // 灏嗕换鍔″彿鍏堜繚瀛樺埌杈撻�佺嚎绔欑偣涓婏紝鐩爣绔欎负0
-////                StaProtocol clone = staProtocol.clone();
-////                clone.setWorkNo(motion.getWrkNo().shortValue());
-////                clone.setStaNo((short) 0);
-////                if (!MessageQueue.offer(SlaveType.Devp, zoneType.devpPlcId, new Task(2, clone))) {
-////                    return false;
-////                }
-////
-////                // 鍋滄鎻愬崌鏈虹數鏈鸿浆鍔紝骞跺浣�
-////                command = liftThread.getLiftTurnCommand(LiftInteractiveModeType.ENGINE_STOP.id);
-////                command.setLiftNo(deviceNo.shortValue());
-////                command.setTaskNo(motion.getWrkNo().shortValue());
-////                return liftThread.assignWork(command);
 
                 break;
             default:
                 return false;
         }
 
-        liftProtocol.setTaskNo(0);//娓呴浂宸ヤ綔鍙�
+        liftThread.setSyncTaskNo(0);//娓呴浂宸ヤ綔鍙�
         return true;
     }
 

--
Gitblit v1.9.1