From 69d6f1711a32ba4d1a989fef6b3640ff5ae4f2e2 Mon Sep 17 00:00:00 2001
From: wuyouming666 <2265557248@qq.com>
Date: 星期二, 12 十二月 2023 13:15:40 +0800
Subject: [PATCH] Merge branch 'master' of http://10.153.19.25:10101/r/CanadaMes

---
 springboot-vue3/src/main/java/com/example/springboot/component/PlcServoManualone.java |  338 ++++++++++++++++++++++----------------------------------
 1 files changed, 132 insertions(+), 206 deletions(-)

diff --git a/springboot-vue3/src/main/java/com/example/springboot/component/PlcServoManualone.java b/springboot-vue3/src/main/java/com/example/springboot/component/PlcServoManualone.java
index 01b178d..88bd43d 100644
--- a/springboot-vue3/src/main/java/com/example/springboot/component/PlcServoManualone.java
+++ b/springboot-vue3/src/main/java/com/example/springboot/component/PlcServoManualone.java
@@ -13,13 +13,44 @@
 public class PlcServoManualone extends Thread {
 
 
-
+  // 鐢ㄤ簬瀛樺偍搴旂敤绋嬪簭鐨勯厤缃俊鎭�
   private Configuration config;
+
+  // 鍒涘缓涓�涓嚜瀹氫箟鐨� S7 鎺у埗鍣ㄦ秷鎭鐞嗗櫒瀵硅薄
+  MessageHandler customS7Control = new MessageHandler();
+
 
   public PlcServoManualone() throws IOException {
     config = new Configuration("config.properties");
   }
 
+//灏嗗竷灏斿垪琛ㄨ浆鎹负浜岃繘鍒剁殑 short 鏁扮粍
+  public static class PLCBooleanConverter {
+
+    public static short[] convertListsToBinaryShortArray(List<Boolean>... lists) {
+      // 璁$畻鎵�鏈夊垪琛ㄤ腑鍏冪礌鐨勬�绘暟
+      int totalSize = 0;
+      for (List<Boolean> list : lists) {
+        totalSize += list.size();
+      }
+
+      // 鍒涘缓涓�涓冻澶熷ぇ鐨勬暟缁勬潵瀛樻斁鎵�鏈夌殑浜岃繘鍒跺��
+      short[] binaryShortArray = new short[totalSize];
+
+      // 褰撳墠鏁扮粍濉厖浣嶇疆鎸囬拡
+      int currentIndex = 0;
+
+      // 閬嶅巻鎵�鏈夌殑鍒楄〃
+      for (List<Boolean> list : lists) {
+        // 灏嗘瘡涓竷灏斿�艰浆鎹负 0 鎴� 1 骞跺~鍏ユ暟缁�
+        for (Boolean value : list) {
+          binaryShortArray[currentIndex++] = (short) (value ? 1 : 0);
+        }
+      }
+
+      return binaryShortArray;
+    }
+  }
 
 //璇诲彇id
   public StringBuilder queGlassid(String address,int count) {
@@ -33,18 +64,7 @@
     }
     return writedstrIdOut;
   }
-//鍐欏叆id
-  public void outmesid(String glassid,String address) {
-    //System.out.println("outmesid:" + glassid);
-    List<Byte> glassidlist = new ArrayList();
-    char ds[]=glassid.toCharArray();
-    for (char iditem : ds) {
-      glassidlist.add((byte)iditem);
-    }
-    byte[] bytes = Bytes.toArray(glassidlist);
-    System.out.println("outmesidbytes:" + bytes.length);
-    S7control.getinstance().WriteByte(address, bytes);
-  }
+
 
   @Override
   public void run() {
@@ -55,6 +75,8 @@
       } catch (InterruptedException e) {
         e.printStackTrace();
       }
+
+
 
 //A01缁勫悎涓湴鍧�琛ㄩ泦鍚�
       List<String> addresses = Arrays.asList(config.getProperty("A01.addresses").split(","));
@@ -80,16 +102,11 @@
       //B02缁勫悎鍦板潃
       String b02Address = config.getProperty("B02.address");
       List<Short> arraylist6 = S7control.getinstance().ReadWord(b02Address, 2);
-      System.out.println(b02Address);
+//      System.out.println(b02Address);
      // 鎵�鏈夋晠闅滄寜閽湴鍧�
       List<String> addresses7 = Arrays.asList(config.getProperty("faultButtonAddresses").split(","));
       List<Boolean> arraylist7 = S7control.getinstance().readBits(addresses7);
