From e0276af68793e2e7d999f8cf31727ae0657fc84e Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@163.com>
Date: 星期四, 15 九月 2022 15:32:44 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/core/thread/SiemensCrnThread.java      |    2 
 src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java |  126 +++++++++++++++++-------------
 src/main/webapp/views/ste.html                              |    4 
 src/main/java/com/zy/core/enums/SteTaskModeType.java        |   49 ++++++++----
 4 files changed, 106 insertions(+), 75 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 3fb68ff..2f813e9 100644
--- a/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
@@ -451,18 +451,20 @@
                 log.error("鍏ュ簱 ===>> 鍫嗗灈鏈虹珯鐐瑰湪鏁版嵁搴撲笉瀛樺湪, 绔欑偣缂栧彿={}", crnStn.getStaNo());
                 continue;
             }
-            if (staProtocol.isAutoing() && staProtocol.isLoading() && staProtocol.getWorkNo() > 0 && staProtocol.isInEnable()
-                    && staDetl.getCanining()!=null && staDetl.getCanining().equals("Y")) {
-                flag = true;
-            }
-            if (!flag) {
-                continue;
-            }
             // 鑾峰彇宸ヤ綔鐘舵�佷负 2,3,4,5,6 鐨勫叆搴撳伐浣滄。
             WrkMast wrkMast = wrkMastMapper.selectPakInStep23456(slave.getId(), staProtocol.getWorkNo().intValue(), crnStn.getStaNo());
             if(null == wrkMast) {
                 log.error("{}绔欑偣鏌ヨ鏃犲緟鍏ュ簱鏁版嵁 宸ヤ綔鍙�={}", crnStn.getStaNo(), staProtocol.getWorkNo());
                 continue;
+            }
+            if (wrkMast.getWrkSts() < 3) {
+                if (staProtocol.isAutoing() && staProtocol.isLoading() && staProtocol.getWorkNo() > 0 && staProtocol.isInEnable()
+                        && staDetl.getCanining()!=null && staDetl.getCanining().equals("Y")) {
+                    flag = true;
+                }
+                if (!flag) {
+                    continue;
+                }
             }
             // 鑾峰彇搴撲綅淇℃伅
             LocMast locMast = locMastService.selectById(wrkMast.getLocNo());
@@ -857,7 +859,7 @@
                     crnCommand.setCrnNo(crnProtocol.getCrnNo()); // 鍫嗗灈鏈虹紪鍙�
                     crnCommand.setTaskNo(wrkMast.getWrkNo().shortValue()); // 宸ヤ綔鍙�
                     crnCommand.setAckFinish((short) 0);  // 浠诲姟瀹屾垚纭浣�
-                    crnCommand.setTaskMode(CrnTaskModeType.LOC_MOVE); // 浠诲姟妯″紡:  搴撲綅绉昏浆
+                    crnCommand.setTaskMode(CrnTaskModeType.STE_MOVE); // 浠诲姟妯″紡:  搴撲綅绉昏浆
                     crnCommand.setSourcePosX(steProtocol.getRow());     // 婧愬簱浣嶆帓
                     crnCommand.setSourcePosY(steProtocol.getBay());     // 婧愬簱浣嶅垪
                     crnCommand.setSourcePosZ(steProtocol.getLev());     // 婧愬簱浣嶅眰
@@ -886,7 +888,7 @@
                     crnCommand.setCrnNo(crnProtocol.getCrnNo()); // 鍫嗗灈鏈虹紪鍙�
                     crnCommand.setTaskNo(wrkMast.getWrkNo().shortValue()); // 宸ヤ綔鍙�
                     crnCommand.setAckFinish((short) 0);  // 浠诲姟瀹屾垚纭浣�
-                    crnCommand.setTaskMode(CrnTaskModeType.LOC_MOVE); // 浠诲姟妯″紡:  搴撲綅绉昏浆
+                    crnCommand.setTaskMode(CrnTaskModeType.STE_MOVE); // 浠诲姟妯″紡:  搴撲綅绉昏浆
                     crnCommand.setSourcePosX(steProtocol.getRow());     // 婧愬簱浣嶆帓
                     crnCommand.setSourcePosY(steProtocol.getBay());     // 婧愬簱浣嶅垪
                     crnCommand.setSourcePosZ(steProtocol.getLev());     // 婧愬簱浣嶅眰
