From 607f84e522f02a87eefd9592245f6393b5164ce6 Mon Sep 17 00:00:00 2001
From: Junjie <540245094@qq.com>
Date: 星期二, 12 十二月 2023 14:27:49 +0800
Subject: [PATCH] #小车跨层调度逻辑

---
 src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java |  136 +++++++++++++++++---------------------------
 1 files changed, 53 insertions(+), 83 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 323e43a..e7e7fba 100644
--- a/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
@@ -633,10 +633,6 @@
             for (DevpSlave devp : slaveProperties.getDevp()) {
                 // 閬嶅巻鎷f枡鍏ュ簱鍙�
                 for (DevpSlave.Sta pickSta : devp.getPickInSta()) {
-//                if (pickSta.getStaNo() == 325 || pickSta.getStaNo() == 331 || pickSta.getStaNo() == 333 || pickSta.getStaNo() == 339) {
-//                    continue;
-//                }
-
                     // 鑾峰彇鎷f枡鍏ュ簱绔欎俊鎭�
                     DevpThread devpThread = (DevpThread) SlaveConnection.get(SlaveType.Devp, devp.getId());
                     StaProtocol staProtocol = devpThread.getStation().get(pickSta.getStaNo());
@@ -648,10 +644,33 @@
                     if (staProtocol.isAutoing()
                             && staProtocol.isLoading()
                             && staProtocol.isInEnable()
-                            && (staProtocol.getWorkNo() > 0)
+//                            && (staProtocol.getWorkNo() > 0)
                             && staProtocol.isPakMk()) {
 
-                        WrkMast wrkMast = wrkMastMapper.selectByWorkNo(staProtocol.getWorkNo().intValue());
+                        WrkMast wrkMast = null;
+                        if (pickSta.getStaNo() == 325 || pickSta.getStaNo() == 331 || pickSta.getStaNo() == 333 || pickSta.getStaNo() == 339) {
+                            if (staProtocol.getWorkNo() == 0) {
+                                continue;
+                            }
+                            //鏍规嵁宸ヤ綔鍙锋悳绱㈠伐浣滄。
+                            wrkMast = wrkMastMapper.selectByWorkNo(staProtocol.getWorkNo().intValue());
+                        }else {
+                            //鏍规嵁鎵樼洏鐮佹悳绱㈠伐浣滄。
+                            // 鑾峰彇鏉$爜鎵弿浠俊鎭�
+                            BarcodeThread barcodeThread = (BarcodeThread) SlaveConnection.get(SlaveType.Barcode, pickSta.getBarcode());
+                            if (barcodeThread == null) {
+                                continue;
+                            }
+                            String barcode = barcodeThread.getBarcode();
+                            if (Cools.isEmpty(barcode)) {
+                                continue;
+                            }
+                            if ("NG".endsWith(barcode) || "NoRead".equals(barcode) || "empty".equals(barcode)) {
+                                continue;
+                            }
+                            wrkMast = wrkMastMapper.selectByBarcode(barcode);
+                        }
+
                         if (wrkMast == null) {//鎵句笉鍒板伐浣滄。
                             continue;
                         }
@@ -660,28 +679,6 @@
                                 || Cools.isEmpty(wrkMast.getStaNo()) || Cools.isEmpty(wrkMast.getSourceStaNo())) {
                             continue;
                         }
-
-                        //*********************鍚屽簱浣嶇粍鏍¢獙*********************
-                        boolean flag = false;
-                        String th = "";
-                        List<String> innerLoc = Utils.getGroupInnerLoc(wrkMast.getSourceLocNo());
-                        for (String loc : innerLoc) {
-                            LocMast locMast = locMastService.selectById(loc);
-                            if (locMast == null) {
-                                continue;
-                            }
-
-                            if (!locMast.getLocSts().equals("F")) {
-                                flag = true;
-                                th = loc + "搴撲綅瀛樺湪鏈洖搴撲换鍔�";
-                                break;
-                            }
-                        }
-                        if (flag) {
-                            News.info(th);
-                            continue;
-                        }
-                        //*********************鍚屽簱浣嶇粍鏍¢獙*********************
 
                         // 淇濆瓨宸ヤ綔涓绘。鍘嗗彶妗�
                         if (wrkMastMapper.saveWrkMastLog(wrkMast.getWrkNo()) == 0) {
@@ -696,7 +693,7 @@
                             param.setWrkNo(wrkMast.getWrkNo());
                             param.setBarcode(wrkMast.getBarcode());
                             param.setIoType(107);//鐩樼偣
-                            param.setSourceStaNo(wrkMast.getStaNo());
+                            param.setSourceStaNo(pickSta.getStaNo());
                             param.setLocType1(locMast.getLocType1());
                             String response = new HttpHandler.Builder()
                                     .setUri(wmsUrl)
@@ -3962,63 +3959,36 @@
         return true;
     }
 
-    /**
-     * 鍑哄叆搴撴ā寮忓垏鎹�
-     */
-    public synchronized void outAndIn() {
-        try {
-            // 鏍规嵁杈撻�佺嚎plc閬嶅巻
-            for (DevpSlave devp : slaveProperties.getDevp()) {
-                for (DevpSlave.Sta inSta : devp.getInSta()) {
-                    Thread.sleep(500);
-                    boolean a=true,b=true;
-                    List<WrkMast> wrkMasts = wrkMastMapper.selectAll(inSta.getStaNo());
-                    if (Cools.isEmpty(wrkMasts)){
-                        b=false;
-                    }else {
-                        for (WrkMast wrkMast:wrkMasts){
-                            if (wrkMast.getSourceStaNo() > wrkMast.getStaNo()){
-                                a=false;
-                                break;
-                            }
-                        }
-                    }
-                    switch (inSta.getStaNo()) {
-                        case 102://1F
-                            if (a && b){
-                                MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(3, 11));
-                            }else if (b){
-                                MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(3, 12));
-                            }else {
-                                MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(3, 10));
-                            }
-                            break;
-                        case 202://2F
-                            if (a && b){
-                                MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(3, 21));
-                            }else if (b){
-                                MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(3, 22));
-                            }else {
-                                MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(3, 20));
-                            }
-                            break;
-                        case 302://3F
-                            if (a && b){
-                                MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(3, 31));
-                            }else if (b){
-                                MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(3, 32));
-                            }else {
-                                MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(3, 30));
-                            }
-                            break;
-                    }
-                }
+    //鎵弿璁惧PakMk鏍囪鏄惁瓒呮椂
+    public synchronized void scanDevicePakMk() {
+        //鎵弿灏忚溅
+        for (ShuttleSlave slave : slaveProperties.getShuttle()) {
+            NyShuttleThread shuttleThread = (NyShuttleThread) SlaveConnection.get(SlaveType.Shuttle, slave.getId());
+            NyShuttleProtocol shuttleProtocol = shuttleThread.getShuttleProtocol();
+            if (shuttleProtocol == null) {
+                continue;
             }
 
-        } catch (Exception e) {
-            e.printStackTrace();
+            if ((System.currentTimeMillis() - shuttleProtocol.getSendTime() > (1000*60*5)) && shuttleProtocol.getPakMk()) {
+                //璁惧瓒呰繃5鍒嗛挓杩樻病澶嶄綅鏍囪
+                shuttleProtocol.setPakMk(false);//澶嶄綅鏍囪
+            }
         }
-    }
 
+        //鎵弿鎻愬崌鏈�
+        for (LiftSlave slave : slaveProperties.getLift()) {
+            LiftThread liftThread = (LiftThread) SlaveConnection.get(SlaveType.Lift, slave.getId());
+            LiftProtocol liftProtocol = liftThread.getLiftProtocol();
+            if (liftProtocol == null) {
+                continue;
+            }
+
+            if ((System.currentTimeMillis() - liftProtocol.getSendTime() > (1000*60*5)) && liftProtocol.getPakMk()) {
+                //璁惧瓒呰繃5鍒嗛挓杩樻病澶嶄綅鏍囪
+                liftProtocol.setPakMk(false);//澶嶄綅鏍囪
+            }
+        }
+
+    }
 
 }

--
Gitblit v1.9.1