|  |  |  | 
|---|
|  |  |  | //                                MessageQueue.offer(SlaveType.Led, inSta.getLed(), new Task(3, errorMsg)); | 
|---|
|  |  |  | //                            } | 
|---|
|  |  |  | log.error(barcode + "托盘识别异常,请先进行组托!"); | 
|---|
|  |  |  | // led 异常显示 | 
|---|
|  |  |  | ledThread = (LedThread) SlaveConnection.get(SlaveType.Led, inSta.getLed()); | 
|---|
|  |  |  | if (ledThread != null) { | 
|---|
|  |  |  | String errorMsg = barcode + "托盘识别异常,请先进行组托!"; | 
|---|
|  |  |  | MessageQueue.offer(SlaveType.Led, inSta.getLed(), new Task(3, errorMsg)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | log.error("请求接口失败!!!url:{};request:{};response:{}", wmsUrl + "/rpc/pakin/loc/v1", JSON.toJSONString(param), response); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | log.error("{}任务出库失败,浅库位堵塞!浅库位号:{}", wrkMast.getWrkNo(), shallowLocNo); | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } else if (shallowLoc.getLocSts().equals("Q") || shallowLoc.getLocSts().equals("S")) { | 
|---|
|  |  |  | WrkMast waitWrkMast = wrkMastMapper.selectByLocNo(shallowLocNo); | 
|---|
|  |  |  | WrkMast waitWrkMast = wrkMastMapper.selectByLocNo1(shallowLocNo); | 
|---|
|  |  |  | if (null != waitWrkMast && (waitWrkMast.getWrkSts() == 4 || waitWrkMast.getWrkSts() == 5)) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 站点条件判断 | 
|---|
|  |  |  | if (staProtocol.isAutoing() && staProtocol.isLoading() && staProtocol.isInEnable() | 
|---|
|  |  |  | && staProtocol.isEmptyMk() && (staProtocol.getWorkNo() >= 9990 | 
|---|
|  |  |  | && staProtocol.getWorkNo() <= 9999)) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | LocTypeDto locTypeDto = new LocTypeDto(staProtocol); | 
|---|
|  |  |  | && staProtocol.isEmptyInPalletRequire() && staProtocol.getWorkNo() == 0) { | 
|---|
|  |  |  | List<StaDesc> staDescs = staDescService.selectList(new EntityWrapper<StaDesc>().eq("type_no", 10).eq("stn_no", sta.getStaNo())); | 
|---|
|  |  |  | for (StaDesc staDesc:staDescs){ | 
|---|
|  |  |  |  | 
|---|
|  |  |  | SearchLocParam param = new SearchLocParam(); | 
|---|
|  |  |  | param.setIoType(10); | 
|---|
|  |  |  | param.setSourceStaNo(sta.getStaNo()); | 
|---|
|  |  |  | param.setLocType1(locTypeDto.getLocType1()); | 
|---|
|  |  |  | String response = new HttpHandler.Builder() | 
|---|
|  |  |  | .setUri(wmsUrl) | 
|---|
|  |  |  | .setPath("/rpc/pakin/loc/v1") | 
|---|
|  |  |  | .setJson(JSON.toJSONString(param)) | 
|---|
|  |  |  | .build() | 
|---|
|  |  |  | .doPost(); | 
|---|
|  |  |  | JSONObject jsonObject = JSON.parseObject(response); | 
|---|
|  |  |  | if (jsonObject.getInteger("code").equals(200)) { | 
|---|
|  |  |  | StartupDto dto = jsonObject.getObject("data", StartupDto.class); | 
|---|
|  |  |  | BasDevp basDevp = basDevpService.selectOne(new EntityWrapper<BasDevp>().eq("dev_no", staDesc.getCrnStn())); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (basDevp.getAutoing().equals("Y") && basDevp.getLoading().equals("N") | 
|---|
|  |  |  | && basDevp.getWrkNo() == 0 && basDevp.getCanining().equals("Y")){ | 
|---|
|  |  |  | // 更新站点信息 且 下发plc命令 | 
|---|
|  |  |  | staProtocol.setWorkNo(dto.getWorkNo().shortValue()); | 
|---|
|  |  |  | staProtocol.setStaNo(dto.getStaNo().shortValue()); | 
|---|
|  |  |  | staProtocol.setWorkNo((short) 9997); | 
|---|
|  |  |  | //                            staProtocol.setStaNo(basDevp.getDevNo().shortValue()); | 
|---|
|  |  |  | staProtocol.setStaNo((short) 1013); | 
|---|
|  |  |  | devpThread.setPakMk(staProtocol.getSiteId(), false); | 
|---|
|  |  |  | boolean result = MessageQueue.offer(SlaveType.Devp, devpThread.getSlave().getId(), new Task(2, staProtocol)); | 
|---|
|  |  |  | if (!result) { | 
|---|
|  |  |  | throw new CoolException("更新plc站点信息失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | log.error("请求接口失败!!!url:{};request:{};response:{}", wmsUrl + "/rpc/pakin/loc/v1", JSON.toJSONString(param), response); | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //                    try { | 
|---|
|  |  |  | //                        LocTypeDto locTypeDto = new LocTypeDto(staProtocol); | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //                        SearchLocParam param = new SearchLocParam(); | 
|---|
|  |  |  | //                        param.setIoType(10); | 
|---|
|  |  |  | //                        param.setSourceStaNo(sta.getStaNo()); | 
|---|
|  |  |  | //                        param.setLocType1(locTypeDto.getLocType1()); | 
|---|
|  |  |  | //                        String response = new HttpHandler.Builder() | 
|---|
|  |  |  | //                                .setUri(wmsUrl) | 
|---|
|  |  |  | //                                .setPath("/rpc/pakin/loc/v1") | 
|---|
|  |  |  | //                                .setJson(JSON.toJSONString(param)) | 
|---|
|  |  |  | //                                .build() | 
|---|
|  |  |  | //                                .doPost(); | 
|---|
|  |  |  | //                        JSONObject jsonObject = JSON.parseObject(response); | 
|---|
|  |  |  | //                        if (jsonObject.getInteger("code").equals(200)) { | 
|---|
|  |  |  | //                            StartupDto dto = jsonObject.getObject("data", StartupDto.class); | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //                            // 更新站点信息 且 下发plc命令 | 
|---|
|  |  |  | //                            staProtocol.setWorkNo(dto.getWorkNo().shortValue()); | 
|---|
|  |  |  | //                            staProtocol.setStaNo(dto.getStaNo().shortValue()); | 
|---|
|  |  |  | //                            devpThread.setPakMk(staProtocol.getSiteId(), false); | 
|---|
|  |  |  | //                            boolean result = MessageQueue.offer(SlaveType.Devp, devpThread.getSlave().getId(), new Task(2, staProtocol)); | 
|---|
|  |  |  | //                            if (!result) { | 
|---|
|  |  |  | //                                throw new CoolException("更新plc站点信息失败"); | 
|---|
|  |  |  | //                            } | 
|---|
|  |  |  | //                        } else { | 
|---|
|  |  |  | //                            log.error("请求接口失败!!!url:{};request:{};response:{}", wmsUrl + "/rpc/pakin/loc/v1", JSON.toJSONString(param), response); | 
|---|
|  |  |  | //                        } | 
|---|
|  |  |  | //                    } catch (Exception e) { | 
|---|
|  |  |  | //                        e.printStackTrace(); | 
|---|
|  |  |  | //                        TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); | 
|---|
|  |  |  | //                    } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (staProtocol.isAutoing()  //自动 | 
|---|
|  |  |  | && !staProtocol.isLoading()  //无物 | 
|---|
|  |  |  | && staProtocol.isOutEnable()  //空托盘需求信号 | 
|---|
|  |  |  | && staProtocol.isEmptyMk() | 
|---|
|  |  |  | && staProtocol.isEmptyOutPalletRequire()  //空托盘需求信号 | 
|---|
|  |  |  | //                        && staProtocol.isEmptyMk() | 
|---|
|  |  |  | && staProtocol.getWorkNo() == 0 | 
|---|
|  |  |  | ) { | 
|---|
|  |  |  | WrkMast pakoutEmpty = wrkMastMapper.selectPakoutEmpty(sta.getStaNo()); | 
|---|
|  |  |  | if (null != pakoutEmpty) { | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<StaDesc> staDescs = staDescService.selectList(new EntityWrapper<StaDesc>().eq("stn_no", sta.getStaNo())); | 
|---|
|  |  |  | for (StaDesc staDesc: staDescs){ | 
|---|
|  |  |  | BasCrnp basCrnp = basCrnpService.selectOne(new EntityWrapper<BasCrnp>().eq("crn_no", staDesc.getCrnNo())); | 
|---|
|  |  |  | if (!basCrnp.getCrnSts().equals(3) || basCrnp.getCrnErr() != 0){ | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | HashMap<String, Object> map = new HashMap<>(); | 
|---|
|  |  |  | map.put("staNo", sta.getStaNo());//目标站 | 
|---|
|  |  |  | map.put("crnNo", staDesc.getCrnNo());//目标站 | 
|---|
|  |  |  | String response = new HttpHandler.Builder() | 
|---|
|  |  |  | .setUri(wmsUrl) | 
|---|
|  |  |  | .setParams(map) | 
|---|
|  |  |  | 
|---|
|  |  |  | if (jsonObject.getInteger("code").equals(200)) { | 
|---|
|  |  |  | JSONObject data = (JSONObject) jsonObject.get("data"); | 
|---|
|  |  |  | log.info((String) data.get("msg")); | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | log.error("请求接口失败!!!url:{};request:{};response:{}", wmsUrl + "/rpc/auto/emptyOut/v1","", response); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|