@@ -1044,6 +1046,18 @@
                         if (!steThread.confirmPos()) {
                             log.error("{}鍙风┛姊溅閲嶆柊瀹氫綅澶辫触锛佷綔涓氬伐浣滄。浠诲姟鍙凤細{}", wrkMast.getSteNo(), wrkMast.getWrkNo());
                         }
+                        // 绌挎杞﹀幓寰呮満浣�
+                        BasSte basSte = basSteService.selectById(wrkMast.getSteNo());
+                        SteCommand steCommand = new SteCommand();
+                        steCommand.setSteNo(wrkMast.getSteNo()); // 绌挎杞︾紪鍙�
+                        steCommand.setTaskNo(9999); // 宸ヤ綔鍙�
+                        steCommand.setTaskMode(SteTaskModeType.findWaiting(basSte.getRow())); // 浠诲姟妯″紡:  鍘昏繎鐐� 绛夊緟鍫嗗灈鏈哄弶鍙�
+//                        steCommand.setRow(Utils.getGroupRow(steProtocol.getRow().intValue()).shortValue());
+//                        steCommand.setBay(steProtocol.getBay());
+//                        steCommand.setLev(steProtocol.getLev());
+                        if (!MessageQueue.offer(SlaveType.Ste, wrkMast.getSteNo(), new Task(2, steCommand))) {
+                            log.error("绌挎杞﹀緟鏈轰綅鍛戒护涓嬪彂澶辫触锛岀┛姊溅鍙�={}锛屼换鍔℃暟鎹�={}", wrkMast.getSteNo(), JSON.toJSON(steCommand));
+                        }
                     } else {
                         log.error("淇敼宸ヤ綔妗g姸鎬� 4.杩佸叆灏忚溅 => 6.灏忚溅寰呭叆 澶辫触锛侊紒锛屽伐浣滃彿={}", wrkMast.getWrkNo());
                     }