-      // 杩涚墖id鍦板潃
-      String inputGlassIdAddress = config.getProperty("inputGlassIdAddress");
-      String outputGlassIdAddress = config.getProperty("outputGlassIdAddress");
-      StringBuilder queueid1 = queGlassid(inputGlassIdAddress, 14);
-      // 瀛樼墖id鍦板潃
-      StringBuilder queueid2 = queGlassid(outputGlassIdAddress, 14);
+
       //A01鍚姩鍦板潃
       List<String> A01start = Arrays.asList(config.getProperty("A01start"));
       //A02鍚姩鍦板潃
@@ -98,12 +115,33 @@
       List<String> A01Bstart = Arrays.asList(config.getProperty("A01Bstart"));
       //A02鍗婅嚜鍔ㄥ湴鍧�
       List<String> A02Bstart = Arrays.asList(config.getProperty("A02Bstart"));
+      //
+      List<String> abortresumeTasks = Arrays.asList(config.getProperty("abortresumeTasks"));
       //鍥為浂鎸夐挳鍦板潃
       List<String> waddresses4 = Arrays.asList(config.getProperty("HomedButtonAddresses").split(","));
       // 鎵�鏈夊浣嶆寜閽湴鍧�
-      List<String> Reset = Arrays.asList(config.getProperty("resetButtonAddresses"));
+      List<String> Reset = Arrays.asList(config.getProperty("resetButtonAddresses").split(","));
+//      System.out.println(Reset);
       // 鎵�鏈夋湭鍥為浂鎸夐挳鍦板潃
-      List<String> addresses8 = Arrays.asList(config.getProperty("notHomedButtonAddresses"));
+      List<String> addresses8 = Arrays.asList(config.getProperty("notHomedButtonAddresses").split(","));
+      // 杩涚墖id鍦板潃
+      String inputGlassIdAddress = config.getProperty("inputGlassIdAddress");
+      String outputGlassIdAddress = config.getProperty("outputGlassIdAddress");
+      StringBuilder queueid1 = queGlassid(inputGlassIdAddress, 14);
+      // 瀛樼墖id鍦板潃
+      StringBuilder queueid2 = queGlassid(outputGlassIdAddress, 14);
+//A01 A02鍚姩   鍗婅嚜鍔ㄥ惎鍔�
+      List<Boolean> A01readstart = S7control.getinstance().readBits(A01start);
+      List<Boolean> A02readstart = S7control.getinstance().readBits(A02start);
+      List<Boolean> A01readBstart = S7control.getinstance().readBits(A01Bstart);
+      List<Boolean> A02readsBtart = S7control.getinstance().readBits(A02Bstart);
+
+      List<Boolean> resumeTasks = S7control.getinstance().readBits(abortresumeTasks);
+
+      short[] combinedBinaryShortArray = PLCBooleanConverter.convertListsToBinaryShortArray(
+              A01readstart, A01readBstart, A02readstart, A02readsBtart
+      );
+
 
 // 鎵�鏈夋晠闅滄寜閽浆鎹负1鍜�0
       short[] params2 = new short[arraylist7.size()];
@@ -112,9 +150,15 @@
         params2[i] = value ? (short) 1 : (short) 0;
       }
 
+//鎬ュ仠涓鎸夐挳
+      short[] resumeTask = new short[resumeTasks.size()];
+      for (int i = 0; i < resumeTasks.size(); i++) {
+        boolean value = resumeTasks.get(i);
+        resumeTask[i] = value ? (short) 1 : (short) 0;
+      }
 
       List<Boolean> Reset1 = S7control.getinstance().readBits(Reset);
-
+    //  System.out.println(Reset1);
 // 鎵�鏈夋晠闅滄寜閽浆鎹负1鍜�0
       short[] rReset = new short[Reset1.size()];
       for (int i = 0; i < Reset1.size(); i++) {
@@ -123,7 +167,7 @@
       }
 
 
