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