From d835d1b51f832889929cdf69010034a30ef44d02 Mon Sep 17 00:00:00 2001 From: Junjie <xjj@123> Date: 星期四, 17 十月 2024 13:57:29 +0800 Subject: [PATCH] # --- zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/controller/BasShuttleController.java | 56 ++++++++++++++++++++++++++++++++++++++++++++++++++------ 1 files changed, 50 insertions(+), 6 deletions(-) diff --git a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/controller/BasShuttleController.java b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/controller/BasShuttleController.java index 305062c..62f5e5e 100644 --- a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/controller/BasShuttleController.java +++ b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/controller/BasShuttleController.java @@ -17,6 +17,7 @@ import com.zy.asrs.wcs.core.entity.TaskCtg; import com.zy.asrs.wcs.core.kernel.AnalyzeService; import com.zy.asrs.wcs.core.model.enums.DeviceCtgType; +import com.zy.asrs.wcs.core.model.enums.TaskCtgType; import com.zy.asrs.wcs.core.model.enums.TaskStsType; import com.zy.asrs.wcs.core.service.BasShuttleService; import com.zy.asrs.wcs.core.service.MotionService; @@ -142,7 +143,7 @@ //鑾峰彇鎵嬪姩浠诲姟绫诲瀷 TaskCtg taskCtg = taskCtgService.getOne(new LambdaQueryWrapper<TaskCtg>() - .eq(TaskCtg::getFlag, "MANUAL") + .eq(TaskCtg::getFlag, String.valueOf(TaskCtgType.MANUAL)) .eq(TaskCtg::getStatus, 1)); if (taskCtg == null) { return R.error(); @@ -175,6 +176,23 @@ shuttleThread.reset(null); return R.ok(); + } else if (param.getShuttleTaskMode().equals("requestWaiting")) { + //鐢宠纭 + Device device = deviceService.getOne(new LambdaQueryWrapper<Device>() + .eq(Device::getDeviceType, DeviceCtgType.SHUTTLE.val()) + .eq(Device::getStatus, 1) + .eq(Device::getDeviceNo, shuttleNo)); + if (device == null) { + return R.error("璁惧涓嶅瓨鍦�"); + } + + ShuttleThread shuttleThread = (ShuttleThread) SlaveConnection.get(SlaveType.Shuttle, device.getId().intValue()); + if (shuttleThread == null) { + return R.error("璁惧绂荤嚎"); + } + + shuttleThread.requestWaiting(); + return R.ok(); } Task task = new Task(); @@ -185,15 +203,15 @@ task.setPriority(10); task.setOriginSite(null); task.setOriginLoc(sourceLoc); - task.setDestSite(targetSite); + task.setDestSite(null); task.setDestLoc(targetLoc); task.setIoTime(new Date()); task.setStartTime(new Date()); task.setStatus(1); - task.setMemo("manual"); + task.setMemo(targetSite); task.setShuttleNo(param.getShuttleNo()); - if (param.getShuttleTaskMode().equals("taskMove")) { + if (param.getShuttleTaskMode().equals("takeMove")) { task.setRecordLoc("Y");//璁板綍搴撳瓨淇℃伅 } boolean result = taskService.save(task); @@ -222,7 +240,6 @@ //璺戝簱绯荤粺 @PreAuthorize("hasAuthority('core:basShuttle:operator')") @PostMapping("/basShuttle/moveLoc") - @Transactional public synchronized R shuttleMoveLoc(@RequestBody ShuttleMoveLocParam param) { Device device = deviceService.getOne(new LambdaQueryWrapper<Device>() .eq(Device::getDeviceType, DeviceCtgType.SHUTTLE.val()) @@ -247,7 +264,34 @@ return R.error("灏忚溅蹇欑涓�"); } - shuttleThread.enableMoveLoc(param); + shuttleThread.enableMoveLoc(param, true); + return R.ok(); + } + + //璺戝簱绯荤粺鍏抽棴 + @PreAuthorize("hasAuthority('core:basShuttle:operator')") + @PostMapping("/basShuttle/moveLocClose") + public synchronized R shuttleMoveLocClose(@RequestBody ShuttleMoveLocParam param) { + Device device = deviceService.getOne(new LambdaQueryWrapper<Device>() + .eq(Device::getDeviceType, DeviceCtgType.SHUTTLE.val()) + .eq(Device::getStatus, 1) + .eq(Device::getHostId, getHostId()) + .eq(Device::getDeviceNo, param.getShuttleNo())); + if (device == null) { + return R.error(); + } + + ShuttleThread shuttleThread = (ShuttleThread) SlaveConnection.get(SlaveType.Shuttle, device.getId().intValue()); + if (shuttleThread == null) { + return R.error(); + } + + ShuttleProtocol shuttleProtocol = shuttleThread.getStatus(); + if (shuttleProtocol == null) { + return R.error(); + } + + shuttleThread.enableMoveLoc(null, false); return R.ok(); } -- Gitblit v1.9.1