-
+//鎵�鏈夋湭鍥為浂鎸夐挳杞崲涓�1鍜�0
       List<Boolean> arraylist8 = S7control.getinstance().readBits(addresses8);
       short[] params = new short[arraylist8.size()];
       for (int i = 0; i < arraylist8.size(); i++) {
@@ -182,207 +226,89 @@
       jsonObject.append("jinpianid", queueid1);
       jsonObject.append("qupianid", queueid2);
       jsonObject.append("fuwei", rReset);
+      jsonObject.append("qidong", combinedBinaryShortArray);
+      jsonObject.append("resumeTasks", resumeTask);
 
 
 
-      WebSocketServer sendwServer = WebSocketServer.sessionMap.get("ServoManualone");
+//      WebSocketServer sendwServer = WebSocketServer.sessionMap.get("ServoManualone");
+//      if (sendwServer != null) {
+//        sendwServer.sendMessage(jsonObject.toString());
+//      }
+
+      ArrayList<WebSocketServer> sendwServer = WebSocketServer.sessionMap.get("ServoManualone");
       if (sendwServer != null) {
-        sendwServer.sendMessage(jsonObject.toString());
-      }
-
-      WebSocketServer webSocketServer = WebSocketServer.sessionMap.get("ServoManualone");
-      if (webSocketServer != null) {
-        List<String> messages = webSocketServer.getMessages();
+        for (WebSocketServer webserver : sendwServer) {
+          webserver.sendMessage(jsonObject.toString());
 
 
+          if (webserver != null) {
+            List<String> messages = webserver.getMessages();
 
-        if (!messages.isEmpty()) {
-          // 灏嗘渶鍚庝竴涓秷鎭浆鎹负 short 绫诲瀷鐨勫垪琛�
-          String lastMessage = messages.get(messages.size() - 1);
+
+            if (!messages.isEmpty()) {
+              // 灏嗘渶鍚庝竴涓秷鎭浆鎹负 short 绫诲瀷鐨勫垪琛�
+              String lastMessage = messages.get(messages.size() - 1);
 //        System.out.println("lastMessage锛�" + lastMessage);
-          JSONArray messageArray = new JSONArray(lastMessage);
+              JSONArray messageArray = new JSONArray(lastMessage);
 
 
-          // 鍐欏叆AO1缁勫悎
-          if (messageArray.getJSONArray(0).size() > 0 ) {
-            JSONArray jsonArray = messageArray.getJSONArray(0);
-            List<Short> sValue = new ArrayList<>();
-            for (int i = 0; i < jsonArray.size(); i++) {
-              Object value = jsonArray.get(i);
-              if (value != null && !value.toString().equals("null")) {
-                try {
-                  String cleanedValue = value.toString().replaceAll("[^0-9-]", "");
-                  short val = Short.parseShort(cleanedValue.trim());
-                  sValue.add(val);
-                  System.out.println("messageValue锛�" + Arrays.asList(val) + " added to the list");
-                } catch (NumberFormatException e) {
-                  // 濡傛灉鏃犳硶瑙f瀽涓� short 绫诲瀷锛屽垯蹇界暐璇ラ儴鍒�
-                  System.err.println("Could not parse value: " + value);
+              // 鍐欏叆AO1缁勫悎
+              customS7Control.WriteWordToPLC(messageArray, addresses,0);
+              if (messageArray.getJSONArray(0).size() > 0) {
+                if (A01readstart != null && !A01readstart.isEmpty()) {
+                  // 鍒涘缓涓�涓柊鐨勫垪琛ㄧ敤浜庡啓鍏ユ柊鍊�
+                  List<Boolean> a01startval = new ArrayList<>();
+                  // 閬嶅巻鎵�鏈夎鍙栧埌鐨勪綅鍊�
+                  for (Boolean bit : A01readstart) {
+                    // 鍙栧弽褰撳墠浣嶇殑鍊煎苟娣诲姞鍒版柊鐨勫垪琛ㄤ腑
+                    a01startval.add(!bit);
+                  }
+                  // 鍐欏叆鏂扮殑浣嶅�煎垪琛�
+                  S7control.getinstance().WriteBit(A01start, a01startval);
                 }
               }
-            }
-            if (!sValue.isEmpty()) {
-
-          S7control.getinstance().WriteWord(addresses, sValue);
-              Boolean[] a01values7 = { true};
-              List<Boolean> a01startval = new ArrayList<>(Arrays.asList(a01values7));
-              S7control.getinstance().WriteBit(A01start, a01startval);
-              System.out.println("Values " + sValue + " written to PLC at address " + addresses);
-            }
-          }
 
 
-          //// 鍐欏叆AO2缁勫悎
-          if (messageArray.getJSONArray(1).size() > 0) {
-            JSONArray jsonArray2 = messageArray.getJSONArray(1);
-            List<Short> sValue2 = new ArrayList<>();
-            for (int i = 0; i < jsonArray2.size(); i++) {
-              Object value = jsonArray2.get(i);
-              if (value != null && !value.toString().equals("null")) {
-                try {
-                  String cleanedValue = value.toString().replaceAll("[^0-9-]", "");
-                  short val = Short.parseShort(cleanedValue.trim());
-                  sValue2.add(val);
-                  System.out.println("messageValue锛�" + Arrays.asList(val) + " added to the list");
-                } catch (NumberFormatException e) {
-                  // 濡傛灉鏃犳硶瑙f瀽涓� short 绫诲瀷锛屽垯蹇界暐璇ラ儴鍒�
-                  System.err.println("Could not parse value: " + value);
+              // 鍐欏叆AO2缁勫悎
+              customS7Control.WriteWordToPLC(messageArray, addresses2,1);
+              if (messageArray.getJSONArray(1).size() > 0) {
+                if (A02readstart != null && !A02readstart.isEmpty()) {
+                  // 鍒涘缓涓�涓柊鐨勫垪琛ㄧ敤浜庡啓鍏ユ柊鍊�
+                  List<Boolean> a02startval = new ArrayList<>();
+                  // 閬嶅巻鎵�鏈夎鍙栧埌鐨勪綅鍊�
+                  for (Boolean bit : A02readstart) {
+                    // 鍙栧弽褰撳墠浣嶇殑鍊煎苟娣诲姞鍒版柊鐨勫垪琛ㄤ腑
+                    a02startval.add(!bit);
+                  }
+                  // 鍐欏叆鏂扮殑浣嶅�煎垪琛�
+                  S7control.getinstance().WriteBit(A02start, a02startval);
                 }
               }
-            }
-            if (!sValue2.isEmpty()) {
-            S7control.getinstance().WriteWord(addresses2, sValue2);
 
-              Boolean[] a02values7 = {true};
-              List<Boolean> a02startval = new ArrayList<>(Arrays.asList(a02values7));
-              S7control.getinstance().WriteBit(A02start, a02startval);
-              System.out.println("Values " + sValue2 + " written to PLC at address " + addresses2);
+              // 澶嶄綅鎸夐挳鍐欏叆
+              customS7Control.writeBitToPLC( messageArray, Reset,2);
+
+              //鍥為浂鎸夐挳鍐欏叆
+              customS7Control.writeBitToPLC( messageArray, waddresses4,3);
+
+              // 杩涚墖ID鍐欏叆
+              customS7Control.writeStringToPLC(  messageArray,inputGlassIdAddress,4);
+              //鍙栫墖ID鍐欏叆
+              customS7Control.writeStringToPLC(  messageArray,outputGlassIdAddress,5);
+
+              //A01鍗婅嚜鍔�
+              customS7Control.writeBitToPLC( messageArray, A01Bstart,6);
+
+            //A02鍗婅嚜鍔�
+              customS7Control.writeBitToPLC( messageArray, A02Bstart,7);
+
+
+
+              // 娓呯┖娑堟伅鍒楄〃
+              webserver.clearMessages();
             }
           }
-
-
-         // 澶嶄綅鎸夐挳鍐欏叆
-          if (messageArray.getJSONArray(2).size() > 0) {
-            JSONArray jsonArray3 = messageArray.getJSONArray(2);
-            List<Boolean> sValue3 = new ArrayList<>();
-            for (int i = 0; i < jsonArray3.size(); i++) {
-              Object value = jsonArray3.get(i);
-              if (value != null && !value.toString().equals("null")) {
-                try {
-                  String cleanedValue = value.toString().replaceAll("[^0-9-]", "");
-                  boolean val = "1".equals(cleanedValue.trim());
-                  sValue3.add(val);
-                  System.out.println("messageValue: " + Arrays.asList(val) + " added to the list");
-                } catch (NumberFormatException e) {
-                  // 濡傛灉鏃犳硶瑙f瀽涓� boolean 绫诲瀷锛屽垯蹇界暐璇ラ儴鍒�
-                  System.err.println("Could not parse value: " + value);
-                }
-              }
-            }
-            if (!sValue3.isEmpty()) {
-              S7control.getinstance().WriteBit(Reset, sValue3);
-              System.out.println("Values " + sValue3 + " written to PLC at address " + Reset);
-            }
-          }
-
-        //鍥為浂鎸夐挳鍐欏叆
-          if (messageArray.getJSONArray(3).size() > 0) {
-            JSONArray jsonArray4 = messageArray.getJSONArray(3);
-            List<Boolean> sValue4 = new ArrayList<>();
-            for (int i = 0; i < jsonArray4.size(); i++) {
-              Object value = jsonArray4.get(i);
-              if (value != null && !value.toString().equals("null")) {
-                try {
-                  String cleanedValue = value.toString().replaceAll("[^0-9-]", "");
-                  boolean val = "1".equals(cleanedValue.trim());
-                  sValue4.add(val);
-                  System.out.println("messageValue: " + Arrays.asList(val) + " added to the list");
-                } catch (NumberFormatException e) {
-                  // 濡傛灉鏃犳硶瑙f瀽涓� boolean 绫诲瀷锛屽垯蹇界暐璇ラ儴鍒�
-                  System.err.println("Could not parse value: " + value);
-                }
-              }
-            }
-            if (!sValue4.isEmpty()) {
-             S7control.getinstance().WriteBit(waddresses4, sValue4);
-              System.out.println("Values " + sValue4 + " written to PLC at address " + waddresses4);
-            }
-          }
-
-
-          //杩涚墖ID鍐欏叆
-          if (messageArray.getJSONArray(4).size() > 0) {
-//            JSONArray jsonArray5 = messageArray.getJSONArray(4);
-            String jsonArray5 = String.valueOf(messageArray.getJSONArray(4));
-            if (!jsonArray5.isEmpty()) {
-//              String value = (String) jsonArray5.get(0);
-              jsonArray5 = jsonArray5.replaceAll("[\\[\\]\"]", ""); // 鍘婚櫎鏂规嫭鍙峰拰鍙屽紩鍙�
-            outmesid( jsonArray5,inputGlassIdAddress);
-              System.out.println("Values " + jsonArray5 + " written to PLC at address " + inputGlassIdAddress);
-            }
-          }
-         // 瀛樼墖ID鍐欏叆
-          if (messageArray.getJSONArray(5).size() > 0) {
-            JSONArray jsonArray6 = messageArray.getJSONArray(5);
-
-            if (!jsonArray6.isEmpty()) {
-              String value2 = (String) jsonArray6.get(0);
-             outmesid( value2,outputGlassIdAddress);
-              System.out.println("Values " + value2 + " written to PLC at address " + outputGlassIdAddress);
-            }
-          }
-          if (messageArray.getJSONArray(6).size() > 0) {
-            JSONArray jsonArray4 = messageArray.getJSONArray(6);
-            List<Boolean> sValueb4 = new ArrayList<>();
-            for (int i = 0; i < jsonArray4.size(); i++) {
-              Object value = jsonArray4.get(i);
-              if (value != null && !value.toString().equals("null")) {
-                try {
-                  String cleanedValue = value.toString().replaceAll("[^0-9-]", "");
-                  boolean val = "1".equals(cleanedValue.trim());
-                  sValueb4.add(val);
-                  System.out.println("messageValue: " + Arrays.asList(val) + " added to the list");
-                } catch (NumberFormatException e) {
-                  // 濡傛灉鏃犳硶瑙f瀽涓� boolean 绫诲瀷锛屽垯蹇界暐璇ラ儴鍒�
-                  System.err.println("Could not parse value: " + value);
-                }
-              }
-            }
-            if (!sValueb4.isEmpty()) {
-
-              S7control.getinstance().WriteBit(A01Bstart, sValueb4);
-              System.out.println("Values " + sValueb4 + " written to PLC at address " + A01Bstart);
-            }
-          }
-
-
-          if (messageArray.getJSONArray(7).size() > 0) {
-            JSONArray jsonArray4 = messageArray.getJSONArray(7);
-            List<Boolean> sValueb5 = new ArrayList<>();
-            for (int i = 0; i < jsonArray4.size(); i++) {
-              Object value = jsonArray4.get(i);
-              if (value != null && !value.toString().equals("null")) {
-                try {
-                  String cleanedValue = value.toString().replaceAll("[^0-9-]", "");
-                  boolean val = "1".equals(cleanedValue.trim());
-                  sValueb5.add(val);
-                  System.out.println("messageValue: " + Arrays.asList(val) + " added to the list");
-                } catch (NumberFormatException e) {
-                  // 濡傛灉鏃犳硶瑙f瀽涓� boolean 绫诲瀷锛屽垯蹇界暐璇ラ儴鍒�
-                  System.err.println("Could not parse value: " + value);
-                }
-              }
-            }
-            if (!sValueb5.isEmpty()) {
-
-              S7control.getinstance().WriteBit(A02Bstart, sValueb5);
-              System.out.println("Values " + sValueb5 + " written to PLC at address " + A02Bstart);
-            }
-          }
-
-
-          // 娓呯┖娑堟伅鍒楄〃
-          webSocketServer.clearMessages();
         }
       }
     }

--
Gitblit v1.8.0