From 1af93b3d4833dfead180264f41cfaa896ac7d24b Mon Sep 17 00:00:00 2001
From: 1 <1>
Date: 星期六, 22 十一月 2025 08:21:58 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java |   69 ++++++++++++++++++++++++++++++++--
 1 files changed, 65 insertions(+), 4 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 69c5cfe..afd9cbf 100644
--- a/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
@@ -111,6 +111,8 @@
     private BasArmMastService basArmMastService;
     @Autowired
     private ApiLogService apiLogService;
+    @Autowired
+    private BasDevpOptService basDevpOptService;
 
     @Value("${wms.url}")
     private String wmsUrl;
@@ -201,6 +203,7 @@
                         MessageQueue.offer(SlaveType.Led, inSta.getLed(), new Task(3, errMsg));
                     }
                     staProtocol.setWorkNo(wrkNo);
+                    staProtocol.setErrCode(errMsg);
                     News.info("寮傚父鍒ゆ柇{}鍏ュ簱鍥為��锛歿}锛屼换鍔″彿锛歿}", inSta.getStaNo(), errMsg,wrkNo);
                     wrkNo++;
                     staProtocol.setStaNo(inSta.getBackSta().shortValue());
@@ -229,6 +232,7 @@
                             MessageQueue.offer(SlaveType.Led, inSta.getLed(), new Task(3, errorMsg));
                         }
                         staProtocol.setWorkNo(wrkNo);
+                        staProtocol.setErrCode(errMsg);
                         News.info("鏉$爜鍒ゆ柇{}鍏ュ簱鍥為��锛歿}锛屼换鍔″彿锛歿}", inSta.getStaNo(), errMsg,wrkNo);
                         wrkNo++;
                         staProtocol.setStaNo(inSta.getBackSta().shortValue());
@@ -299,7 +303,6 @@
                     }
                     try {
                         LocTypeDto locTypeDto = new LocTypeDto(staProtocol);
-
                         SearchLocParam param = new SearchLocParam();
                         param.setBarcode(barcode);
                         param.setIoType(1);
@@ -334,6 +337,10 @@
                             staProtocol.setWorkNo(wrkNo);
                             staProtocol.setStaNo(inSta.getBackSta().shortValue());
                             devpThread.setPakMk(staProtocol.getSiteId(), false);
+                            switch (jsonObject.getInteger("code")){
+                                case 700: staProtocol.setErrCode("鏈粍鎵�");break;
+                                case 500: staProtocol.setErrCode("宸ヤ綔妗�/搴撳瓨鏉$爜鏁版嵁宸插瓨鍦�");break;
+                            }
                             MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(2, staProtocol));
                             News.info("浠诲姟涓嬪彂鍒ゆ柇{}鍏ュ簱鍥為��锛歿}锛岄敊璇紪鍙穥},浠诲姟鍙凤細{}", inSta.getStaNo(), errMsg,jsonObject.getInteger("code"),wrkNo);
                             wrkNo++;
@@ -2259,7 +2266,8 @@
                 WrkMast wrkMast = wrkMastMapper.selectById(staProtocol.getWorkNo());
                 if (null == wrkMast) {
                     if(staProtocol.getWorkNo() > 9999){ //寮傚父閫�鍑�
-                        MessageQueue.offer(SlaveType.Led, 2, new Task(3, "寮傚父閫�鍑�"));
+                        String err = basDevpOptService.getErr(staProtocol.getWorkNo());
+                        MessageQueue.offer(SlaveType.Led, led.getId(), new Task(3, err));
                     }
                     continue;
                 }
