|  |  |  | 
|---|
|  |  |  | 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.*; | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.util.Date; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  | import java.util.Objects; | 
|---|
|  |  |  | import java.util.Optional; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * judge whether agv go to funcSta which be charging or standby | 
|---|
|  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private MainService mainService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private MainLockWrapService mainLockWrapService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private TaskService taskService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private ConfigService configService; | 
|---|
|  |  |  | 
|---|
|  |  |  | List<Agv> agvList = agvService.list(new LambdaQueryWrapper<Agv>().eq(Agv::getStatus, StatusType.ENABLE.val)); | 
|---|
|  |  |  | for (Agv agv : agvList) { | 
|---|
|  |  |  | AgvDetail agvDetail = agvDetailService.selectByAgvId(agv.getId()); | 
|---|
|  |  |  | AgvModel agvModel = agvModelService.getById(agv.getAgvModel()); | 
|---|
|  |  |  | AgvModel agvModel = agvModelService.getByAgvId(agv.getId()); | 
|---|
|  |  |  | if (null == agvDetail || null == agvDetail.getVol() || null == agvDetail.getAgvStatus()) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | mainService.buildMinorTask(agv, agvDetail, TaskTypeType.TO_CHARGE, null); | 
|---|
|  |  |  | mainLockWrapService.buildMinorTask(agv.getId(), TaskTypeType.TO_CHARGE, null, null); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | List<Agv> agvList = agvService.list(new LambdaQueryWrapper<Agv>().eq(Agv::getStatus, StatusType.ENABLE.val)); | 
|---|
|  |  |  | for (Agv agv : agvList) { | 
|---|
|  |  |  | AgvDetail agvDetail = agvDetailService.selectByAgvId(agv.getId()); | 
|---|
|  |  |  | AgvModel agvModel = agvModelService.getById(agv.getAgvModel()); | 
|---|
|  |  |  | AgvModel agvModel = agvModelService.getByAgvId(agv.getId()); | 
|---|
|  |  |  | if (null == agvDetail || null == agvDetail.getVol() || null == agvDetail.getAgvStatus() || null == agvDetail.getRecentCode()) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | )) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // the time between the latest task and now that be must more that 10 seconds | 
|---|
|  |  |  | // the time between the latest task and now that be must more that @{param} seconds | 
|---|
|  |  |  | //            if (!Optional.ofNullable((Boolean) redis.getObject(RedisConstant.AGV_TO_STANDBY_FLAG, agv.getUuid())).orElse(false)) { | 
|---|
|  |  |  | Integer intervalOfAutoStandby = configService.getVal("intervalOfAutoStandby", Integer.class); | 
|---|
|  |  |  | if (null != intervalOfAutoStandby && intervalOfAutoStandby > 0) { | 
|---|
|  |  |  | Task latestTask = taskService.findLatestTask(agv.getId(), null); | 
|---|
|  |  |  | if (null != latestTask) { | 
|---|
|  |  |  | long seconds = DateUtils.diffToSeconds(latestTask.getUpdateTime(), new Date()); | 
|---|
|  |  |  | long seconds = DateUtils.diffToSeconds( | 
|---|
|  |  |  | Optional.ofNullable(latestTask.getEndTime()).orElse(latestTask.getUpdateTime()) | 
|---|
|  |  |  | , new Date() | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | if (seconds < intervalOfAutoStandby) { continue; } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | mainService.buildMinorTask(agv, agvDetail, TaskTypeType.TO_STANDBY, null); | 
|---|
|  |  |  | mainLockWrapService.buildMinorTask(agv.getId(), TaskTypeType.TO_STANDBY, null, null); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | private synchronized void releaseFuncSta(){ | 
|---|
|  |  |  | List<FuncSta> funcStaList = funcStaService.list(new LambdaQueryWrapper<FuncSta>().eq(FuncSta::getState, FuncStaStateType.OCCUPIED.toString())); | 
|---|
|  |  |  | 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()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 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; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | boolean beIdle = funcStaService.isCanBeIdle(funcSta); | 
|---|
|  |  |  | if (beIdle) { | 
|---|
|  |  |  | funcSta.setState(FuncStaStateType.IDLE.toString()); | 
|---|
|  |  |  | funcSta.setUpdateTime(new Date()); | 
|---|