From 357dde734fdb70d4918a6b6a1c6469952a2bcf09 Mon Sep 17 00:00:00 2001
From: lsh <lsh123456>
Date: 星期一, 15 七月 2024 23:11:58 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/core/model/CrnSlave.java               |    2 
 src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java |  147 ++++++++++++++++++++++++++++++++++++
 src/main/java/com/zy/core/thread/SiemensDevpThread.java     |   57 ++++++++++++++
 src/main/resources/application.yml                          |   12 ++
 4 files changed, 213 insertions(+), 5 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 cb828b8..f24c52a 100644
--- a/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
@@ -1901,6 +1901,141 @@
                 }
             }
 
+            StaProtocol staProtocolOther = devpThread.getStation().get(crnStn.getStaNoOther());
+            if (staProtocolOther == null) {
+                continue;
+            } else {
+                staProtocolOther = staProtocolOther.clone();
+            }
+
+            // 鏌ヨ绔欑偣璇︾粏淇℃伅
+            BasDevp staDetlOther = basDevpService.selectById(crnStn.getStaNoOther());
+            if (staDetlOther == null) {
+                log.error("鍏ュ簱 ===>> 鍫嗗灈鏈虹珯鐐瑰湪鏁版嵁搴撲笉瀛樺湪, 绔欑偣缂栧彿={}", crnStn.getStaNoOther());
+                continue;
+            }
+            if (staProtocolOther.getWorkNo()!=0){
+                WrkMast wrkMastOther = wrkMastMapper.selectPakInStep3(staProtocolOther.getWorkNo());
+                if (Cools.isEmpty(wrkMastOther)){
+                    log.error("Other鏌ヨ宸ヤ綔妗f鏃犳暟鎹�--宸ヤ綔鍙穥},绔欑偣鍙凤細{}", staProtocolOther.getWorkNo(),staProtocolOther.getSiteId());
+                    continue;
+                }
+                // 鑾峰彇搴撲綅淇℃伅
+                LocMast locMastOther = locMastService.selectById(wrkMastOther.getLocNo());
+                if (locMastOther == null) {
+                    log.error("鏌ヨ搴撳瓨鏃犳暟鎹�--搴撲綅鍙穥}", locMastOther.getLocNo());
+                    continue;
+                }
+                if (!locMastOther.getLocSts().equals("S") && !locMastOther.getLocSts().equals("Q")) {
+                    log.error("鍏ュ簱鎿嶄綔搴撲綅鐘舵�佷笉绗﹀悎--鐘舵��, 搴撲綅鍙�={}锛屽簱浣嶇姸鎬�={}", wrkMastOther.getLocNo(), locMastOther.getLocSts());
+                    continue;
+                }
+                if (locMastOther.getBay1()!=81){
+                    if (staProtocolOther.isAutoing() && staProtocolOther.isLoading()
+                            && staProtocolOther.isInEnable() && staDetlOther.getCanining() != null && staDetlOther.getCanining().equals("Y")) {
+                        // 鍛戒护涓嬪彂鍖� --------------------------------------------------------------------------
+                        CrnCommandParam crnCommandParam = new CrnCommandParam();
+                        crnCommandParam.setCrnNo(slave.getId()); // 鍫嗗灈鏈虹紪鍙�
+
+                        crnCommandParam.setTaskNo2(wrkMast.getWrkNo().shortValue()); // 宸ヤ綔鍙�
+                        crnCommandParam.setAckFinish2((short) 0);  // 浠诲姟瀹屾垚纭浣�
+                        crnCommandParam.setTaskMode2(CrnTaskModeType.SEPARATE_TAKE); // 浠诲姟妯″紡:  鍗曞彇璐�
+                        crnCommandParam.setSourcePosX2(crnStn.getRow().shortValue());     // 婧愬簱浣嶆帓
+                        crnCommandParam.setSourcePosY2(crnStn.getBay().shortValue());     // 婧愬簱浣嶅垪
+                        crnCommandParam.setSourcePosZ2(crnStn.getLev().shortValue());     // 婧愬簱浣嶅眰
+                        crnCommandParam.setDestinationPosX2((short)0);     // 鐩爣搴撲綅鎺�
+                        crnCommandParam.setDestinationPosY2((short)0);     // 鐩爣搴撲綅鍒�
+                        crnCommandParam.setDestinationPosZ2((short)0);     // 鐩爣搴撲綅灞�
+
+                        crnCommandParam.setTaskNo(wrkMastOther.getWrkNo().shortValue()); // 宸ヤ綔鍙�
+                        crnCommandParam.setAckFinish((short) 0);  // 浠诲姟瀹屾垚纭浣�
+                        crnCommandParam.setTaskMode(CrnTaskModeType.SEPARATE_TAKE); // 浠诲姟妯″紡:  鍗曞彇璐�
+                        crnCommandParam.setSourcePosX(crnStn.getRow().shortValue());     // 婧愬簱浣嶆帓
+                        crnCommandParam.setSourcePosY(crnStn.getBay().shortValue());     // 婧愬簱浣嶅垪
+                        crnCommandParam.setSourcePosZ(crnStn.getLev().shortValue());     // 婧愬簱浣嶅眰
+                        crnCommandParam.setDestinationPosX((short)0);     // 鐩爣搴撲綅鎺�
+                        crnCommandParam.setDestinationPosY((short)0);     // 鐩爣搴撲綅鍒�
+                        crnCommandParam.setDestinationPosZ((short)0);     // 鐩爣搴撲綅灞�
+                        if (!MessageQueue.offer(SlaveType.Crn, crnCommandParam.getCrnNo(), new Task(9, crnCommandParam))) {
+                            log.error("鍫嗗灈鏈哄懡浠や笅鍙戝け璐ワ紝鍫嗗灈鏈哄彿={}锛屼换鍔℃暟鎹�={}", wrkMast.getCrnNo(), JSON.toJSONString(crnCommandParam));
+                        } else {
+                            // 淇敼宸ヤ綔妗g姸鎬� 2.璁惧涓婅蛋 => 3.鍚婅溅鍏ュ簱涓�
+                            Date now = new Date();
+                            wrkMast.setWrkSts(3L);
+                            wrkMast.setCrnStrTime(now);
+                            wrkMast.setModiTime(now);
+                            WrkMastSplitTwin wrkMastSplitTwin = new WrkMastSplitTwin(wrkMast,2,now);
+                            wrkMastSplitTwin.setWrkSts(1);
+                            wrkMastSplitTwin.setWrkStart(wrkMast.getStaNo().toString());
+                            wrkMastSplitTwin.setWrkEnd(wrkMast.getLocNo());
+                            wrkMastSplitTwin.setStartRow(crnStn.getRow());
+                            wrkMastSplitTwin.setStartBay(crnStn.getBay());
+                            wrkMastSplitTwin.setStartLev(crnStn.getLev());
+                            wrkMastSplitTwin.setEndRow(locMast.getRow1());
+                            wrkMastSplitTwin.setEndBay(locMast.getBay1());
+                            wrkMastSplitTwin.setEndLev(locMast.getLev1());
+                            wrkMastSplitTwin.setWrkType(1);
+                            wrkMastSplitTwin.setIoType(1);
+
+                            wrkMastOther.setWrkSts(3L);
+                            wrkMastOther.setCrnStrTime(now);
+                            wrkMastOther.setModiTime(now);
+                            WrkMastSplitTwin wrkMastSplitTwinOther = new WrkMastSplitTwin(wrkMastOther,1,now);
+                            wrkMastSplitTwinOther.setWrkSts(1);
+                            wrkMastSplitTwinOther.setWrkStart(wrkMastOther.getStaNo().toString());
+                            wrkMastSplitTwinOther.setWrkEnd(wrkMastOther.getLocNo());
+                            wrkMastSplitTwinOther.setStartRow(crnStn.getRow());
+                            wrkMastSplitTwinOther.setStartBay(crnStn.getBay());
+                            wrkMastSplitTwinOther.setStartLev(crnStn.getLev());
+                            wrkMastSplitTwinOther.setEndRow(locMastOther.getRow1());
+                            wrkMastSplitTwinOther.setEndBay(locMastOther.getBay1());
+                            wrkMastSplitTwinOther.setEndLev(locMastOther.getLev1());
+                            wrkMastSplitTwinOther.setWrkType(1);
+                            wrkMastSplitTwinOther.setIoType(1);
+
+                            if (wrkMastMapper.updateById(wrkMast) == 0) {
+                                log.error("淇敼宸ヤ綔妗g姸鎬� 2.璁惧涓婅蛋 => 3.鍚婅溅鍏ュ簱涓� 澶辫触锛侊紒锛屽伐浣滃彿={}", wrkMast.getWrkNo());
+                            }
+
+                            if (wrkMastSplitTwinMapper.insert(wrkMastSplitTwin)==0){
+                                log.error("鍒涘缓 鍫嗗灈鏈烘墽琛屼换鍔� 澶辫触锛侊紒锛屽伐浣滃彿={}锛屽爢鍨涙満鍙�={}", wrkMast.getWrkNo(),wrkMast.getCrnNo());
+                            }
+
+                            if (wrkMastMapper.updateById(wrkMastOther) == 0) {
+                                log.error("Other淇敼宸ヤ綔妗g姸鎬� 2.璁惧涓婅蛋 => 3.鍚婅溅鍏ュ簱涓� 澶辫触锛侊紒锛屽伐浣滃彿={}", wrkMast.getWrkNo());
+                            }
+
+                            if (wrkMastSplitTwinMapper.insert(wrkMastSplitTwinOther)==0){
+                                log.error("Other鍒涘缓 鍫嗗灈鏈烘墽琛屼换鍔� 澶辫触锛侊紒锛屽伐浣滃彿={}锛屽爢鍨涙満鍙�={}", wrkMast.getWrkNo(),wrkMast.getCrnNo());
+                            }
+                            return;
+                        }
+                    }
+                }
+                return;
+            }
+            StaProtocol staProtocolOther1 = devpThread.getStation().get(crnStn.getStaNoOther1());
+            if (staProtocolOther1 == null) {
+                continue;
+            } else {
+                staProtocolOther1 = staProtocolOther1.clone();
+            }
+
+            if (staProtocolOther1.isAutoing() && staProtocolOther1.getWorkNo()!=0){
+                return;
+            }
+
+
+            StaProtocol staProtocolOther2 = devpThread.getStation().get(crnStn.getStaNoOther2());
+            if (staProtocolOther2 == null) {
+                continue;
+            } else {
+                staProtocolOther2 = staProtocolOther2.clone();
+            }
+            if (staProtocolOther2.isAutoing() && staProtocolOther2.getWorkNo()!=0){
+                return;
+            }
+            crnStation = 2;
             // 鍛戒护涓嬪彂鍖� --------------------------------------------------------------------------
             CrnCommand crnCommand = new CrnCommand();
             crnCommand.setCrnNo(slave.getId()); // 鍫嗗灈鏈虹紪鍙�
