From 23b4e7942a8524ed1e89d93c55a470f0dc263d5a Mon Sep 17 00:00:00 2001 From: lsh <lsh@163.com> Date: 星期五, 06 六月 2025 13:54:01 +0800 Subject: [PATCH] * --- src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java | 115 +++++++++++++++++++++++++++++++++++++++++---------------- 1 files changed, 83 insertions(+), 32 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 89115d2..9841de2 100644 --- a/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java +++ b/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java @@ -234,7 +234,7 @@ return; } long differenceInSeconds = TimeCalculatorUtils.differenceInMilliseconds(wrkMasts.get(0).getModiTime(), new Date()); - if (differenceInSeconds <= 100) { + if (differenceInSeconds <= 1000) { return; } @@ -263,20 +263,44 @@ //鑾峰彇灏忚溅鍙栨斁浠诲姟鍒楄〃澶辫触 public synchronized List<List<List<WrkMast>>> getWrkMastListAll(List<List<Integer>> siteListAll ,BasDevpPosition[] basDevpPositionsListUN) { List<List<List<WrkMast>>> wrkMastListAll = new ArrayList<>(); + List<Integer> sourceStaNoList = new ArrayList<>(); + for (List<Integer> siteList : siteListAll){ List<List<WrkMast>> wrkMastLists = new ArrayList<>(); try { List<WrkMast> wrkMastlistA = new ArrayList<>(); List<WrkMast> wrkMastlistB = new ArrayList<>(); + List<WrkMast> wrkMastlistC = new ArrayList<>(); + List<WrkMast> wrkMastlistD = new ArrayList<>(); for (BasDevpPosition basDevpPosition : basDevpPositionsListUN) { List<WrkMast> wrkMastList = wrkMastService.selectList(new EntityWrapper<WrkMast>().eq("sta_no", basDevpPosition.getDevNo()).eq("wrk_sts", 1L).orderBy("modi_time", true)); for (WrkMast wrkMast : wrkMastList) { if (!Cools.isEmpty(wrkMast)) { if (siteList.contains(wrkMast.getSourceStaNo())){ - if (SortTheExecutionOfTheCarUtil.devpNoSortbj(basDevpPositionsListUN, wrkMast.getSourceStaNo(), wrkMast.getStaNo())) { - wrkMastlistA.add(wrkMast); + if (!sourceStaNoList.contains(wrkMast.getSourceStaNo())){ + List<WrkMast> wrkMastListS = wrkMastService.selectList(new EntityWrapper<WrkMast>().eq("source_sta_no", wrkMast.getSourceStaNo()).eq("wrk_sts", 1L).orderBy("modi_time", true)); + if (wrkMastListS.isEmpty()){ + continue; + } } else { - wrkMastlistB.add(wrkMast); + continue; + } + long differenceInSeconds = TimeCalculatorUtils.differenceInMilliseconds(wrkMast.getModiTime(), new Date()); + + if (SortTheExecutionOfTheCarUtil.devpNoSortbj(basDevpPositionsListUN, wrkMast.getSourceStaNo(), wrkMast.getStaNo())) { + sourceStaNoList.add(wrkMast.getSourceStaNo()); + if (differenceInSeconds>600000){ + wrkMastlistA.add(wrkMast); + } else { + wrkMastlistC.add(wrkMast); + } + } else { + sourceStaNoList.add(wrkMast.getSourceStaNo()); + if (differenceInSeconds>600000){ + wrkMastlistB.add(wrkMast); + } else { + wrkMastlistD.add(wrkMast); + } } } } @@ -284,6 +308,8 @@ } wrkMastLists.add(wrkMastlistA); wrkMastLists.add(wrkMastlistB); + wrkMastLists.add(wrkMastlistC); + wrkMastLists.add(wrkMastlistD); // return wrkMastLists; wrkMastListAll.add(wrkMastLists); } catch (Exception e) { @@ -453,15 +479,13 @@ // } // } public synchronized void taskDown(List<List<List<WrkMast>>> wrkMastListAll) { + + List<Integer> rgvNoM = new ArrayList<>(); + List<Integer> rgvNoR = new ArrayList<>(); + int wrkMastRunCount = 0; + long devperimeter = 0L; for (List<List<WrkMast>> wrkMastLists : wrkMastListAll) { - int wrkMastRunCount = 0; - int wrkMastCount = 0; long rgvId = 0; - for (List<WrkMast> wrkMastList : wrkMastLists) { - for (WrkMast wrkMast : wrkMastList) { - wrkMastCount++; - } - } runRgv: for (List<WrkMast> wrkMastList : wrkMastLists) { for (WrkMast wrkMast : wrkMastList) { @@ -493,34 +517,29 @@ BasDevpPosition basDevpPosition = basDevpPositionService.selectOne(new EntityWrapper<BasDevpPosition>().eq("dev_no", wrkMast.getSourceStaNo())); if (basDevpPosition.getPlcPosition()>rgvProtocol.getRgvPos()){ if (basDevpPosition.getPlcPosition()-rgvProtocol.getRgvPos()>taskRunPerimeter){ - if (wrkMastRunCount<wrkMastCount){ - if (rgvProtocol.getStatusType() == RgvStatusType.IDLE) { - if (!MessageQueue.offer(SlaveType.Rgv, rgvProtocol.getRgvNo(), new Task(4,null))) { - log.error("RGV婕父鍚姩鍛戒护涓嬪彂澶辫触锛孯GV鍙�={}锛屼换鍔℃暟鎹�={}", rgvId, "婕父鎸囦护"); - break runRgv; - } - wrkMastRunCount++; - continue ; + if (!rgvNoM.contains(rgvProtocol.getRgvNo())){ + rgvNoM.add(rgvProtocol.getRgvNo()); + if (wrkMastRunCount == 0){ + devperimeter = basDevpPosition.getPlcPosition()-taskRunPerimeter+10000>perimeter? 10000:basDevpPosition.getPlcPosition()-taskRunPerimeter+10000; } + wrkMastRunCount++; + break; } - break runRgv; + continue ; } } else { if (rgvProtocol.getRgvPos()+ perimeter -basDevpPosition.getPlcPosition()>taskRunPerimeter){ - if (wrkMastRunCount<wrkMastCount){ - if (rgvProtocol.getStatusType() == RgvStatusType.IDLE) { - if (!MessageQueue.offer(SlaveType.Rgv, rgvProtocol.getRgvNo(), new Task(4,null))) { - log.error("RGV婕父鍚姩鍛戒护涓嬪彂澶辫触锛孯GV鍙�={}锛屼换鍔℃暟鎹�={}", rgvId, "婕父鎸囦护"); - break runRgv; - } - wrkMastRunCount++; - continue ; + if (!rgvNoM.contains(rgvProtocol.getRgvNo())){ + rgvNoM.add(rgvProtocol.getRgvNo()); + if (wrkMastRunCount == 0){ + devperimeter = basDevpPosition.getPlcPosition()-taskRunPerimeter+10000>perimeter? 10000:basDevpPosition.getPlcPosition()-taskRunPerimeter+10000; } + wrkMastRunCount++; + break; } - break runRgv; + continue ; } } - if (rgvProtocol.getStatusType() == RgvStatusType.ROAM) { double finalVelocity = 0.0; // 鏈�缁堥�熷害 (m/s) @@ -539,6 +558,11 @@ } } + if (!rgvNoR.contains(rgvProtocol.getRgvNo())){ + rgvNoR.add(rgvProtocol.getRgvNo()); + } else { + continue ; + } RgvCommand rgvCommand = new RgvCommand(); rgvCommand.setRgvNo(rgvProtocol.getRgvNo()); @@ -563,7 +587,6 @@ wrkMast.setCrnStrTime(now); try { wrkMastService.updateById(wrkMast); - wrkMastCount--; break; } catch (Exception e) { log.error("鏇存柊灏忚溅浠诲姟澶辫触,浠诲姟鍙凤細" + wrkMast.getWrkNo()); @@ -573,6 +596,34 @@ } } } + } + try{ + for (Integer rgvNo : rgvNoM){ + if (wrkMastRunCount==0){ + break; + } + if (rgvNoR.contains(rgvNo)){ + continue; + } + RgvThread rgvThread = (RgvThread) SlaveConnection.get(SlaveType.Rgv, rgvNo); + RgvProtocol rgvProtocol = rgvThread.getRgvProtocol(); + if (rgvProtocol == null) { + continue; + } + wrkMastRunCount--; + if (rgvProtocol != null + && rgvProtocol.modeType == RgvModeType.AUTO + && rgvProtocol.getStatusType() == RgvStatusType.IDLE + && rgvProtocol.getTaskNo1() == 0 + && rgvProtocol.getAlarm() == 0) { + if (!MessageQueue.offer(SlaveType.Rgv, rgvProtocol.getRgvNo(), new Task(5,devperimeter))) { + log.error("RGV婕父鍚姩鍛戒护涓嬪彂澶辫触锛孯GV鍙�={}锛屼换鍔℃暟鎹�={}", rgvNo, "婕父鎸囦护"); + break; + } + } + } + } catch (Exception e){ + } } @@ -624,7 +675,7 @@ wrkMastService.updateById(wrkMast); continue; }else { - log.error("宸ヤ綔鍙�"+wrkMast.getWrkNo()+"浠诲姟瀹屾垚淇℃伅涓婁紶澶勭悊澶辫触"); + log.error("宸ヤ綔鍙�"+wrkMast.getWrkNo()+"浠诲姟瀹屾垚淇℃伅涓婁紶澶勭悊澶辫触1"); } } else { //娴嬭瘯鐢� -- Gitblit v1.9.1