@@ -1116,54 +1130,56 @@
             SteProtocol steProtocol = steThread.getSteProtocol();
             if (steProtocol == null) { continue; }
             if (steProtocol.getWaiting() && steProtocol.getTaskNo() != 0) {
-                // 鏌ヨ鏄惁鏈夊緟鍏ュ簱鐨勪换鍔�
-                WrkMast wrkMast = wrkMastMapper.selectCarWaiting(steProtocol.getTaskNo().intValue());
-                if (wrkMast == null) { continue; }
+                if (steProtocol.getTaskNo() == 9999) {
+                    steThread.setResetFlag(true);
+                } else {
+                    // 鏌ヨ鏄惁鏈夊緟鍏ュ簱鐨勪换鍔�
+                    WrkMast wrkMast = wrkMastMapper.selectCarWaiting(steProtocol.getTaskNo().intValue());
+                    if (wrkMast == null) { continue; }
 
-                switch (wrkMast.getWrkSts().intValue()) {
-                    case 2:
-                        // 淇敼宸ヤ綔妗g姸鎬� 2.璁惧涓婅蛋 => 3.灏忚溅寰呮惉
-                        wrkMast.setWrkSts(3L);
-                        wrkMast.setModiTime(now);
-                        if (wrkMastMapper.updateById(wrkMast) == 0) {
-                            log.error("淇敼宸ヤ綔妗g姸鎬� 2.璁惧涓婅蛋 => 3.灏忚溅寰呮惉 澶辫触锛侊紒锛屽伐浣滃彿={}", wrkMast.getWrkNo());
-                        } else {
-                            steThread.setResetFlag(true);
-                        }
-                        break;
-                    case 8:
-                        // 淇敼宸ヤ綔妗g姸鎬� 8.灏忚溅鎼叆搴� => 9.鍏ュ簱瀹屾垚
-                        wrkMast.setWrkSts(9L);
-                        wrkMast.setModiTime(now);
-                        if (wrkMastMapper.updateById(wrkMast) == 0) {
-                            log.error("淇敼宸ヤ綔妗g姸鎬� 8.灏忚溅鎼叆搴� => 9.鍏ュ簱瀹屾垚 澶辫触锛侊紒锛屽伐浣滃彿={}", wrkMast.getWrkNo());
-                        } else {
-                            steThread.setResetFlag(true);
-                        }
-                        break;
-                    case 11:
-                        // 淇敼宸ヤ綔妗g姸鎬� 11.鐢熸垚鍑哄簱ID => 12.灏忚溅寰呮惉
-                        wrkMast.setWrkSts(12L);
-                        wrkMast.setModiTime(now);
-                        if (wrkMastMapper.updateById(wrkMast) == 0) {
-                            log.error("淇敼宸ヤ綔妗g姸鎬� 11.鐢熸垚鍑哄簱ID => 12.灏忚溅寰呮惉 澶辫触锛侊紒锛屽伐浣滃彿={}", wrkMast.getWrkNo());
-                        } else {
-                            steThread.setResetFlag(true);
-                        }
-                        break;
-                    case 14:
-                        // 淇敼宸ヤ綔妗g姸鎬� 14.灏忚溅鎼嚭搴� => 15.绛夊緟鍚婅溅
-                        wrkMast.setWrkSts(15L);
-                        wrkMast.setModiTime(now);
-                        if (wrkMastMapper.updateById(wrkMast) == 0) {
-                            log.error("淇敼宸ヤ綔妗g姸鎬� 14.灏忚溅鎼嚭搴� => 15.绛夊緟鍚婅溅 澶辫触锛侊紒锛屽伐浣滃彿={}", wrkMast.getWrkNo());
-                        } else {
-                            steThread.setResetFlag(true);
-                        }
-                        break;
+                    switch (wrkMast.getWrkSts().intValue()) {
+                        case 2:
+                            // 淇敼宸ヤ綔妗g姸鎬� 2.璁惧涓婅蛋 => 3.灏忚溅寰呮惉
+                            wrkMast.setWrkSts(3L);
+                            wrkMast.setModiTime(now);
+                            if (wrkMastMapper.updateById(wrkMast) == 0) {
+                                log.error("淇敼宸ヤ綔妗g姸鎬� 2.璁惧涓婅蛋 => 3.灏忚溅寰呮惉 澶辫触锛侊紒锛屽伐浣滃彿={}", wrkMast.getWrkNo());
+                            } else {
+                                steThread.setResetFlag(true);
+                            }
+                            break;
+                        case 8:
+                            // 淇敼宸ヤ綔妗g姸鎬� 8.灏忚溅鎼叆搴� => 9.鍏ュ簱瀹屾垚
+                            wrkMast.setWrkSts(9L);
+                            wrkMast.setModiTime(now);
+                            if (wrkMastMapper.updateById(wrkMast) == 0) {
+                                log.error("淇敼宸ヤ綔妗g姸鎬� 8.灏忚溅鎼叆搴� => 9.鍏ュ簱瀹屾垚 澶辫触锛侊紒锛屽伐浣滃彿={}", wrkMast.getWrkNo());
+                            } else {
+                                steThread.setResetFlag(true);
+                            }
+                            break;
+                        case 11:
+                            // 淇敼宸ヤ綔妗g姸鎬� 11.鐢熸垚鍑哄簱ID => 12.灏忚溅寰呮惉
+                            wrkMast.setWrkSts(12L);
+                            wrkMast.setModiTime(now);
+                            if (wrkMastMapper.updateById(wrkMast) == 0) {
+                                log.error("淇敼宸ヤ綔妗g姸鎬� 11.鐢熸垚鍑哄簱ID => 12.灏忚溅寰呮惉 澶辫触锛侊紒锛屽伐浣滃彿={}", wrkMast.getWrkNo());
+                            } else {
+                                steThread.setResetFlag(true);
+                            }
+                            break;
+                        case 14:
+                            // 淇敼宸ヤ綔妗g姸鎬� 14.灏忚溅鎼嚭搴� => 15.绛夊緟鍚婅溅
+                            wrkMast.setWrkSts(15L);
+                            wrkMast.setModiTime(now);
+                            if (wrkMastMapper.updateById(wrkMast) == 0) {
+                                log.error("淇敼宸ヤ綔妗g姸鎬� 14.灏忚溅鎼嚭搴� => 15.绛夊緟鍚婅溅 澶辫触锛侊紒锛屽伐浣滃彿={}", wrkMast.getWrkNo());
+                            } else {
+                                steThread.setResetFlag(true);
+                            }
+                            break;
+                    }
                 }
-
-
             }
         }
     }
diff --git a/src/main/java/com/zy/core/enums/SteTaskModeType.java b/src/main/java/com/zy/core/enums/SteTaskModeType.java
index 74d5577..6de32d4 100644
--- a/src/main/java/com/zy/core/enums/SteTaskModeType.java
+++ b/src/main/java/com/zy/core/enums/SteTaskModeType.java
@@ -15,8 +15,8 @@
 //    MOVE_RIGHT(6, "鍙崇Щ搴�"),    // 鍙崇Щ搴�
     GO_ORIGIN(7, "鍘诲彸绔�"),    // 鍥炲師鐐�
     BACK_ORIGIN(8, "鍘诲乏绔�"),      // 鍥炲弽鍘熺偣