@@ -1913,7 +2048,17 @@
             crnCommand.setDestinationPosX((short)0);     // 鐩爣搴撲綅鎺�
             crnCommand.setDestinationPosY((short)0);     // 鐩爣搴撲綅鍒�
             crnCommand.setDestinationPosZ((short)0);     // 鐩爣搴撲綅灞�
-            if (!MessageQueue.offer(SlaveType.Crn, wrkMast.getCrnNo(), new Task(crnStation==1? 2:5, crnCommand))) {
+
+            staProtocol.setWorkNo(wrkMast.getWrkNo());
+            staProtocol.setStaNo(wrkMast.getStaNo());
+
+            devpThread.setPakMk(staProtocol.getSiteId(), false);
+
+            if (!MessageQueue.offer(SlaveType.Devp, crnStn.getDevpPlcId(), new Task(99, crnCommand.getCrnNo()-2))) {
+                log.error("杈撻�佺嚎閿佸畾鍛戒护涓嬪彂澶辫触锛屽爢鍨涙満鍙�={}锛屼换鍔℃暟鎹�={}", wrkMast.getCrnNo(), crnCommand.getCrnNo()-2);
+                continue;
+            }
+            if (!MessageQueue.offer(SlaveType.Crn, wrkMast.getCrnNo(), new Task(5, crnCommand))) {
                 log.error("鍫嗗灈鏈哄懡浠や笅鍙戝け璐ワ紝鍫嗗灈鏈哄彿={}锛屼换鍔℃暟鎹�={}", wrkMast.getCrnNo(), JSON.toJSONString(crnCommand));
             } else {
                 // 淇敼宸ヤ綔妗g姸鎬� 2.璁惧涓婅蛋 => 3.鍚婅溅鍏ュ簱涓�
diff --git a/src/main/java/com/zy/core/model/CrnSlave.java b/src/main/java/com/zy/core/model/CrnSlave.java
index 0c2b392..29f843e 100644
--- a/src/main/java/com/zy/core/model/CrnSlave.java
+++ b/src/main/java/com/zy/core/model/CrnSlave.java
@@ -39,6 +39,8 @@
 
         // 鍫嗗灈鏈虹珯鐐圭紪鍙�
         private Integer staNoOther;
+        private Integer staNoOther1;
+        private Integer staNoOther2;
 
         // 鎺�
         private Integer row;
diff --git a/src/main/java/com/zy/core/thread/SiemensDevpThread.java b/src/main/java/com/zy/core/thread/SiemensDevpThread.java
index 089e61e..851cfce 100644
--- a/src/main/java/com/zy/core/thread/SiemensDevpThread.java
+++ b/src/main/java/com/zy/core/thread/SiemensDevpThread.java
@@ -207,6 +207,8 @@
                     case 11:
                         write11((StaProtocol)task.getData());
                         break;
+                    case 99:
+                        write99((Integer) task.getData());
                     default:
                         break;
                 }
@@ -968,7 +970,60 @@
         }
     }
 
