| | |
| | | |
| | | import com.alibaba.fastjson.JSON; |
| | | import com.baomidou.mybatisplus.mapper.EntityWrapper; |
| | | import com.core.common.SpringUtils; |
| | | import com.zy.asrs.domain.enums.NotifyMsgType; |
| | | import com.zy.asrs.entity.*; |
| | | import com.zy.asrs.service.*; |
| | |
| | | public synchronized boolean shuttleInExecuteStep1(WrkMast wrkMast) { |
| | | if (wrkMast.getWrkSts() == WrkStsType.INBOUND_LIFT_RUN_COMPLETE.sts) { |
| | | //获取目标站 |
| | | ForkLiftStaProtocol liftSta = ForkLiftUtils.getLiftStaByStaNo(wrkMast.getStaNo()); |
| | | LiftStaProtocol liftSta = LiftUtils.getLiftStaByStaNo(wrkMast.getStaNo()); |
| | | if (liftSta == null) { |
| | | News.taskInfo(wrkMast.getWrkNo(), "{}任务,缺少站点信息,禁止派发", wrkMast.getWrkNo()); |
| | | return false; |
| | |
| | | Integer liftNo = wrkMast.getLiftNo(); |
| | | if (liftNo == null) { |
| | | //通过输送线站号获取提升机号 |
| | | liftNo = ForkLiftUtils.getConveyorBindLiftNo(wrkMast.getStaNo()); |
| | | liftNo = LiftUtils.getConveyorBindLiftNo(wrkMast.getStaNo()); |
| | | if (liftNo == null) { |
| | | News.taskInfo(wrkMast.getWrkNo(), "{}任务,未找到匹配的提升机", wrkMast.getWrkNo()); |
| | | return false; |
| | | } |
| | | } |
| | | |
| | | ForkLiftThread forkLiftThread = (ForkLiftThread) SlaveConnection.get(SlaveType.ForkLift, liftNo); |
| | | if (forkLiftThread == null) { |
| | | LiftThread liftThread = (LiftThread) SlaveConnection.get(SlaveType.Lift, liftNo); |
| | | if (liftThread == null) { |
| | | return false; |
| | | } |
| | | ForkLiftProtocol forkLiftProtocol = forkLiftThread.getStatus(); |
| | | if (forkLiftProtocol == null) { |
| | | LiftProtocol liftProtocol = liftThread.getStatus(); |
| | | if (liftProtocol == null) { |
| | | return false; |
| | | } |
| | | |
| | | //判断提升机是否处于出库模式 |
| | | if (!forkLiftProtocol.getIOModeType().equals(ForkLiftIoModeType.OUT)) { |
| | | if (!liftProtocol.getIOModeType().equals(LiftIoModeType.OUT)) { |
| | | News.taskInfo(wrkMast.getWrkNo(), "{}任务,提升机不处于出库模式,禁止出库", wrkMast.getWrkNo()); |
| | | return false; |
| | | } |
| | | |
| | | //获取源站 |
| | | ForkLiftStaProtocol liftSta = ForkLiftUtils.getLiftStaByLev(liftNo, Utils.getLev(wrkMast.getSourceLocNo())); |
| | | LiftStaProtocol liftSta = LiftUtils.getLiftStaByLev(liftNo, Utils.getLev(wrkMast.getSourceLocNo())); |
| | | if (liftSta == null) { |
| | | News.taskInfo(wrkMast.getWrkNo(), "{}任务,缺少站点信息,禁止派发", wrkMast.getWrkNo()); |
| | | return false; |
| | |
| | | assignCommand.setCommands(commands); |
| | | assignCommand.setLiftNo(liftNo); |
| | | assignCommand.setTaskNo(wrkMast.getWrkNo()); |
| | | assignCommand.setTaskMode(ForkLiftTaskModeType.PICK_PUT.id); |
| | | assignCommand.setTaskMode(LiftTaskModeType.PICK_PUT.id); |
| | | |
| | | wrkMast.setWrkSts(WrkStsType.INBOUND_LIFT_RUN.sts);//提升机搬运中 1.生成入库任务 ==> 3.提升机搬运中 |
| | | wrkMast.setSystemMsg("");//清空消息 |
| | |
| | | if (liftNo == null) { |
| | | //未分配提升机 |
| | | Integer staNo = wrkMast.getStaNo(); |
| | | liftNo = ForkLiftUtils.getConveyorBindLiftNo(staNo); |
| | | liftNo = LiftUtils.getConveyorBindLiftNo(staNo); |
| | | if(liftNo == null) { |
| | | News.taskInfo(wrkMast.getWrkNo(), "{}任务,未找到匹配的提升机", wrkMast.getWrkNo()); |
| | | return false; |
| | |
| | | assignCommand.setCommands(commands); |
| | | assignCommand.setLiftNo(liftNo); |
| | | assignCommand.setTaskNo(wrkMast.getWrkNo()); |
| | | assignCommand.setTaskMode(ForkLiftTaskModeType.PICK_PUT.id); |
| | | assignCommand.setTaskMode(LiftTaskModeType.PICK_PUT.id); |
| | | |
| | | wrkMast.setWrkSts(WrkStsType.OUTBOUND_LIFT_RUN.sts);//提升机搬运中 103.生成入库任务 ==> 104.提升机搬运中 |
| | | wrkMast.setShuttleNo(null);//释放小车 |
| | |
| | | News.error("提升机已确认且任务完成状态,复位失败,但未找到工作档。提升机号={},工作号={}", liftProtocol.getLiftNo(), liftProtocol.getTaskNo()); |
| | | } |
| | | }else { |
| | | boolean checkPreviewDispatchForkLift = commonService.checkWorkNoContainMk(liftProtocol.getTaskNo(), WrkIoType.PREVIEW_LIFT_MOVE.id); |
| | | if (checkPreviewDispatchForkLift) { |
| | | boolean checkPreviewDispatchLift = commonService.checkWorkNoContainMk(liftProtocol.getTaskNo(), WrkIoType.PREVIEW_LIFT_MOVE.id); |
| | | if (checkPreviewDispatchLift) { |
| | | //属于提升机预调度移动任务 |
| | | //无工作档支撑,直接确认完成 |
| | | liftThread.setSyncTaskNo(0); |
| | |
| | | */ |
| | | private void recLiftErr() { |
| | | Date now = new Date(); |
| | | List<DeviceConfig> forkliftList = deviceConfigService.selectList(new EntityWrapper<DeviceConfig>() |
| | | .eq("device_type", String.valueOf(SlaveType.ForkLift))); |
| | | for (DeviceConfig device : forkliftList) { |
| | | List<DeviceConfig> liftList = deviceConfigService.selectList(new EntityWrapper<DeviceConfig>() |
| | | .eq("device_type", String.valueOf(SlaveType.Lift))); |
| | | for (DeviceConfig device : liftList) { |
| | | // 获取提升机信息 |
| | | ForkLiftThread forkLiftThread = (ForkLiftThread) SlaveConnection.get(SlaveType.ForkLift, device.getDeviceNo()); |
| | | if (forkLiftThread == null) { |
| | | LiftThread liftThread = (LiftThread) SlaveConnection.get(SlaveType.Lift, device.getDeviceNo()); |
| | | if (liftThread == null) { |
| | | continue; |
| | | } |
| | | ForkLiftProtocol forkLiftProtocol = forkLiftThread.getStatus(); |
| | | if (forkLiftProtocol == null) { |
| | | LiftProtocol liftProtocol = liftThread.getStatus(); |
| | | if (liftProtocol == null) { |
| | | continue; |
| | | } |
| | | |
| | | if (forkLiftProtocol.getTaskNo() != 0) { |
| | | if (liftProtocol.getTaskNo() != 0) { |
| | | //有任务 |
| | | BasLiftErrLog latest = basLiftErrLogService.findLatestByTaskNo(device.getDeviceNo(), forkLiftProtocol.getTaskNo()); |
| | | BasLiftErrLog latest = basLiftErrLogService.findLatestByTaskNo(device.getDeviceNo(), liftProtocol.getTaskNo()); |
| | | // 有异常 |
| | | if (latest == null) { |
| | | if (forkLiftProtocol.getErrorCode() != null && forkLiftProtocol.getErrorCode() != 0) { |
| | | WrkMast wrkMast = wrkMastService.selectByWorkNo(forkLiftProtocol.getWrkNo()); |
| | | if (liftProtocol.getErrorCode() != null && liftProtocol.getErrorCode() != 0) { |
| | | WrkMast wrkMast = wrkMastService.selectByWorkNo(liftProtocol.getTaskNo()); |
| | | if (wrkMast == null) { |
| | | continue; |
| | | } |
| | | |
| | | BasLiftErr basLiftErr = basLiftErrService.queryByCode(forkLiftProtocol.getErrorCode()); |
| | | BasLiftErr basLiftErr = basLiftErrService.queryByCode(liftProtocol.getErrorCode()); |
| | | String errName = basLiftErr==null? "未知异常":basLiftErr.getErrName(); |
| | | |
| | | BasLiftErrLog basLiftErrLog = new BasLiftErrLog( |
| | |
| | | now, // 修改时间 |
| | | null, // 修改人员 |
| | | "任务中异常", // 备注 |
| | | JSON.toJSONString(forkLiftProtocol) // 系统状态数据 |
| | | JSON.toJSONString(liftProtocol) // 系统状态数据 |
| | | ); |
| | | if (!basLiftErrLogService.insert(basLiftErrLog)) { |
| | | News.error("提升机plc异常记录失败 ===>> [id:{}] [error:{}]", device.getDeviceNo(), errName); |
| | |
| | | } |
| | | } else { |
| | | // 异常修复 |
| | | if (forkLiftProtocol.getErrorCode() == null || forkLiftProtocol.getErrorCode() == 0) { |
| | | if (liftProtocol.getErrorCode() == null || liftProtocol.getErrorCode() == 0) { |
| | | latest.setEndTime(now); |
| | | latest.setUpdateTime(now); |
| | | latest.setStatus(2); |