From 2534c069e82ec81119eb9f2477075e389dadf625 Mon Sep 17 00:00:00 2001 From: lsh <1> Date: 星期四, 07 三月 2024 14:24:18 +0800 Subject: [PATCH] # --- src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java | 70 ++++++++++++++++++++++++++++++++++- 1 files changed, 68 insertions(+), 2 deletions(-) diff --git a/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java index 777a44a..98efc3c 100644 --- a/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java +++ b/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java @@ -190,7 +190,7 @@ continue; } String barcode = barcodeThread.getBarcode(); - if(!Cools.isEmpty(barcode)) { + if(!Cools.isEmpty(barcode) && !barcode.equals("99999999")) { // 璇锋眰wms鎺ュ彛锛岃幏鍙栧伐浣滃彿鍜岀洰鏍囧簱浣� ToWmsDTO toWmsDTO = new ToWmsDTO(barcode,staProtocol.getSiteId(),staProtocol.isHigh() ? 2 : 1); TaskWrk taskWrk1=taskWrkService.selectOne(new EntityWrapper<TaskWrk>().eq("barcode",barcode)); @@ -221,6 +221,41 @@ log.info("鍏ュ簱璇锋眰鍙傛暟{}" + JSON.toJSONString(toWmsDTO)); if (jsonObject.getInteger("code").equals(200) && !Cools.isEmpty(jsonObject.get("data").toString())) { GetWmsDto getWmsDto = JSON.parseObject(jsonObject.get("data").toString(), GetWmsDto.class); + + //鏌ョ湅璇ュ簱浣嶆槸鍚︿负绌哄簱浣� + LocMast locMast=locMastService.selectOne(new EntityWrapper<LocMast>() + .eq("loc_sts","O") + .eq("loc_no",getWmsDto.getLocNo())); + if(Cools.isEmpty(locMast)){ + try{ + HashMap<String, Object> headParam1 = new HashMap<>(); + headParam1.put("taskNo",getWmsDto.getTaskNo()); + headParam1.put("status",6); + headParam1.put("ioType",1); + headParam1.put("barcode",barcode); + String response2; + response2 = new HttpHandler.Builder() + // .setHeaders(headParam) + .setUri(wmsUrl) + .setPath(taskStatusFeedbackPath) + .setJson(JSON.toJSONString(headParam1)) + .build() + .doPost(); + JSONObject jsonObject1 = JSON.parseObject(response2); + apiLogService.save("wcs娲惧彂搴撲綅涓嶄负绌轰笂鎶ms" + ,wmsUrl+taskStatusFeedbackPath + ,null + ,"127.0.0.1" + ,JSON.toJSONString(headParam1) + ,response + ,true + ); + }catch (Exception e){ + log.error("wcs娲惧彂搴撲綅涓嶄负绌轰笂鎶ms", getWmsDto.getWrkNo()); + throw new CoolException("wcs娲惧彂鍏ュ簱浠诲姟涓婃姤wms澶辫触"); + } + } + // 鍒涙柊涓�涓叆搴撳伐浣滄。 TaskWrk taskWrk = taskWrkService.selectByTaskNo(getWmsDto.getWrkNo()); if(Cools.isEmpty(taskWrk)) { @@ -1097,7 +1132,38 @@ } } - //鑷姩瀹屾垚浠诲姟 + //agv鍙栨斁璐т换鍔″畬鎴� + public synchronized void autoCompleteAGV() { + List<BasDevp> basDevps = basDevpService.selectList(new EntityWrapper<>()); + for (BasDevp basDevp:basDevps){ + DevpThread devpThread = (DevpThread) SlaveConnection.get(SlaveType.Devp, 1); + StaProtocol staProtocol = devpThread.getStation().get(basDevp.getDevNo()); + if (staProtocol == null) { + continue; + } else { + staProtocol = staProtocol.clone(); + } + if (basDevp.getWrkNo()!=0){ + if (basDevp.getAgvTargetPick()!=0){//鍙栬揣 + staProtocol.setAgvTypeSign((short)0); + staProtocol.setStaNo(basDevp.getDevNo().shortValue()); + MessageQueue.offer(SlaveType.Devp, 1, new Task(4, staProtocol)); + }else if (basDevp.getAgvTargetPlace()!=0){ + staProtocol.setAgvTypeSign((short)1); + staProtocol.setStaNo(basDevp.getDevNo().shortValue()); + MessageQueue.offer(SlaveType.Devp, 1, new Task(4, staProtocol)); + } + }else { + if (basDevp.getAgvTargetPick()!=0){ + basDevp.setAgvStartPick(0); + basDevpService.updateById(basDevp); + }else if (basDevp.getAgvTargetPlace()!=0){ + basDevp.setAgvStartPlace(0); + basDevpService.updateById(basDevp); + } + } + } + } public synchronized void autoCompleteTask() { List<TaskWrk> taskWrks = taskWrkMapper.selectWorkingTask(); for (TaskWrk taskWrk : taskWrks) { -- Gitblit v1.9.1