-    // 鏇存柊鍏ュ嚭搴撴ā寮�
+    private void write99(Integer devNo) throws InterruptedException {
+        String resultV1 = "";
+        switch (devNo){
+            case 1:
+                resultV1 = "DB100.1824";
+                break;
+            case 2:
+                resultV1 = "DB100.1836";
+                break;
+            case 3:
+                resultV1 = "DB100.1848";
+                break;
+            default:
+                return;
+        }
+        OperateResult result = siemensS7Net.Write(resultV1, (short) 1);
+        Integer writeCount = 0;
+        do {
+            try{
+                if(!result.IsSuccess){
+                    log.error("鍐欏叆RGV鏁版嵁澶辫触锛岄噸鏂颁笅鍙戜换鍔�  鍐欏叆鐩存帴澶辫触 ===>> [id:{}],{},[鍐欏叆娆℃暟:{}]", slave.getId(), JSON.toJSONString(devNo),writeCount);
+                    result = siemensS7Net.Write(resultV1, (short) 1);
+                    Thread.sleep(100);
+                    writeCount++;
+                    continue;
+                }
+                OperateResultExOne<byte[]> resultRead1 = siemensS7Net.Read("resultV1", (short) 2);
+                if (resultRead1.IsSuccess) {
+                    short transInt16 = siemensS7Net.getByteTransform().TransInt16(resultRead1.Content, 0);
+                    if (transInt16 == (short) 1){
+                        break;
+                    } else {
+                        log.error("鍐欏叆RGV鏁版嵁澶辫触锛岄噸鏂颁笅鍙戜换鍔�  鍐欏叆鐩存帴澶辫触 ===>> [id:{}],{},[鍐欏叆娆℃暟:{}]", slave.getId(), JSON.toJSONString(devNo),writeCount);
+                        result = siemensS7Net.Write(resultV1, (short) 1);
+                        Thread.sleep(100);
+                        writeCount++;
+                        continue;
+                    }
+                } else {
+                    log.error("鍐欏叆RGV鏁版嵁澶辫触锛岄噸鏂颁笅鍙戜换鍔�  鍐欏叆鐩存帴澶辫触 ===>> [id:{}],{},[鍐欏叆娆℃暟:{}]", slave.getId(), JSON.toJSONString(devNo),writeCount);
+                    result = siemensS7Net.Write(resultV1, (short) 1);
+                    Thread.sleep(100);
+                    writeCount++;
+                    continue;
+                }
+            }catch (Exception e){
+                log.error("鍐欏叆鏁版嵁鍚庡洖璇诲嚭閿�,寮傚父锛�"+e);
+            }
+            writeCount++;
+        } while (writeCount<6);
+    }
+
+
+        // 鏇存柊鍏ュ嚭搴撴ā寮�
     private void updateIoMode() throws InterruptedException {
         if (this.ioModeOf2F != IoModeType.NONE) {
             if (!siemensS7Net.Write("DB100.180", this.ioModeOf2F.id).IsSuccess) {
diff --git a/src/main/resources/application.yml b/src/main/resources/application.yml
index 46c8cf6..6f51d81 100644
--- a/src/main/resources/application.yml
+++ b/src/main/resources/application.yml
@@ -118,7 +118,9 @@
     crnInStn[0]:
       devpPlcId: ${wcs-slave.devp[0].id}
       staNo: 261
-      staNoOther: 261
+    staNoOther: 257
+      staNoOther1: 256
+      staNoOther2: 255
       row: 10
       bay: 1
       lev: 1
@@ -144,7 +146,9 @@
     crnInStn[0]:
       devpPlcId: ${wcs-slave.devp[0].id}
       staNo: 260
-      staNoOther: 260
+      staNoOther: 248
+      staNoOther1: 247
+      staNoOther2: 246
       row: 12
       bay: 1
       lev: 1
@@ -170,7 +174,9 @@
     crnInStn[0]:
       devpPlcId: ${wcs-slave.devp[0].id}
       staNo: 259
-      staNoOther: 259
+      staNoOther: 239
+      staNoOther1: 238
+      staNoOther2: 237
       row: 14
       bay: 1
       lev: 1

--
Gitblit v1.9.1