From eb5eb35a7ef56a01a4c788a8c2efef9fc7b823e7 Mon Sep 17 00:00:00 2001 From: Junjie <fallin.jie@qq.com> Date: 星期一, 27 三月 2023 14:04:54 +0800 Subject: [PATCH] 四向穿梭车线程完善 --- src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java | 240 +++++++++++++++++++++++++++++++++++++++++++++-------------- 1 files changed, 181 insertions(+), 59 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 012062f..a8fa25d 100644 --- a/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java +++ b/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java @@ -10,15 +10,11 @@ import com.zy.asrs.mapper.*; import com.zy.asrs.service.*; import com.zy.asrs.utils.Utils; -import com.zy.common.model.LocTypeDto; -import com.zy.common.model.MatDto; -import com.zy.common.model.SearchLocParam; -import com.zy.common.model.StartupDto; +import com.zy.common.model.*; import com.zy.common.model.enums.WrkChargeType; import com.zy.common.service.CommonService; import com.zy.common.service.erp.ErpService; -import com.zy.common.utils.CollectionUtils; -import com.zy.common.utils.HttpHandler; +import com.zy.common.utils.*; import com.zy.core.CrnThread; import com.zy.core.DevpThread; import com.zy.core.News; @@ -26,17 +22,13 @@ import com.zy.core.cache.SlaveConnection; import com.zy.core.enums.*; import com.zy.core.model.*; -import com.zy.core.model.command.CrnCommand; -import com.zy.core.model.command.LedCommand; -import com.zy.core.model.command.SteCommand; +import com.zy.core.model.command.*; import com.zy.core.model.protocol.CrnProtocol; +import com.zy.core.model.protocol.ShuttleProtocol; import com.zy.core.model.protocol.StaProtocol; import com.zy.core.model.protocol.SteProtocol; import com.zy.core.properties.SlaveProperties; -import com.zy.core.thread.BarcodeThread; -import com.zy.core.thread.LedThread; -import com.zy.core.thread.SiemensDevpThread; -import com.zy.core.thread.SteThread; +import com.zy.core.thread.*; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; @@ -96,6 +88,8 @@ private OrderMapper orderMapper; @Autowired private OrderDetlMapper orderDetlMapper; + @Autowired + private RedisUtil redisUtil; /** * 缁勬墭 @@ -115,57 +109,51 @@ staProtocol = staProtocol.clone(); } Short workNo = staProtocol.getWorkNo(); + // 灏哄妫�娴嬪紓甯� + boolean back = false; + String errMsg = "寮傚父锛�"; + if (staProtocol.isFrontErr()) { + errMsg = errMsg+"鍓嶈秴闄愶紱"; + back = true; + } + if (staProtocol.isBackErr()) { + errMsg = errMsg+"鍚庤秴闄�"; + back = true; + } + if (staProtocol.isHighErr()) { + errMsg = errMsg+"楂樿秴闄�"; + back = true; + } + if (staProtocol.isLeftErr()) { + errMsg = errMsg+"宸﹁秴闄�"; + back = true; + } + if (staProtocol.isRightErr()) { + errMsg = errMsg+"鍙宠秴闄�"; + back = true; + } + if (staProtocol.isWeightErr()) { + errMsg = errMsg+"瓒呴噸"; + back = true; + } + if (staProtocol.isBarcodeErr()) { + errMsg = errMsg+"鎵爜澶辫触"; + back = true; + } + // 閫�鍥� + if (back) { + // led 寮傚父鏄剧ず + LedThread ledThread = (LedThread) SlaveConnection.get(SlaveType.Led, inSta.getLed()); + if (ledThread != null) { + MessageQueue.offer(SlaveType.Led, inSta.getLed(), new Task(3, errMsg)); + } + continue; + } // 鍒ゆ柇鏄惁婊¤冻鍏ュ簱鏉′欢 if (staProtocol.isAutoing() && staProtocol.isLoading() && staProtocol.isInEnable() && !staProtocol.isEmptyMk() && (workNo == 0 || (workNo >= 9990 && workNo <= 9999)) && staProtocol.isPakMk()) { - // 灏哄妫�娴嬪紓甯� - boolean back = false; - String errMsg = "寮傚父锛�"; - if (staProtocol.isFrontErr()) { - errMsg = errMsg+"鍓嶈秴闄愶紱"; - back = true; - } - if (staProtocol.isBackErr()) { - errMsg = errMsg+"鍚庤秴闄�"; - back = true; - } - if (staProtocol.isHighErr()) { - errMsg = errMsg+"楂樿秴闄�"; - back = true; - } - if (staProtocol.isLeftErr()) { - errMsg = errMsg+"宸﹁秴闄�"; - back = true; - } - if (staProtocol.isRightErr()) { - errMsg = errMsg+"鍙宠秴闄�"; - back = true; - } - if (staProtocol.isWeightErr()) { - errMsg = errMsg+"瓒呴噸"; - back = true; - } - if (staProtocol.isBarcodeErr()) { - errMsg = errMsg+"鎵爜澶辫触"; - back = true; - } - // 閫�鍥� - if (back) { - News.warn("鎵爜鍏ュ簱澶辫触锛寋}鍏ュ簱绔欏洜{}寮傚父锛屾墭鐩樺凡琚��鍥�", inSta.getStaNo(), errMsg); - staProtocol.setWorkNo((short) 32002); - staProtocol.setStaNo(inSta.getBackSta().shortValue()); - devpThread.setPakMk(staProtocol.getSiteId(), false); - MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(2, staProtocol)); - - // led 寮傚父鏄剧ず - LedThread ledThread = (LedThread) SlaveConnection.get(SlaveType.Led, inSta.getLed()); - if (ledThread != null) { - MessageQueue.offer(SlaveType.Led, inSta.getLed(), new Task(3, errMsg)); - } - continue; - } // 鑾峰彇鏉$爜鎵弿浠俊鎭� BarcodeThread barcodeThread = (BarcodeThread) SlaveConnection.get(SlaveType.Barcode, inSta.getBarcode()); @@ -618,6 +606,51 @@ } /** + * 鍏ュ嚭搴� ===>> 鍥涘悜绌挎杞﹀叆鍑哄簱浣滀笟涓嬪彂 + */ + public synchronized void shuttleIoExecute() { + for (ShuttleSlave shuttle : slaveProperties.getShuttle()) { + //鑾峰彇鍥涘悜绌挎杞︿俊鎭� + ShuttleThread shuttleThread = (ShuttleThread) SlaveConnection.get(SlaveType.Shuttle, shuttle.getId()); + ShuttleProtocol shuttleProtocol = shuttleThread.getShuttleProtocol(); + if (shuttleProtocol == null) { + continue; + } + + // 鍙湁褰撳洓鍚戠┛姊溅绌洪棽 骞朵笖鏃犱换鍔℃椂鎵嶇户缁墽琛� + if (shuttleProtocol.getBusyStatusType() == ShuttleStatusType.IDLE && shuttleProtocol.getTaskNo() == 0) { + //鍏ュ嚭搴撻�昏緫 + for (WrkMast wrkSts : wrkMastMapper.selectList(new EntityWrapper<WrkMast>().eq("wrk_sts", 2))) { + //鍒嗛厤浠诲姟鍙� + shuttleProtocol.setTaskNo(wrkSts.getWrkNo().shortValue()); + //鍒嗛厤婧愬簱浣� + shuttleProtocol.setSourceLocNo(wrkSts.getSourceLocNo()); + //鍒嗛厤鐩爣搴撲綅 + shuttleProtocol.setLocNo(wrkSts.getLocNo()); + + + ShuttleAssignCommand assignCommand = new ShuttleAssignCommand(); + //鍥涘悜绌挎杞﹀彿 + assignCommand.setShuttleNo(shuttleProtocol.getShuttleNo()); + //浠诲姟鍙� + assignCommand.setTaskNo(wrkSts.getWrkNo().shortValue()); + //鍏ュ嚭搴撴ā寮� + assignCommand.setTaskMode((short) 0); + //婧愬簱浣� + assignCommand.setSourceLocNo(wrkSts.getSourceLocNo()); + //鐩爣搴撲綅 + assignCommand.setDistLocNo(wrkSts.getLocNo()); + + //涓嬪彂浠诲姟 + MessageQueue.offer(SlaveType.Shuttle, assignCommand.getShuttleNo().intValue(), new Task(3, assignCommand)); + } + + } + } + + } + + /** * 鍏ュ嚭搴� ===>> 鍫嗗灈鏈哄叆鍑哄簱浣滀笟涓嬪彂 */ public synchronized void crnIoExecute(){ @@ -721,6 +754,51 @@ } if (!locMast.getLocSts().equals("S") && !locMast.getLocSts().equals("Q")) { News.error("鍏ュ簱鎿嶄綔搴撲綅鐘舵�佷笉绗﹀悎--鐘舵��, 搴撲綅鍙�={}锛屽簱浣嶇姸鎬�={}", wrkMast.getLocNo(), locMast.getLocSts()); + continue; + } + + List<LocMast> locMasts = null; + boolean sign=false; + if (locMast.getRow1()>=5){ + locMasts=locMastService.selectList(new EntityWrapper<LocMast>().ge("row1", 5) + .eq("bay1",locMast.getBay1()).eq("lev1",locMast.getLev1())); + for (LocMast locMast1:locMasts){ + if (locMast1.getRow1()>locMast.getRow1()){ + if (!locMast1.getLocSts().equals("F") && !locMast1.getLocSts().equals("D")){ + if (!locMast1.getLocSts().equals("X")){ + sign=true; + break; + } + } + }else if (locMast1.getRow1()<locMast.getRow1()){ + if (locMast1.getLocSts().equals("F") || locMast1.getLocSts().equals("D")){ + News.error("褰撳墠宸ヤ綔妗g洰鏍囧簱浣嶆墍鍦ㄦ帓鍓嶈竟瀛樺湪璐х墿锛�", wrkMast.getWrkNo()); + sign=true; + break; + } + } + } + }else { + locMasts=locMastService.selectList(new EntityWrapper<LocMast>().le("row1", 4) + .eq("bay1",locMast.getBay1()).eq("lev1",locMast.getLev1())); + for (LocMast locMast1:locMasts){ + if (locMast1.getRow1()>locMast.getRow1()){ + if (locMast1.getLocSts().equals("F") || locMast1.getLocSts().equals("D")){ + News.error("褰撳墠宸ヤ綔妗g洰鏍囧簱浣嶆墍鍦ㄦ帓鍓嶈竟瀛樺湪璐х墿锛�", wrkMast.getWrkNo()); + sign=true; + break; + } + }else if (locMast1.getRow1()<locMast.getRow1()){ + if (!locMast1.getLocSts().equals("F") && !locMast1.getLocSts().equals("D")){ + if (!locMast1.getLocSts().equals("X")){ + sign=true; + break; + } + } + } + } + } + if (sign){ continue; } @@ -897,6 +975,36 @@ LocMast sourceSta = locMastService.selectById(wrkMast.getSourceLocNo()); if (!sourceSta.getLocSts().equals("R") &&!sourceSta.getLocSts().equals("P")) { News.error("鍑哄簱鎿嶄綔搴撲綅鐘舵�佷笉绗﹀悎--鐘舵��, 搴撲綅鍙�={}锛屽簱浣嶇姸鎬�={}", wrkMast.getLocNo(), sourceSta.getLocSts()); + continue; + } + List<LocMast> locMasts = null; + boolean sign=false; + if (sourceSta.getRow1()>=5){ + locMasts=locMastService.selectList(new EntityWrapper<LocMast>().ge("row1", 5) + .eq("bay1",sourceSta.getBay1()).eq("lev1",sourceSta.getLev1())); + for (LocMast locMast1:locMasts){ + if (locMast1.getRow1()<sourceSta.getRow1()){ + if (!locMast1.getLocSts().equals("O")){ + News.error("褰撳墠宸ヤ綔妗f簮搴撲綅鎵�鍦ㄦ帓鍓嶈竟瀛樺湪璐х墿锛�", wrkMast.getWrkNo()); + sign=true; + break; + } + } + } + }else { + locMasts=locMastService.selectList(new EntityWrapper<LocMast>().le("row1", 4) + .eq("bay1",sourceSta.getBay1()).eq("lev1",sourceSta.getLev1())); + for (LocMast locMast1:locMasts){ + if (locMast1.getRow1()>sourceSta.getRow1()){ + if (!locMast1.getLocSts().equals("O")){ + News.error("褰撳墠宸ヤ綔妗g洰鏍囧簱浣嶆墍鍦ㄦ帓鍓嶈竟瀛樺湪璐х墿锛�", wrkMast.getWrkNo()); + sign=true; + break; + } + } + } + } + if (sign){ continue; } @@ -1615,6 +1723,17 @@ WrkCharge wrkCharge = wrkChargeService.selectById(crnProtocol.getTaskNo()); if (wrkCharge == null) { News.error("鍫嗗灈鏈哄浜庣瓑寰呯‘璁や笖浠诲姟瀹屾垚鐘舵�侊紝浣嗘湭鎵惧埌宸ヤ綔妗c�傚爢鍨涙満鍙�={}锛屽伐浣滃彿={}", crn.getId(), crnProtocol.getTaskNo()); + wrkMast = wrkMastMapper.selectCrnWaiting2(crnProtocol.getTaskNo().intValue()); + if (wrkMast.getIoType() != 11) { + // 淇敼鎴愬姛鍚庡浣嶅爢鍨涙満 + if (wrkMastMapper.updateById(wrkMast) > 0) { + // 鍫嗗灈鏈哄浣� + crnThread.setResetFlag(true); + News.error("鍫嗗灈鏈哄浜庣瓑寰呯‘璁や笖浠诲姟瀹屾垚鐘舵��,澶嶄綅锛屼絾鏈壘鍒板伐浣滄。銆傚爢鍨涙満鍙�={}锛屽伐浣滃彿={}", crn.getId(), crnProtocol.getTaskNo()); + } else { + News.error("鍫嗗灈鏈哄浜庣瓑寰呯‘璁や笖浠诲姟瀹屾垚鐘舵��,澶嶄綅澶辫触锛屼絾鏈壘鍒板伐浣滄。銆傚爢鍨涙満鍙�={}锛屽伐浣滃彿={}", crn.getId(), crnProtocol.getTaskNo()); + } + } continue; } else { // 灏忚溅鎼嚦鎸囧畾搴撲綅瀹屾垚 @@ -2505,6 +2624,9 @@ */ @SuppressWarnings("serial") public synchronized void loopSteCharge() { + if (!Cools.isEmpty(wrkMastMapper.selectAllC())){ + return; + } if (null != wrkChargeService.selectWorking(null, WrkChargeType.reset)) { return; } -- Gitblit v1.9.1