From fc5fc7ca68282cce52c240ae5b3e69e81c27bfcb Mon Sep 17 00:00:00 2001 From: luxiaotao1123 <t1341870251@163.com> Date: 星期三, 13 十一月 2024 14:15:10 +0800 Subject: [PATCH] # --- zy-acs-manager/src/main/java/com/zy/acs/manager/core/scheduler/MaintainScheduler.java | 112 ++++++++++++++++++++++++++++++-------------------------- 1 files changed, 60 insertions(+), 52 deletions(-) diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/scheduler/MaintainScheduler.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/scheduler/MaintainScheduler.java index 26ddb08..1095e24 100644 --- a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/scheduler/MaintainScheduler.java +++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/scheduler/MaintainScheduler.java @@ -4,6 +4,7 @@ import com.zy.acs.common.enums.AgvStatusType; import com.zy.acs.common.utils.RedisSupport; import com.zy.acs.framework.common.DateUtils; +import com.zy.acs.manager.core.service.MainLockWrapService; import com.zy.acs.manager.core.service.MainService; import com.zy.acs.manager.manager.entity.*; import com.zy.acs.manager.manager.enums.*; @@ -37,6 +38,8 @@ private FuncStaService funcStaService; @Autowired private MainService mainService; + @Autowired + private MainLockWrapService mainLockWrapService; @Autowired private TaskService taskService; @Autowired @@ -79,7 +82,7 @@ continue; } - mainService.buildMinorTask(agv, agvDetail, TaskTypeType.TO_CHARGE, null); + mainLockWrapService.buildMinorTask(agv, agvDetail, TaskTypeType.TO_CHARGE, null); } } } @@ -142,7 +145,7 @@ } // } - mainService.buildMinorTask(agv, agvDetail, TaskTypeType.TO_STANDBY, null); + mainLockWrapService.buildMinorTask(agv, agvDetail, TaskTypeType.TO_STANDBY, null); } } @@ -152,60 +155,65 @@ for (FuncSta funcSta : funcStaList) { boolean beIdle = true; Agv agv = agvService.findByPosition(funcSta.getCode()); - AgvModel agvModel = agvModelService.getById(agv.getAgvModel()); - AgvDetail agvDetail = agvDetailService.selectByAgvId(agv.getId()); + if (null == agv) { + beIdle = false; + } else { + AgvModel agvModel = agvModelService.getById(agv.getAgvModel()); + AgvDetail agvDetail = agvDetailService.selectByAgvId(agv.getId()); - switch (Objects.requireNonNull(FuncStaType.query(funcSta.getType()))) { - case CHARGE: - if (agvDetail.getAgvStatus().equals(AgvStatusType.CHARGE)) { - beIdle = false; - } else { - Task latestTask = taskService.findLatestTask(agv.getId(), null); - if (null != latestTask - && latestTask.getTaskType().equals(TaskTypeType.TO_CHARGE.val()) - && latestTask.getDestCode().equals(funcSta.getCode()) - ) { - // avoid the agv already be full battery but there was no task assign to it, so that not in charge status and battery had down - if (agvDetailService.isPowerLoss(agv, agvDetail, agvModel)) { - beIdle = false; + switch (Objects.requireNonNull(FuncStaType.query(funcSta.getType()))) { + case CHARGE: + if (agvDetail.getAgvStatus().equals(AgvStatusType.CHARGE)) { + beIdle = false; + } else { + Task latestTask = taskService.findLatestTask(agv.getId(), null); + if (null != latestTask + && latestTask.getTaskType().equals(TaskTypeType.TO_CHARGE.val()) + && latestTask.getDestCode().equals(funcSta.getCode()) + ) { + // avoid the agv already be full battery but there was no task assign to it, so that not in charge status and battery had down + if (agvDetailService.isPowerLoss(agv, agvDetail, agvModel)) { + beIdle = false; + } } } - } - if (0 < taskService.count(new LambdaQueryWrapper<Task>() - .eq(Task::getTaskType, TaskTypeType.TO_CHARGE.val()) - .eq(Task::getDestCode, funcSta.getCode()) - .and(i -> { - i.eq(Task::getTaskSts, TaskStsType.WAITING.val()).or() - .eq(Task::getTaskSts, TaskStsType.ASSIGN.val()).or() - .eq(Task::getTaskSts, TaskStsType.PROGRESS.val()); - }) - )) { - beIdle = false; - } - break; - case STANDBY: - Task latestTask = taskService.findLatestTask(agv.getId(), null); - if (null != latestTask - && latestTask.getTaskType().equals(TaskTypeType.TO_STANDBY.val()) - && latestTask.getDestCode().equals(funcSta.getCode()) - ) { - beIdle = false; - } - if (0 < taskService.count(new LambdaQueryWrapper<Task>() - .eq(Task::getTaskType, TaskTypeType.TO_STANDBY.val()) - .eq(Task::getDestCode, funcSta.getCode()) - .and(i -> { - i.eq(Task::getTaskSts, TaskStsType.WAITING.val()).or() - .eq(Task::getTaskSts, TaskStsType.ASSIGN.val()).or() - .eq(Task::getTaskSts, TaskStsType.PROGRESS.val()); - }) - )) { - beIdle = false; - } - break; - default: - break; + if (0 < taskService.count(new LambdaQueryWrapper<Task>() + .eq(Task::getTaskType, TaskTypeType.TO_CHARGE.val()) + .eq(Task::getDestCode, funcSta.getCode()) + .and(i -> { + i.eq(Task::getTaskSts, TaskStsType.WAITING.val()).or() + .eq(Task::getTaskSts, TaskStsType.ASSIGN.val()).or() + .eq(Task::getTaskSts, TaskStsType.PROGRESS.val()); + }) + )) { + beIdle = false; + } + break; + case STANDBY: + Task latestTask = taskService.findLatestTask(agv.getId(), null); + if (null != latestTask + && latestTask.getTaskType().equals(TaskTypeType.TO_STANDBY.val()) + && latestTask.getDestCode().equals(funcSta.getCode()) + ) { + beIdle = false; + } + if (0 < taskService.count(new LambdaQueryWrapper<Task>() + .eq(Task::getTaskType, TaskTypeType.TO_STANDBY.val()) + .eq(Task::getDestCode, funcSta.getCode()) + .and(i -> { + i.eq(Task::getTaskSts, TaskStsType.WAITING.val()).or() + .eq(Task::getTaskSts, TaskStsType.ASSIGN.val()).or() + .eq(Task::getTaskSts, TaskStsType.PROGRESS.val()); + }) + )) { + beIdle = false; + } + break; + default: + break; + } } + if (beIdle) { funcSta.setState(FuncStaStateType.IDLE.toString()); funcSta.setUpdateTime(new Date()); -- Gitblit v1.9.1