@@ -2390,6 +2398,8 @@
             // 鍛戒护闆嗗悎
             boolean reset = true;
             for (Integer staNo : led.getStaArr()) {
+//                System.out.println("staArr = " + staNo);
+
                 // 鑾峰彇鍙夎溅绔欑偣
                 StaProtocol staProtocol = devpThread.getStation().get(staNo);
                 if (staProtocol == null) { continue; }
@@ -3553,7 +3563,8 @@
             }
             if(rgvProtocol.getStatusType1() == RgvStatusType.WORKING){
                 rgvThread.setPaking(true);
-            }else if(rgvProtocol.getTaskNo1() == 0 && rgvProtocol.getTaskNo2() == 0 && rgvProtocol.getStatusType1() == RgvStatusType.IDLE){
+            }
+            if(rgvProtocol.getTaskNo1() == 0 && rgvProtocol.getTaskNo2() == 0 && rgvProtocol.getStatusType1() == RgvStatusType.IDLE){
                 rgvThread.setPaking(true);
             }
             if(rgvProtocol.isLoaded1ing() && rgvProtocol.isLoaded2ing()){
@@ -4767,7 +4778,9 @@
 //                        News.info("{}鍙风珯鐐瑰瓨鍦ㄤ换鍔℃墽琛屼腑锛岃绛夊緟浠诲姟鎵ц瀹屾瘯锛歿}", outStaAgv.getStaNo(), barcode);
                         continue;
                     }
-
+                    if(barcode.equals("0")){
+                        continue;
+                    }
                     List<LocMast> locMastList = locMastService.selectList(new EntityWrapper<LocMast>().eq("barcode", barcode));
                     if (!locMastList.isEmpty()) {
                         News.info("{}鍙风珯鐐规潯鐮佷俊鎭噸澶嶏細{}", outStaAgv.getStaNo(), barcode);
@@ -4873,6 +4886,52 @@
         }
     }
 
+    /*
+     * agv浠诲姟鐢熸垚 寮傚父閫佸埌鍏ュ簱鍙�
+     * */
+    public synchronized void agvTaskCreateException() {
+        // 鏍规嵁杈撻�佺嚎plc閬嶅巻
+        for (DevpSlave devp : slaveProperties.getDevp()) {
+            Integer outStaAgv = 1041;
+            // 鑾峰彇鍏ュ簱绔欎俊鎭�
+            SiemensDevpThread devpThread = (SiemensDevpThread) SlaveConnection.get(SlaveType.Devp, devp.getId());
+            StaProtocol staProtocol = devpThread.getStation().get(outStaAgv);
+            if (staProtocol == null) {
+                continue;
+            } else {
+                staProtocol = staProtocol.clone();
+            }
+            // 鍒ゆ柇鏄惁婊¤冻鍏ュ簱鏉′欢
+            if (!staProtocol.isLoading()){
+                continue;
+            }
+
+            if (staProtocol.isAutoing() && staProtocol.getWorkNo() > 10000) {
+
+                // 鍒ゆ柇閲嶅宸ヤ綔妗�
+                List<BasAgvMast> basAgvMastList = basAgvMastService.selectList(new EntityWrapper<BasAgvMast>().eq("sta_no", 1037));
+                if (!basAgvMastList.isEmpty()) {
+                    News.info("{}鍙风珯鐐瑰瓨鍦ㄤ换鍔℃墽琛屼腑锛岀瓑寰呬换鍔℃墽琛屽畬姣�!!!", outStaAgv);
+                    continue;
+                }
+                // 浠诲姟鐢熸垚鍖� --------------------------------------------------------------------------
+
+                BasAgvMast basAgvMast = new BasAgvMast();
+                try {
+                    basAgvMast.setTaskNo(staProtocol.getWorkNo());
+                    basAgvMast.setSourceStaNo(1041);
+                    basAgvMast.setStaNo(1037);
+                    basAgvMast.setDevpId(devp.getId());
+                    basAgvMast.setIoType(3);//杈撻��==銆嬭緭閫佺嚎绔欑偣 3
+                    basAgvMastService.insert(basAgvMast);
+                    break;
+                } catch (Exception e) {
+                    News.error(JSON.toJSONString(e.getMessage()));
+                }
+            }
+        }
+    }
+
 
     /*
      * agv浠诲姟涓嬪彂:AGV搴撲綅==銆嬭緭閫佺嚎绔欑偣
@@ -4916,6 +4975,8 @@
         }
     }
 
+
+
     /*
      * agv浠诲姟涓嬪彂:AGV搴撲綅==銆婣GV搴撲綅
      * */

--
Gitblit v1.9.1