From f11ebf31a302d2a8a755625cec83294c67a9088c Mon Sep 17 00:00:00 2001
From: zjj <3272660260@qq.com>
Date: 星期一, 18 十一月 2024 13:00:33 +0800
Subject: [PATCH] #led

---
 zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/kernel/command/LiftCommandService.java |  105 ++++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 100 insertions(+), 5 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 df05a64..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
@@ -113,8 +113,57 @@
 //                    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 (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:
                 //鍒ゆ柇鎻愬崌鏈烘槸鍚﹁嚜鍔�
@@ -236,13 +285,59 @@
                 if (devpThread == null) {
                     return false;
                 }
-                StaProtocol staProtocol = devpThread.getStation().get(motion.getTarDrt());
-                if(staProtocol == null) {
+
+//                //*************姝や唬鐮佷负鏍囧噯鐗堟湰浠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;
+                    }
+                    if (!staProtocol.isAutoing()) {
+                        continue;
+                    }
+                    if (!staProtocol.isLoading()) {
+                        continue;
+                    }
+                    if (Integer.parseInt(motion.getTemp()) == staProtocol.getWorkNo().intValue()) {
+                        check = true;
+                        break;
+                    }
+                }
+
+                if (!check) {
                     return false;
                 }
-                if (!staProtocol.isLoading()) {
-                    return false;
-                }
+                //*************************************************
+
 
                 if (motion.getReleaseLift() == 1) {//閲婃斁鎻愬崌鏈�
                     task.setLiftNo(0);

--
Gitblit v1.9.1