|  |  |  | 
|---|
|  |  |  | import com.zy.asrs.common.utils.HttpHandler; | 
|---|
|  |  |  | import com.zy.asrs.framework.common.Cools; | 
|---|
|  |  |  | import com.zy.asrs.framework.common.SnowflakeIdWorker; | 
|---|
|  |  |  | import com.zy.asrs.framework.exception.CoolException; | 
|---|
|  |  |  | import com.zy.asrs.wcs.core.domain.dto.MatDto; | 
|---|
|  |  |  | import com.zy.asrs.wcs.core.domain.dto.RedisMapDto; | 
|---|
|  |  |  | import com.zy.asrs.wcs.core.domain.dto.StaDto; | 
|---|
|  |  |  | import com.zy.asrs.wcs.core.entity.*; | 
|---|
|  |  |  | import com.zy.asrs.wcs.core.kernel.AnalyzeService; | 
|---|
|  |  |  | import com.zy.asrs.wcs.core.model.MapNode; | 
|---|
|  |  |  | import com.zy.asrs.wcs.core.model.enums.DeviceCtgType; | 
|---|
|  |  |  | import com.zy.asrs.wcs.core.model.enums.MotionStsType; | 
|---|
|  |  |  | import com.zy.asrs.wcs.core.model.enums.TaskCtgType; | 
|---|
|  |  |  | import com.zy.asrs.wcs.core.model.enums.TaskStsType; | 
|---|
|  |  |  | import com.zy.asrs.wcs.core.model.enums.*; | 
|---|
|  |  |  | import com.zy.asrs.wcs.core.service.*; | 
|---|
|  |  |  | import com.zy.asrs.wcs.core.utils.RedisUtil; | 
|---|
|  |  |  | import com.zy.asrs.wcs.core.utils.ShuttleDispatcher; | 
|---|
|  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private BasConveyorStaService basConveyorStaService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private BasConveyorPathService basConveyorPathService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private BasLedService basLedService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private DeviceBarcodeService deviceBarcodeService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 组托 | 
|---|
|  |  |  | 
|---|
|  |  |  | Integer code = jsonObject.getInteger("code"); | 
|---|
|  |  |  | if (code.equals(200)) { | 
|---|
|  |  |  | StartupDto dto = jsonObject.getObject("data", StartupDto.class); | 
|---|
|  |  |  | devpThread.writeWorkSta(staProtocol.getSiteId(), dto.getWorkNo().shortValue(), dto.getStaNo().shortValue()); | 
|---|
|  |  |  | devpThread.setPakMk(staProtocol.getSiteId(), false); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } else if (code == 500) { | 
|---|
|  |  |  | //获取输送路径 | 
|---|
|  |  |  | BasConveyorPath conveyorPath = basConveyorPathService.getOne(new LambdaQueryWrapper<BasConveyorPath>() | 
|---|
|  |  |  | .eq(BasConveyorPath::getTypeNo, TaskCtgType.IN.val()) | 
|---|
|  |  |  | .eq(BasConveyorPath::getDeviceId, devp.getId()) | 
|---|
|  |  |  | .eq(BasConveyorPath::getStnNo, staProtocol.getSiteId())); | 
|---|
|  |  |  | if (conveyorPath == null) { | 
|---|
|  |  |  | News.error("输送路径不存在"); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | devpThread.writeWorkSta(staProtocol.getSiteId(), dto.getWorkNo().shortValue(), conveyorPath.getDeviceStn().shortValue()); | 
|---|
|  |  |  | devpThread.setPakMk(staProtocol.getSiteId(), false); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | if (ledThread != null) { | 
|---|
|  |  |  | String errorMsg = jsonObject.getString("msg"); | 
|---|
|  |  |  | if (!Cools.isEmpty(errorMsg)) { | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | News.error("请求接口失败!!!url:{};request:{};response:{}", wmsUrl + "/rpc/pakin/loc/v2", JSON.toJSONString(param), response); | 
|---|
|  |  |  | } else if (code == 700) { | 
|---|
|  |  |  | //                            staProtocol.setWorkNo((short) 32002); | 
|---|
|  |  |  | //                            staProtocol.setRollback102(1);//102站回退信号 | 
|---|
|  |  |  | //                            devpThread.setPakMk(staProtocol.getSiteId(), false); | 
|---|
|  |  |  | //                            MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(5, staProtocol)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // led 异常显示 | 
|---|
|  |  |  | if (ledThread != null) { | 
|---|
|  |  |  | String errorMsg = barcode + "托盘识别异常,请先进行组托!"; | 
|---|
|  |  |  | ledThread.error(errorMsg); | 
|---|
|  |  |  | ledThread.setLedMk(false); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | 
|---|
|  |  |  | // 解析入库工作档 | 
|---|
|  |  |  | public synchronized void analyzeInBoundTask() { | 
|---|
|  |  |  | for (Task task : taskService.selectWaitAnalyzeInBoundTask()) { | 
|---|
|  |  |  | BasConveyorSta basConveyorSta = basConveyorStaService.getOne(new LambdaQueryWrapper<BasConveyorSta>().eq(BasConveyorSta::getSiteNo, task.getDestSite())); | 
|---|
|  |  |  | if (basConveyorSta == null) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | BasConveyor basConveyor = basConveyorService.getById(basConveyorSta.getConveyorId()); | 
|---|
|  |  |  | if (basConveyor == null) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | DeviceBarcode deviceBarcode = deviceBarcodeService.getById(basConveyorSta.getBarcodeId()); | 
|---|
|  |  |  | if (deviceBarcode == null) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | BarcodeThread barcodeThread = (BarcodeThread) SlaveConnection.get(SlaveType.Barcode, Integer.parseInt(deviceBarcode.getDeviceId())); | 
|---|
|  |  |  | if (barcodeThread == null) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!barcodeThread.getBarcode().equals(task.getZpallet())) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | DevpThread devpThread = (DevpThread) SlaveConnection.get(SlaveType.Conveyor, basConveyor.getDeviceId().intValue()); | 
|---|
|  |  |  | if (devpThread == null) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | StaProtocol staProtocol = devpThread.getStation().get(basConveyorSta.getSiteNo()); | 
|---|
|  |  |  | if (staProtocol == null) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!(staProtocol.isAutoing() | 
|---|
|  |  |  | && staProtocol.isLoading() | 
|---|
|  |  |  | && staProtocol.isInEnable())) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (Cools.isEmpty(task.getShuttleNo())) { | 
|---|
|  |  |  | //分配小车 | 
|---|
|  |  |  | //搜索空闲车 | 
|---|
|  |  |  | ShuttleThread shuttleThread = shuttleDispatcher.searchIdleShuttle(task); | 
|---|
|  |  |  | if (shuttleThread == null) { | 
|---|
|  |  |  | News.info("{}任务未找到空闲穿梭车", task.getTaskNo()); | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | task.setShuttleNo(Integer.valueOf(shuttleThread.getDevice().getDeviceNo()));//保存穿梭车号 | 
|---|
|  |  |  | task.setUpdateTime(new Date()); | 
|---|
|  |  |  | if (!taskService.updateById(task)) { | 
|---|
|  |  |  | News.info("{}任务更新穿梭车号失败", task.getTaskNo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // generate motion list | 
|---|
|  |  |  | List<Motion> motionList = analyzeService.generateMotion(task); | 
|---|
|  |  |  | if (motionList.isEmpty()) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | motionService.batchInsert(motionList, task.getUuid(), Integer.valueOf(task.getTaskNo())); | 
|---|
|  |  |  | motionService.batchInsert(motionList, task.getUuid(), Integer.valueOf(task.getTaskNo()), task.getHostId()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 更新工作主档 | 
|---|
|  |  |  | task.setTaskSts(TaskStsType.ANALYZE_INBOUND.sts); // 工作状态 | 
|---|
|  |  |  | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | DevpThread devpThread = (DevpThread) SlaveConnection.get(SlaveType.Conveyor, originStaObj.getConveyorId().intValue()); | 
|---|
|  |  |  | BasConveyor basConveyor = basConveyorService.getById(originStaObj.getConveyorId()); | 
|---|
|  |  |  | if(basConveyor == null) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | DevpThread devpThread = (DevpThread) SlaveConnection.get(SlaveType.Conveyor, basConveyor.getDeviceId().intValue()); | 
|---|
|  |  |  | StaProtocol staProtocol = devpThread.getStation().get(Integer.parseInt(task.getOriginSite()));//源站 | 
|---|
|  |  |  | StaProtocol staProtocol1 = devpThread.getStation().get(Integer.parseInt(task.getDestSite()));//目标站 | 
|---|
|  |  |  | if (staProtocol == null || staProtocol1 == null) { | 
|---|
|  |  |  | //            StaProtocol staProtocol1 = devpThread.getStation().get(Integer.parseInt(task.getDestSite()));//目标站 | 
|---|
|  |  |  | if (staProtocol == null) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | staProtocol = staProtocol.clone(); | 
|---|
|  |  |  | staProtocol1 = staProtocol1.clone(); | 
|---|
|  |  |  | //                staProtocol1 = staProtocol1.clone(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 判断堆垛机出库站状态 | 
|---|
|  |  |  | if (staProtocol.isAutoing() && !staProtocol.isLoading() && staProtocol.getWorkNo() == 0 && staProtocol.isOutEnable()) { | 
|---|
|  |  |  | if (!(staProtocol1.isAutoing() && !staProtocol1.isLoading() && staProtocol1.getWorkNo() == 0 && staProtocol1.isOutEnable())) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //                if (!(staProtocol1.isAutoing() && !staProtocol1.isLoading() && staProtocol1.getWorkNo() == 0 && staProtocol1.isOutEnable())) { | 
|---|
|  |  |  | //                    continue; | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //                //同库位组校验 | 
|---|
|  |  |  | //                List<String> outerLoc = Utils.getGroupOuterLoc(wrkMast.getSourceLocNo()); | 
|---|
|  |  |  | 
|---|
|  |  |  | log.error("出库 ===>> 暂时没有空闲小车, 任务号={}", task.getTaskNo()); | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | motionService.batchInsert(motionList, task.getUuid(), Integer.valueOf(task.getTaskNo())); | 
|---|
|  |  |  | motionService.batchInsert(motionList, task.getUuid(), Integer.valueOf(task.getTaskNo()), task.getHostId()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 更新工作主档 | 
|---|
|  |  |  | task.setTaskSts(TaskStsType.ANALYZE_OUTBOUND.sts); // 工作状态 | 
|---|
|  |  |  | 
|---|
|  |  |  | // 解析小车移动工作档 | 
|---|
|  |  |  | public synchronized void analyzeMoveTask() { | 
|---|
|  |  |  | for (Task task : taskService.selectWaitAnalyzeMoveTask()) { | 
|---|
|  |  |  | if (Cools.isEmpty(task.getShuttleNo())) { | 
|---|
|  |  |  | //分配小车 | 
|---|
|  |  |  | //搜索空闲车 | 
|---|
|  |  |  | ShuttleThread shuttleThread = shuttleDispatcher.searchIdleShuttle(task); | 
|---|
|  |  |  | if (shuttleThread == null) { | 
|---|
|  |  |  | News.info("{}任务未找到空闲穿梭车", task.getTaskNo()); | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | task.setShuttleNo(Integer.valueOf(shuttleThread.getDevice().getDeviceNo()));//保存穿梭车号 | 
|---|
|  |  |  | task.setUpdateTime(new Date()); | 
|---|
|  |  |  | if (!taskService.updateById(task)) { | 
|---|
|  |  |  | News.info("{}任务更新穿梭车号失败", task.getTaskNo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // generate motion list | 
|---|
|  |  |  | List<Motion> motionList = analyzeService.generateMotion(task); | 
|---|
|  |  |  | List<Motion> motionList = analyzeService.generateShuttleMoveMotion(task); | 
|---|
|  |  |  | if (motionList.isEmpty()) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | motionService.batchInsert(motionList, task.getUuid(), Integer.valueOf(task.getTaskNo())); | 
|---|
|  |  |  | motionService.batchInsert(motionList, task.getUuid(), Integer.valueOf(task.getTaskNo()), task.getHostId()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 更新工作主档 | 
|---|
|  |  |  | task.setTaskSts(TaskStsType.ANALYZE_MOVE.sts); // 工作状态 | 
|---|
|  |  |  | 
|---|
|  |  |  | * 四向穿梭车电量检测 ===>> 发起充电 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public synchronized void loopShuttleCharge() { | 
|---|
|  |  |  | // 获取充电桩库位类型 | 
|---|
|  |  |  | LocCtg locCtg = locCtgService.getOne(new LambdaQueryWrapper<LocCtg>() | 
|---|
|  |  |  | .eq(LocCtg::getFlag, "CHARGE") | 
|---|
|  |  |  | .eq(LocCtg::getStatus, 1)); | 
|---|
|  |  |  | if (locCtg == null) { | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //获取充电任务类型 | 
|---|
|  |  |  | TaskCtg taskCtg = taskCtgService.getOne(new LambdaQueryWrapper<TaskCtg>() | 
|---|
|  |  |  | .eq(TaskCtg::getFlag, String.valueOf(TaskCtgType.CHARGE)) | 
|---|
|  |  |  | 
|---|
|  |  |  | //搜索小车当前楼层充电桩 | 
|---|
|  |  |  | ArrayList<Loc> allChargeLoc = new ArrayList<>(); | 
|---|
|  |  |  | List<Loc> list1 = locService.list(new LambdaQueryWrapper<Loc>() | 
|---|
|  |  |  | .eq(Loc::getLocCtg, locCtg.getId()) | 
|---|
|  |  |  | .eq(Loc::getLocSts, LocStsType.C.val()) | 
|---|
|  |  |  | .eq(Loc::getStatus, 1) | 
|---|
|  |  |  | .eq(Loc::getLev, lev)); | 
|---|
|  |  |  | if (!list1.isEmpty()) { | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //搜索其他楼层充电桩 | 
|---|
|  |  |  | List<Loc> list2 = locService.list(new LambdaQueryWrapper<Loc>() | 
|---|
|  |  |  | .eq(Loc::getLocCtg, locCtg.getId()) | 
|---|
|  |  |  | .eq(Loc::getLocSts, LocStsType.C.val()) | 
|---|
|  |  |  | .eq(Loc::getStatus, 1) | 
|---|
|  |  |  | .notIn(Loc::getLev, lev)); | 
|---|
|  |  |  | if (!list2.isEmpty()) { | 
|---|
|  |  |  | 
|---|
|  |  |  | News.error("保存{}号四向穿梭车充电任务失败!!!", device.getDeviceNo()); | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | motionService.batchInsert(motionList, task.getUuid(), Integer.valueOf(task.getTaskNo())); | 
|---|
|  |  |  | motionService.batchInsert(motionList, task.getUuid(), Integer.valueOf(task.getTaskNo()), task.getHostId()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | task.setTaskSts(TaskStsType.ANALYZE_CHARGE.sts); | 
|---|
|  |  |  | if (!taskService.save(task)) { | 
|---|
|  |  |  | 
|---|
|  |  |  | News.error("保存{}号四向穿梭车迁移任务失败!!!", device.getDeviceNo()); | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | motionService.batchInsert(motionList, task.getUuid(), Integer.valueOf(task.getTaskNo())); | 
|---|
|  |  |  | motionService.batchInsert(motionList, task.getUuid(), Integer.valueOf(task.getTaskNo()), task.getHostId()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | task.setTaskSts(TaskStsType.ANALYZE_MOVE.sts); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | .eq(BasLed::getDeviceId, ledDevice.getId())); | 
|---|
|  |  |  | List<Integer> staArr = JSON.parseArray(led.getSta(), Integer.class); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | BasConveyor basConveyor = basConveyorService.getById(led.getConveyorId().intValue()); | 
|---|
|  |  |  | if (basConveyor == null) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 获取输送线plc线程 | 
|---|
|  |  |  | DevpThread devpThread = (DevpThread) SlaveConnection.get(SlaveType.Conveyor, led.getConveyorId().intValue()); | 
|---|
|  |  |  | DevpThread devpThread = (DevpThread) SlaveConnection.get(SlaveType.Conveyor, basConveyor.getDeviceId().intValue()); | 
|---|
|  |  |  | // 命令集合 | 
|---|
|  |  |  | List<LedCommand> commands = new ArrayList<>(); | 
|---|
|  |  |  | // 工作档集合 | 
|---|
|  |  |  | 
|---|
|  |  |  | .eq(BasLed::getDeviceId, ledDevice.getId())); | 
|---|
|  |  |  | List<Integer> staArr = JSON.parseArray(led.getSta(), Integer.class); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | BasConveyor basConveyor = basConveyorService.getById(led.getConveyorId().intValue()); | 
|---|
|  |  |  | if (basConveyor == null) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 获取输送线plc线程 | 
|---|
|  |  |  | DevpThread devpThread = (DevpThread) SlaveConnection.get(SlaveType.Conveyor, led.getConveyorId().intValue()); | 
|---|
|  |  |  | DevpThread devpThread = (DevpThread) SlaveConnection.get(SlaveType.Conveyor, basConveyor.getDeviceId().intValue()); | 
|---|
|  |  |  | // 命令集合 | 
|---|
|  |  |  | boolean reset = true; | 
|---|
|  |  |  | for (Integer staNo : staArr) { | 
|---|
|  |  |  | 
|---|
|  |  |  | .eq(BasLed::getDeviceId, ledDevice.getId())); | 
|---|
|  |  |  | List<Integer> staArr = JSON.parseArray(led.getSta(), Integer.class); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | BasConveyor basConveyor = basConveyorService.getById(led.getConveyorId()); | 
|---|
|  |  |  | if (basConveyor == null) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 获取输送线plc线程 | 
|---|
|  |  |  | DevpThread devpThread = (DevpThread) SlaveConnection.get(SlaveType.Conveyor, led.getConveyorId().intValue()); | 
|---|
|  |  |  | DevpThread devpThread = (DevpThread) SlaveConnection.get(SlaveType.Conveyor, basConveyor.getDeviceId().intValue()); | 
|---|
|  |  |  | // 命令集合 | 
|---|
|  |  |  | boolean reset = true; | 
|---|
|  |  |  | for (Integer staNo : staArr) { | 
|---|