| | |
| | | @Autowired |
| | | private BasDevpOptService basDevpOptService; |
| | | @Autowired |
| | | private BasRgvOptService basRgvOptService; |
| | | @Autowired |
| | | private MatService matService; |
| | | |
| | | @Value("${wms.url}") |
| | |
| | | |
| | | } |
| | | |
| | | if(rgvProtocol.getStatusType1() == RgvStatusType.IDLE && |
| | | rgvProtocol.getModeType() == RgvModeType.AUTO && rgvThread.isPakMk() |
| | | && rgvThread.isPaking() && basRgv.getPakAll().equals("1")){ |
| | | RgvThread rgvThread1 = (RgvThread) SlaveConnection.get(SlaveType.Rgv, rgv.getId()); |
| | | RgvProtocol rgvProtocol1 = rgvThread.getRgvProtocol(); |
| | | if (rgvProtocol1 == null) { |
| | | continue; |
| | | } |
| | | if(rgvProtocol1.getStatusType1() == RgvStatusType.IDLE && |
| | | rgvProtocol1.getModeType() == RgvModeType.AUTO && rgvThread1.isPakMk() |
| | | && rgvThread1.isPaking() && basRgv.getPakAll().equals("1")){ |
| | | if(basRgv.getPakOut().equals("1") && basRgv.getPakIn().equals("1")){ |
| | | rgvPreSchedulingIn(rgv, rgvProtocol);//若暂无下发任务预调度提前到取货点 |
| | | if (rgvProtocol.getLastIo().equals("I")) { |
| | |
| | | |
| | | sign = rgvTakeFullAll(basRgvMap.getRgvNo(), wrkMastSta); //命令下发 |
| | | if (sign){ |
| | | if(wrkMastSta.getMk() == 1){//若已执行 |
| | | if(wrkMastSta.getMk() != null && wrkMastSta.getMk() == 1){//若已执行 |
| | | basRgv.setPakAll("1"); |
| | | basRgvService.updateById(basRgv); |
| | | } |
| | |
| | | System.out.println("小车下发命令时间:" + |
| | | new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS").format(now)); |
| | | } |
| | | EntityWrapper<BasRgvOpt> entityWrapper = new EntityWrapper<>(); |
| | | entityWrapper.eq("rgv_no", rgvId) |
| | | .orderBy("send_time"); |
| | | BasRgvOpt basRgvOpt = basRgvOptService.selectOne(entityWrapper); |
| | | // 防止重复下发命令 |
| | | if (basRgvOpt != null) { |
| | | // 获取最新记录的 mode 对应的任务类型 |
| | | RgvTaskStatusType latestTaskStatus = RgvTaskStatusType.valueOf(basRgvOpt.getMode()); |
| | | // 判断当前命令与最新记录是否相同 |
| | | if (latestTaskStatus == type && basRgvOpt.getPosSta().equals(wrkMastSta.getWorkSta())) { |
| | | // 如果最新记录的 mode 和 posSta 与当前命令相同,认为是重复命令 |
| | | log.error("命令重复下发,当前命令与最新记录相同,任务不下发!"); |
| | | return false; |
| | | } |
| | | } |
| | | |
| | | rgvCommand.setTaskNo(Math.toIntExact(wrkMastSta.getWrkNo())); // 工位工作号 |
| | | rgvCommand.setTaskStatus(type); // 工位任务模式: 取货 |
| | |
| | | continue; |
| | | } |
| | | List<BasArm> basArmList = basArmService.selectList(new EntityWrapper<BasArm>().eq("arm_no",armSta.getArmNo())); |
| | | boolean sign = true; |
| | | BasArmMast basArmMastFinal = null; |
| | | Integer num = 0; |
| | | for (BasArm basArm : basArmList){ |
| | | // if (basArm.getStaNo()==2){//NG |
| | | // continue; |
| | | // } |
| | | LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>().eq("loc_no", basArm.getStaNoSou())); |
| | | if (Cools.isEmpty(locMast) || !locMast.getLocSts().equals("D")){ |
| | | continue; |
| | |
| | | basArmMast.setArmNo(basArm.getArmNo()); |
| | | basArmMast.setStaNo(basArm.getStaNoSou()); |
| | | basArmMast.setSortingLine(basArm.getSortingLineSou()); |
| | | basArmMastService.insert(basArmMast); |
| | | sign = false; |
| | | if(basArmMastList2.size() > num){ |
| | | basArmMastFinal = basArmMast; |
| | | } |
| | | } |
| | | if(basArmMastFinal != null){ |
| | | basArmMastService.insert(basArmMastFinal); |
| | | break; |
| | | } |
| | | // if (sign){ |
| | | // for (BasArm basArm : basArmList){ |
| | | // if (basArm.getStaNo()==2){//NG |
| | | // LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>().eq("loc_no", basArm.getStaNoSou())); |
| | | // if (Cools.isEmpty(locMast) || !locMast.getLocSts().equals("D")){ |
| | | // continue; |
| | | // } |
| | | // BasArmMast basArmMast = new BasArmMast(armBarcodeTwoParam); |
| | | // basArmMast.setArmNo(basArm.getArmNo()); |
| | | // basArmMast.setStaNo(basArm.getStaNoSou()); |
| | | // basArmMast.setSortingLine(basArm.getSortingLineSou()); |
| | | // basArmMastService.insert(basArmMast); |
| | | // break; |
| | | // } |
| | | // } |
| | | // } |
| | | } |
| | | } |
| | | } catch (Exception e){ |
| | |
| | | String barcode = locMastEnd.getBarcode(); |
| | | if(!Cools.isEmpty(barcode)) { |
| | | if("NG".endsWith(barcode) || "NoRead".equals(barcode) || "0".equals(barcode)) { |
| | | armTaskAssignmentCallApiLogSave(locMastEnd, "取货条码为空", basArm.getStaNoSou()+"码垛位置,===》托盘条码为空", false); |
| | | log.error( "取货条码为空", basArm.getStaNoSou()); |
| | | continue; |
| | | } |
| | | } else { |
| | | armTaskAssignmentCallApiLogSave(locMastEnd, "取货条码为空", basArm.getStaNoSou()+"码垛位置,===》托盘条码为空", false); |
| | | log.error( "取货条码为空", basArm.getStaNoSou()); |
| | | continue; |
| | | } |
| | | |
| | |
| | | SearchLocParam param = new SearchLocParam(); |
| | | param.setBarcode(staProtocol.getWorkNo().toString()); |
| | | param.setIoType(1); |
| | | param.setOutArea(wrkMast.getCtnKind()); |
| | | param.setSourceStaNo(outStaAgv.getStaNo()); |
| | | param.setLocType1(locTypeDto.getLocType1()); |
| | | String response = new HttpHandler.Builder() |
| | |
| | | SearchLocParam param = new SearchLocParam(); |
| | | param.setBarcode(wrkMast.getBarcode()); |
| | | param.setIoType(1); |
| | | param.setOutArea(wrkMast.getCtnKind()); |
| | | param.setSourceStaNo(outStaAgv.getStaNo()); |
| | | param.setLocType1(locTypeDto.getLocType1()); |
| | | String response = new HttpHandler.Builder() |