From ad54981b1831bd6e31f45901bb2b08b8d7a3ff68 Mon Sep 17 00:00:00 2001
From: LSH
Date: 星期三, 31 五月 2023 15:36:11 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/core/thread/SiemensDevpThread.java |   57 +++++++++++++++++++++++++++++++++++++++++++++++----------
 1 files changed, 47 insertions(+), 10 deletions(-)

diff --git a/src/main/java/com/zy/core/thread/SiemensDevpThread.java b/src/main/java/com/zy/core/thread/SiemensDevpThread.java
index ea0e6b9..b4ee00b 100644
--- a/src/main/java/com/zy/core/thread/SiemensDevpThread.java
+++ b/src/main/java/com/zy/core/thread/SiemensDevpThread.java
@@ -42,18 +42,19 @@
     private Map<Integer, StaProtocol> station = new ConcurrentHashMap<>();
     private short heartBeatVal = 1;
     public static final ArrayList<Integer> staNos = new ArrayList<Integer>() {{
-        add(101);add(102);add(103);add(104);add(105);add(106);add(107);add(108);add(109);
-//        add(201);add(202);add(203);add(204);
-//        add(301);add(302);add(303);add(304);add(305);add(306);
+        add(101);add(102);add(103);add(104);
+        add(201);add(202);add(203);add(204);add(205);add(206);
+        add(207);add(208);add(209);add(210);add(211);add(212);
+        add(213);add(105);
     }};
 
     /**
      * 鏉$爜鏁伴噺
      */
-    private int barcodeSize = 1;
+    private int barcodeSize = 2;
     public IoModeType ioMode = IoModeType.NONE;
 
-    public int[] startSignal = new int[48];
+    public int[][] startSignal = new int[48][2];
 
     public SiemensDevpThread(DevpSlave slave) {
         this.slave = slave;
@@ -78,6 +79,15 @@
                     // 鍐欐暟鎹� ID+鐩爣绔�
                     case 2:
                         write((StaProtocol)task.getData());
+                        break;
+                    // 鍐欐暟鎹� 103绔欑偣鍐欏叆PACK鐮�
+                    case 4:
+                        write103((String)task.getData());
+                        break;
+                    // 鐏淇″彿
+                    case 5:
+                        StaProtocol staProtocol2 = (StaProtocol)task.getData();
+                        siemensS7Net.Write("DB102.0" + staProtocol2.getSiteId(), staProtocol2.getStaNo()==1);
                         break;
                     //澶嶄綅娴嬭瘯淇″彿
                     case 3:
@@ -175,23 +185,32 @@
         }
 
         Thread.sleep(200);
-        OperateResultExOne<byte[]> result2 = siemensS7Net.Read("DB100.190",(short)(barcodeSize*12));
+        OperateResultExOne<byte[]> result2 = siemensS7Net.Read("DB100.190",(short)(26));
+        OperateResultExOne<byte[]> result5 = siemensS7Net.Read("DB100.216",(short)(6));
         if (result2.IsSuccess) {
-            for (int i = 0; i < barcodeSize; i++) {
-                String barcode = siemensS7Net.getByteTransform().TransString(result2.Content,i*12,12, "UTF-8");
+                String barcode =siemensS7Net.getByteTransform().TransString(result2.Content,0,26, "UTF-8");
 //                String barcode=new String(result2.Content,i*12,12);
-                BarcodeThread barcodeThread = (BarcodeThread) SlaveConnection.get(SlaveType.Barcode, i + 1);
+                BarcodeThread barcodeThread = (BarcodeThread) SlaveConnection.get(SlaveType.Barcode, 1);
                 if(!Cools.isEmpty(barcodeThread) && !barcodeThread.getBarcode().equals(barcode)) {
                     barcodeThread.setBarcode(barcode);
                 }
+        }
+        if (result5.IsSuccess) {
+            String barcode =siemensS7Net.getByteTransform().TransString(result5.Content,0,6, "UTF-8");
+//                String barcode=new String(result2.Content,i*12,12);
+            BarcodeThread barcodeThread = (BarcodeThread) SlaveConnection.get(SlaveType.Barcode,  2);
+            if(!Cools.isEmpty(barcodeThread) && !barcodeThread.getBarcode().equals(barcode)) {
+                barcodeThread.setBarcode(barcode);
             }
         }
 
         Thread.sleep(200);
         OperateResultExOne<byte[]> result3 = siemensS7Net.Read("DB102.0", (short) 96);
+        OperateResultExOne<byte[]> result4 = siemensS7Net.Read("DB102.0", (short) 96);
         if(result3.IsSuccess) {
             for(int i=0; i<48; i++){
-                startSignal[i] = siemensS7Net.getByteTransform().TransInt16(result3.Content, i*2);
+                startSignal[i][0] = siemensS7Net.getByteTransform().TransInt16(result3.Content, i*2);
+                startSignal[i][1] = siemensS7Net.getByteTransform().TransInt16(result4.Content, i*2);
             }
         }
 //        OperateResultExOne<Short> result2 = siemensS7Net.ReadInt16("DB200.0");
@@ -228,6 +247,24 @@
     }
 
     /**
+     * 鍐欏叆 pack鐮� =====> 鍗曠珯鐐瑰啓鍏�
+     */
+    private void write103(String packNo){
+        try{
+            OperateResult write = siemensS7Net.Write("DB100.", packNo);
+            if (!write.IsSuccess) {
+                OutputQueue.DEVP.offer(MessageFormat.format("銆恵0}銆戝啓鍏ヨ緭閫佺嚎绔欑偣鏁版嵁澶辫触銆傝緭閫佺嚎plc缂栧彿={1}锛岀珯鐐规暟鎹�={2}", slave.getId(), JSON.toJSON(packNo)));
+                log.error("鍐欏叆杈撻�佺嚎绔欑偣鏁版嵁澶辫触銆傝緭閫佺嚎plc缂栧彿={}锛岀珯鐐规暟鎹�={}", slave.getId(), JSON.toJSON(packNo));
+            } else {
+                OutputQueue.DEVP.offer(MessageFormat.format("銆恵0}銆� 杈撻�佺嚎鍛戒护涓嬪彂 [id:{1}] >>>>> {2}", DateUtils.convert(new Date()), slave.getId(), JSON.toJSON(packNo)));
+                log.info("杈撻�佺嚎鍛戒护涓嬪彂 [id:{}] >>>>> 鍛戒护涓嬪彂锛� {}",  slave.getId(), JSON.toJSON(packNo));
+            }
+        }catch (Exception e){
+            log.error("103绔欑偣鍐欏叆鏁版嵁澶辫触锛岃緭閫佺嚎绾跨▼write103");
+        }
+    }
+
+    /**
      * 鍐欏叆 ID+鐩爣绔� =====> 鍗曠珯鐐瑰啓鍏�
      */
     private void write(StaProtocol staProtocol) throws InterruptedException {

--
Gitblit v1.9.1