From d62c5c0eb2e28b7bf27d23de84a609b5a2e415e4 Mon Sep 17 00:00:00 2001 From: Junjie <xjj@123> Date: 星期四, 17 十月 2024 18:48:00 +0800 Subject: [PATCH] # --- zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/kernel/command/LiftCommandService.java | 74 +++++++++++++++++++++++++++++++----- 1 files changed, 63 insertions(+), 11 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 9789394..35cac52 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 @@ -84,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<>(); @@ -100,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: @@ -112,8 +113,13 @@ // return false; // } - command = liftThread.getPalletInOutCommand(motion.getTaskNo(), Integer.parseInt(motion.getOrigin()), Integer.parseInt(motion.getTarget()), motion.getOriDrt(), motion.getTarDrt(), LiftCommandModeType.PALLET_INOUT); + 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: //鍒ゆ柇鎻愬崌鏈烘槸鍚﹁嚜鍔� @@ -125,7 +131,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: @@ -144,7 +150,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: @@ -154,7 +160,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: @@ -164,7 +170,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: @@ -235,13 +241,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