-//    TO_A(9, "A鐐�"),        // A鐐�
-//    TO_B(10, "B鐐�"),       // B鐐�
+    WAITING_RIGHT(9, "鍙冲緟鏈�"),        // A鐐�
+    WAITING_LEFT(10, "宸﹀緟鏈�"),       // B鐐�
 //    FIT_LEFT(11, "宸︽惉绉�"),   // 宸︽惉绉�
 //    FIT_RIGHT(12, "鍙虫惉绉�"),      // 鍙虫惉绉�
     CHARGE(13, "鍏呯數"),         // 鍏呯數
@@ -53,21 +53,6 @@
             }
         }
         return null;
-    }
-
-    public static SteTaskModeType findOriginByLoc(String locNo) {
-        switch (Utils.getGroupRow(locNo)) {
-            case 3:
-            case 11:
-            case 18:
-                return SteTaskModeType.GO_ORIGIN;   // 鍙�
-            case 4:
-            case 12:
-            case 19:
-                return SteTaskModeType.BACK_ORIGIN; // 宸�
-            default:
-                throw new CoolException("瑙f瀽绌挎杞﹀師鐐瑰畾浣嶅け璐�");
-        }
     }
 
     public static SteTaskModeType findInByLoc(String locNo) {
@@ -193,4 +178,34 @@
         }
     }
 
+    public static SteTaskModeType findWaiting(Integer row) {
+        switch (row) {
+            case 1:
+            case 2:
+            case 3:
+            case 8:
+            case 9:
+            case 10:
+            case 11:
+            case 15:
+            case 16:
+            case 17:
+            case 18:
+                return SteTaskModeType.WAITING_LEFT;
+            case 4:
+            case 5:
+            case 6:
+            case 7:
+            case 12:
+            case 13:
+            case 14:
+            case 19:
+            case 20:
+            case 21:
+                return SteTaskModeType.WAITING_RIGHT;
+            default:
+                throw new CoolException("瑙f瀽绌挎杞﹀師鐐瑰畾浣嶅け璐�");
+        }
+    }
+
 }
diff --git a/src/main/java/com/zy/core/thread/SiemensCrnThread.java b/src/main/java/com/zy/core/thread/SiemensCrnThread.java
index dd1a66d..6e43a34 100644
--- a/src/main/java/com/zy/core/thread/SiemensCrnThread.java
+++ b/src/main/java/com/zy/core/thread/SiemensCrnThread.java
@@ -269,7 +269,7 @@
 
         if (result != null && result.IsSuccess) {
             Thread.sleep(200);
-            this.readStatus();
+//            this.readStatus();
             log.info("鍫嗗灈鏈哄懡浠や笅鍙慬id:{}] >>>>> {}", slave.getId(), JSON.toJSON(command));
             OutputQueue.CRN.offer(MessageFormat.format("銆恵0}銆慬id:{1}] >>>>> 鍛戒护涓嬪彂锛� {2}", DateUtils.convert(new Date()), slave.getId(), JSON.toJSON(command)));
             return true;
diff --git a/src/main/webapp/views/ste.html b/src/main/webapp/views/ste.html
index 6cb2810..fcfa9be 100644
--- a/src/main/webapp/views/ste.html
+++ b/src/main/webapp/views/ste.html
@@ -115,8 +115,8 @@
 <!--                            <button class="item" onclick="steOperator(6)">鍙崇Щ搴�</button>-->
                             <button class="item" onclick="steOperator(8)">鍘诲乏绔�</button>
                             <button class="item" onclick="steOperator(7)">鍘诲彸绔�</button>
-<!--                            <button class="item" onclick="steOperator(9)">A 鐐�</button>-->
-<!--                            <button class="item" onclick="steOperator(10)">B 鐐�</button>-->
+                            <button class="item" onclick="steOperator(10)">宸﹀緟鏈�</button>
+                            <button class="item" onclick="steOperator(9)">鍙冲緟鏈�</button>
 <!--                            <button class="item" onclick="steOperator(11)">宸︽惉绉�</button>-->
 <!--                            <button class="item" onclick="steOperator(12)">鍙虫惉绉�</button>-->
                             <button class="item" onclick="steOperator(13)">鍏呯數</button>

--
Gitblit v1.9.1