From ce641926a957d238b202aa0d9dac3b8f15aff153 Mon Sep 17 00:00:00 2001 From: ZY <zc857179121@qq.com> Date: 星期三, 14 五月 2025 14:43:00 +0800 Subject: [PATCH] 123 --- src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java | 144 +++++++++++++++++++++++++++++++---------------- 1 files changed, 94 insertions(+), 50 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 f5d8190..6a022bd 100644 --- a/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java +++ b/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java @@ -270,7 +270,7 @@ param.setLocType1(locTypeDto.getLocType1()); if (inSta.getStaNo() == 102) { param.setLocType2((short) 3); - } else if (inSta.getStaNo() == 211) { + } else if (inSta.getStaNo() == 211 || inSta.getStaNo() == 104) { param.setLocType1((short) 5); param.setLocType2((short) 4); } else if (inSta.getStaNo() == 201) { @@ -310,16 +310,17 @@ staProtocol.setWorkNo((short) 9999); staProtocol.setStaNo(inSta.getBackSta().shortValue()); devpThread.setPakMk(staProtocol.getSiteId(), false); - boolean result = MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(2, staProtocol)); - if (!result) { - throw new CoolException("鏇存柊plc绔欑偣淇℃伅澶辫触"); - } - // led 寮傚父鏄剧ず if (ledThread != null) { String errorMsg = jsonObject.getString("msg"); MessageQueue.offer(SlaveType.Led, inSta.getLed(), new Task(5, errorMsg)); } + boolean result = MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(2, staProtocol)); + if (!result) { + throw new CoolException("鏇存柊plc绔欑偣淇℃伅澶辫触"); + } + + } } catch (Exception e) { @@ -417,10 +418,20 @@ staProtocol = staProtocol.clone(); } - if (barcodeThread == null) { + String barcode = ""; + if (barcodeThread == null && staProtocol.getSiteId() != 104) { continue; + } else if (staProtocol.getSiteId() == 104) { + if (staProtocol.getWorkNo() == 9996) { + // 鑾峰彇鍒版嫞鏂欎换鍔$殑鎵樼洏鐮� + WrkMast wrkMast = wrkMastMapper.selectOne(new QueryWrapper<WrkMast>().eq("wrk_sts", 14).eq("io_type", 103).eq("source_sta_no", 104)); + if (wrkMast != null) { + barcode = wrkMast.getBarcode(); + } + } + } else { + barcode = barcodeThread.getBarcode(); } - String barcode = barcodeThread.getBarcode(); // 灏哄妫�娴嬪紓甯� boolean back = false; String errMsg = ""; @@ -530,7 +541,7 @@ StaDesc staDesc = staDescService.getOne(wrapper); if (Cools.isEmpty(staDesc)) { News.error("" + mark + " - 2" + " - 鍏ュ簱璺緞涓嶅瓨鍦紒type_no={},stn_no={},crn_no={}", wrkMast.getIoType(), pickSta.getStaNo(), wrkMast.getCrnNo()); - staProtocol.setWorkNo((short) 9989); + staProtocol.setWorkNo((short) 9999); staProtocol.setStaNo((short) (pickSta.getStaNo().shortValue() - (short) 1)); devpThread.setPakMk(staProtocol.getSiteId(), false); MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(2, staProtocol)); @@ -879,7 +890,7 @@ wrkMast.setIoPri(14D); wrkMastMapper.updateById(wrkMast); // 鐢熸垚宸ヤ綔妗�,灏嗘祬搴撲綅绉昏浆鍒版柊鐨勫簱浣嶄腑 - moveLocForDeepLoc(slave, shallowLoc, mark); + moveLocForDeepLoc(slave, shallowLoc, mark, wrkMast.getTenant()); // 鐢熸垚宸ヤ綔妗c�佹敼鍙樻祬搴撲綅鐨勬簮搴�/鐩爣搴� 搴撲綅鐘舵�併�佷笅鍙戝爢鍨涙満鍛戒护锛堢珛椹墽琛�) // moveLocForDeepLocPakin(slave, shallowLoc, wrkMast); } @@ -909,6 +920,9 @@ crnCommand.setDestinationPosXTwo(locMast.getRow1().shortValue()); // 鐩爣搴撲綅鎺� crnCommand.setDestinationPosYTwo(locMast.getBay1().shortValue()); // 鐩爣搴撲綅鍒� crnCommand.setDestinationPosZTwo(locMast.getLev1().shortValue()); // 鐩爣搴撲綅灞� + if (crnStn.getStaNo() == 202) { + crnCommand.setSourcePosYTwo((short) 6); // 婧愬簱浣嶅垪 + } } else { if (workMode == 1) { crnCommand.setTaskMode(CrnTaskModeType.PAKIN); @@ -921,6 +935,9 @@ crnCommand.setDestinationPosX(locMast.getRow1().shortValue()); // 鐩爣搴撲綅鎺� crnCommand.setDestinationPosY(locMast.getBay1().shortValue()); // 鐩爣搴撲綅鍒� crnCommand.setDestinationPosZ(locMast.getLev1().shortValue()); // 鐩爣搴撲綅灞� + if (workMode == 1 && crnStn.getStaNo() == 202) { + crnCommand.setSourcePosY((short) 6); // 婧愬簱浣嶅垪 + } } // crnCommand.setAckFinish((short) 0); // 浠诲姟瀹屾垚纭浣� @@ -1048,7 +1065,7 @@ wrkMast.setUpdMk("Y"); wrkMastMapper.updateById(wrkMast); // 鐢熸垚宸ヤ綔妗�,灏嗘祬搴撲綅绉昏浆鍒版柊鐨勫簱浣嶄腑 - moveLocForDeepLoc(slave, shallowLoc, mark); + moveLocForDeepLoc(slave, shallowLoc, mark, wrkMast.getTenant()); } News.error("{}浠诲姟鍑哄簱澶辫触锛屾祬搴撲綅鍫靛锛佹祬搴撲綅鍙�:{}", wrkMast.getWrkNo(), shallowLocNo); continue; @@ -1087,6 +1104,9 @@ crnCommand.setDestinationPosXTwo(crnStn.getRow().shortValue()); // 鐩爣搴撲綅鎺� crnCommand.setDestinationPosYTwo(crnStn.getBay().shortValue()); // 鐩爣搴撲綅鍒� crnCommand.setDestinationPosZTwo(crnStn.getLev().shortValue()); // 鐩爣搴撲綅灞� + if (crnStn.getStaNo() == 202) { + crnCommand.setDestinationPosYTwo((short) 6); // 婧愬簱浣嶅垪 + } } else { if (workMode == 1) { crnCommand.setTaskMode(CrnTaskModeType.PAKIN); @@ -1099,6 +1119,9 @@ crnCommand.setDestinationPosX(crnStn.getRow().shortValue()); // 鐩爣搴撲綅鎺� crnCommand.setDestinationPosY(crnStn.getBay().shortValue()); // 鐩爣搴撲綅鍒� crnCommand.setDestinationPosZ(crnStn.getLev().shortValue()); // 鐩爣搴撲綅灞� + if (workMode == 1 && crnStn.getStaNo() == 202) { + crnCommand.setDestinationPosY((short) 6); // 婧愬簱浣嶅垪 + } } if (!MessageQueue.offer(SlaveType.Crn, wrkMast.getCrnNo(), new Task(2, crnCommand))) { @@ -1539,10 +1562,10 @@ staProtocol = staProtocol.clone(); } - if (barcodeThread == null) { - continue; - } - String barcode = barcodeThread.getBarcode(); +// if (barcodeThread == null) { +// continue; +// } +// String barcode = barcodeThread.getBarcode(); // 灏哄妫�娴嬪紓甯� boolean back = false; String errMsg = ""; @@ -1583,9 +1606,9 @@ if (!staProtocol.isLoading()) { continue; } - if (!staProtocol.isPakMk()) { - continue; - } +// if (!staProtocol.isPakMk()) { +// continue; +// } staProtocol.setWorkNo((short) 9999); News.info("{}鍏ュ簱鍥為��锛歿}锛屼换鍔″彿锛歿}", emptyInSta.getStaNo(), errMsg, (short) 9999); staProtocol.setStaNo(emptyInSta.getBackSta().shortValue()); @@ -1617,7 +1640,7 @@ param.setLocType1(locTypeDto.getLocType1()); if (emptyInSta.getStaNo() == 102) { param.setLocType2((short) 3); - } else if (emptyInSta.getStaNo() == 211) { + } else if (emptyInSta.getStaNo() == 211 || emptyInSta.getStaNo() == 104) { param.setLocType1((short) 5); param.setLocType2((short) 4); } else if (emptyInSta.getStaNo() == 201) { @@ -1930,7 +1953,7 @@ * 鍥犲弻娣卞簱浣嶉樆濉烇紝瀵规祬搴撲綅杩涜绉昏浆锛堢珛鍗虫墽琛岀増) * tip锛氬悓姝� */ - private synchronized void moveLocForDeepLoc(CrnSlave crn, LocMast shallowLoc, Integer mark) { + private synchronized void moveLocForDeepLoc(CrnSlave crn, LocMast shallowLoc, Integer mark, Long tenant) { try { News.warnNoLog("" + mark + "moveLocForDeepLoc" + " - 0" + " - 寮�濮嬫墽琛�:鍥犲弻娣卞簱浣嶉樆濉烇紝瀵规祬搴撲綅杩涜绉昏浆锛堢珛鍗虫墽琛岀増)"); @@ -2014,7 +2037,7 @@ wrkMast.setCrnNo(crn.getId()); wrkMast.setSourceLocNo(shallowLoc.getLocNo()); // 婧愬簱浣� wrkMast.setLocNo(loc.getLocNo()); // 鐩爣搴撲綅 - wrkMast.setFullPlt(shallowLoc.getFullPlt()); // 婊℃澘 + wrkMast.setFullPlt(shallowLoc.getLocSts().equals("F") ? "Y" : "N"); // 婊℃澘 wrkMast.setPicking("N"); // 鎷f枡 wrkMast.setExitMk("N"); // 閫�鍑� wrkMast.setEmptyMk(shallowLoc.getLocSts().equals("D") ? "Y" : "N"); // 绌烘澘 @@ -2022,6 +2045,7 @@ wrkMast.setLinkMis("N"); wrkMast.setAppeTime(new Date()); wrkMast.setModiTime(new Date()); + wrkMast.setTenant(tenant); int res = wrkMastMapper.insert(wrkMast); if (res == 0) { News.errorNoLog("" + mark + "moveLocForDeepLoc" + " - 2" + " - 淇濆瓨宸ヤ綔妗eけ璐�"); @@ -2038,6 +2062,7 @@ VersionUtils.setWrkDetl(wrkDetl, locDetl); // 鐗堟湰鎺у埗 wrkDetl.setAppeTime(new Date()); wrkDetl.setModiTime(new Date()); + wrkDetl.setTenant(tenant); if (!wrkDetlService.save(wrkDetl)) { News.errorNoLog("" + mark + "moveLocForDeepLoc" + " - 3" + " - 淇濆瓨宸ヤ綔妗f槑缁嗗け璐�"); throw new CoolException("淇濆瓨宸ヤ綔妗f槑缁嗗け璐�"); @@ -2305,7 +2330,7 @@ public synchronized void autoEmptyOut() { DevpThread devpThread = (DevpThread) SlaveConnection.get(SlaveType.Devp, 1); - Integer autoOutSite = 12; + Integer autoOutSite = 103; //濡傛灉绔欑偣鍙嚭绂佺敤锛屽垯涓嶇敓鎴愮┖鐩樺嚭搴撲换鍔� StaProtocol staProtocol = devpThread.getStation().get(autoOutSite); if (staProtocol == null) { @@ -2315,32 +2340,27 @@ } if (staProtocol.isAutoing() //鑷姩 && !staProtocol.isLoading() //鏃犵墿 - && staProtocol.isOutEnable() //鍙嚭淇″彿 +// && staProtocol.isOutEnable() //鍙嚭淇″彿 && staProtocol.getWorkNo() == 0) { - WrkMast pakoutEmpty = wrkMastMapper.selectPakoutEmpty(autoOutSite); - if (null != pakoutEmpty) { - return; +// WrkMast pakoutEmpty = wrkMastMapper.selectPakoutEmpty(autoOutSite); +// if (null != pakoutEmpty) { +// return; +// } + + LocMast byId = locMastService.getById("0200405"); + if (byId != null&&byId.getLocSts().equalsIgnoreCase("D")){ + } - try { - String response = new HttpHandler.Builder().setUri(wmsUrl).setPath("/rpc/auto/emptyOut/v1").build().doPost(); - JSONObject jsonObject = JSON.parseObject(response); - if (jsonObject.getInteger("code").equals(200)) { - JSONObject data = (JSONObject) jsonObject.get("data"); - News.info((String) data.get("msg")); - } else { - News.error("璇锋眰鎺ュ彛澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", wmsUrl + "/rpc/auto/emptyOut/v1", "", response); - } - } catch (Exception e) { - e.printStackTrace(); - TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); - } + } } + @Autowired + private WrkMastService wrkMastService; + public synchronized void autoEmptyIn() { DevpThread devpThread = (DevpThread) SlaveConnection.get(SlaveType.Devp, 1); - Integer autoInSite = 12; - StaProtocol staProtocol = devpThread.getStation().get(autoInSite); + StaProtocol staProtocol = devpThread.getStation().get(103); if (staProtocol == null) { return; } else { @@ -2348,20 +2368,44 @@ } if (staProtocol.isAutoing() //鑷姩 && staProtocol.isLoading() //鏈夌墿 - && staProtocol.isInEnable() //鍙叆淇″彿 +// && staProtocol.isInEnable() //鍙叆淇″彿 && (staProtocol.getWorkNo() == 0 || staProtocol.getWorkNo() >= 9990) //宸ヤ綔鍙蜂负0鎴栬�呭伐浣滃彿鏄�9991~9999锛堣緭閫佹満鐣欑敤锛� ) { try { - LocTypeDto locTypeDto = new LocTypeDto((short) 1, (short) 1, (short) 1); + Date now = new Date(); + // 鐢熸垚宸ヤ綔妗� + WrkMast wrkMast = new WrkMast(); + int workNo = commonService.getWorkNo(0); + wrkMast.setWrkNo(workNo); + wrkMast.setIoTime(now); + wrkMast.setWrkSts(2L); + wrkMast.setIoPri(13D); + wrkMast.setIoType(10); + wrkMast.setCrnNo(1); + wrkMast.setSourceStaNo(101); + wrkMast.setStaNo(103); + wrkMast.setLocNo("0200405"); + wrkMast.setFullPlt("N"); // 婊℃澘锛歂 + wrkMast.setPicking("N"); // 鎷f枡 + wrkMast.setExitMk("N"); // 閫�鍑� + wrkMast.setEmptyMk("Y"); // 绌烘澘 + wrkMast.setLinkMis("Y"); + // 鎿嶄綔浜哄憳鏁版嵁 + wrkMast.setAppeTime(now); + wrkMast.setModiTime(now); + wrkMast.setMemo("鑷姩绌烘墭鍏ュ簱"); + boolean res = wrkMastService.save(wrkMast); - - String response = new HttpHandler.Builder().setUri(wmsUrl).setPath("/rpc/auto/emptyIn/v1").setJson(JSON.toJSONString(locTypeDto)).build().doPost(); - JSONObject jsonObject = JSON.parseObject(response); - if (jsonObject.getInteger("code").equals(200)) { - News.info((String) jsonObject.get("msg")); - } else { - News.error("璇锋眰鎺ュ彛澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", wmsUrl + "/rpc/auto/emptyIn/v1", JSON.toJSONString(locTypeDto), response); + // 鏇存柊鐩爣搴撲綅鐘舵�� + LocMast locMast = locMastService.getById("0200405"); + if (locMast.getLocSts().equals("O")) { + locMast.setLocSts("S"); // S.鍏ュ簱棰勭害 + locMast.setModiUser(789L); + locMast.setModiTime(now); + if (!locMastService.updateById(locMast)) { + throw new CoolException("鏀瑰彉搴撲綅鐘舵�佸け璐�"); + } } } catch (Exception e) { e.printStackTrace(); -- Gitblit v1.9.1