From b6eb0edc58567aca4d303f4928389bf25fe025ba Mon Sep 17 00:00:00 2001
From: wuyouming666 <2265557248@qq.com>
Date: 星期三, 29 十一月 2023 11:04:27 +0800
Subject: [PATCH] 电气后端逻辑修改

---
 springboot-vue3/src/main/java/com/example/springboot/component/PlcServoManualone.java |  178 +++++++++++++++++++++++++++++++++++++++++------------------
 1 files changed, 124 insertions(+), 54 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 70b6ea5..4eb6072 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
@@ -18,42 +18,25 @@
     return FileUtils.readFileToString(file, "UTF-8");
   }
 
-  public void readValue() {
-    String str = "";
-    BufferedReader bufferedReader = null;
-    FileInputStream fileInputStream;
-    try {
-      // 浠庢枃浠朵腑璇诲彇瀛楄妭鏁版嵁瀛樺叆 fileInputStream
-      fileInputStream = new FileInputStream("CanadaMes-ui/src/configuration/address.json");
-      // 璇诲彇 fileInputStream 涓瓧鑺傚苟灏嗗叾瑙g爜涓哄瓧绗�
-      InputStreamReader inputStreamReader = new InputStreamReader(fileInputStream, "utf-8");
-      // 鎻愰珮璇诲彇鏁堢巼锛屽湪 BufferedReader 鍐呭寘瑁� InputStreamReader
-      bufferedReader = new BufferedReader(inputStreamReader);
-      String line = null;
-      // 灏� bufferedReader 鍐呭涓�琛屼竴琛岃祴鍊肩粰str
-      while ((line = bufferedReader.readLine()) != null) {
-        str += line;
+
+
+
+  public void insertDataToList(List<Short> list, String rangeAddress, int insertIndex) {
+    if (list.size() >= insertIndex + 14) {
+      List<Short> rangeData = new ArrayList<>();
+      byte[] byteData = S7control.getinstance().ReadByte(rangeAddress, 14);
+      if (byteData != null && byteData.length == 14) {
+        for (byte b : byteData) {
+          rangeData.add((short) b);
+        }
+      } else {
+        // 璇诲彇鏁版嵁澶辫触锛屾坊鍔犻粯璁ゅ��
+        for (int i = 0; i < 14; i++) {
+          rangeData.add((short) -1);
+        }
       }
 
-      // 灏唖tr瀛楃涓叉牸寮忚浆涓簀son
-      JSONObject jsonObject = new JSONObject(str);
-
-      // 鑾峰彇json涓殑鍊�
-      JSONArray address = jsonObject.getJSONArray("ServoManualone");
-      for (int i = 0; i < address.size(); i++) {
-        JSONObject ress = (JSONObject) address.get(i);
-
-        this.name = ress.getStr("name");
-        this.count = ress.getInt("count");
-
-      }
-
-    } catch (FileNotFoundException e) {
-      e.printStackTrace();
-    } catch (UnsupportedEncodingException e) {
-      e.printStackTrace();
-    } catch (IOException e) {
-      e.printStackTrace();
+      list.addAll(insertIndex, rangeData);
     }
   }
 
@@ -61,20 +44,17 @@
   public void run() {
     while (this != null) {
       try {
-        Thread.sleep(500);
+        Thread.sleep(1000);
 
       } catch (InterruptedException e) {
         e.printStackTrace();
       }
-//      this.readValue();
-//      String PlcAddress = this.name;
-//      Integer Plccount = this.count;
 
 
       List<String> addresses = new ArrayList<>();
       addresses.add("DB103.25");
       addresses.add("DB100.144");
-      addresses.add("DB100.148-161");
+
       addresses.add("DB100.184");
       addresses.add("DB100.186");
       addresses.add("DB100.180");
@@ -82,14 +62,24 @@
 
       List<Short> arraylist = S7control.getinstance().readWords(addresses);
 
+//      String rangeAddress = "DB100.148-161";
+      String rangeAddress = "DB100.148";
+      int insertIndex = 2;
+      insertDataToList(arraylist, rangeAddress, insertIndex);
+
+
       List<String> addresses2 = new ArrayList<>();
       addresses2.add("DB103.26");
       addresses2.add("DB100.188");
       addresses2.add("DB100.190");
       addresses2.add("DB100.146");
-      addresses2.add("DB100.162-175");
+//      addresses2.add("DB100.162-175");
       List<Short> arraylist2 = S7control.getinstance().readWords(addresses2);
-
+//      String rangeAddress2 = "DB100.148-161";
+      String rangeAddress2 = "DB100.162";
+      int insertIndex2 = 4;
+      insertDataToList(arraylist2, rangeAddress2, insertIndex2);
+//      System.out.println(arraylist2);
       List<String> addresses3 = new ArrayList<>();
       addresses3.add("DB103.42");
       List<Short> arraylist3 = S7control.getinstance().readWords(addresses3);
@@ -108,18 +98,26 @@
       addresses7.add("DB104.28");
       addresses7.add("DB104.30");
       List<Short> arraylist7 = S7control.getinstance().readWords(addresses7);
-//      List<String> addresses8 = new ArrayList<>();
-//      addresses8.add("DB103.26");
-//      addresses8.add("DB103.26");
-//      addresses8.add("DB103.26");
-//      addresses8.add("DB103.26");
-//      List<Short> arraylist8 = S7control.getinstance().readWords(addresses8);
+
+
+      List<String> addresses8 = new ArrayList<>();
+      addresses8.add("DB101.3.7");
+      addresses8.add("DB101.4.2");
+      addresses8.add("DB101.4.5");
+      addresses8.add("DB101.4.7");
+      List<Boolean> arraylist8 = S7control.getinstance().readBits(addresses8);
+      short[] params = new short[arraylist8.size()];
+      for (int i = 0; i < arraylist8.size(); i++) {
+        boolean value = arraylist8.get(i);
+        params[i] = value ? (short) 1 : (short) 0;
+      }
+
 
 //      Short[] values1 = { 1, 2, 3, 4, 5, 6, 7};
 //      List<Short> arraylist = new ArrayList<>(Arrays.asList(values1));
 //      Short[] values2 = { 1, 2, 3, 4, 5};
 //      List<Short> arraylist2 = new ArrayList<>(Arrays.asList(values2));
-
+//
 //      Short[] values3 = {1};
 //      List<Short> arraylist3 = new ArrayList<>(Arrays.asList(values3));
 //      Short[] values4 = {2};
@@ -143,7 +141,7 @@
       jsonObject.append("zuhe5", arraylist5);
       jsonObject.append("zuhe6", arraylist6);
       jsonObject.append("guzhang", arraylist7);
-//      jsonObject.append("weihuiling", arraylist8);
+   jsonObject.append("weihuiling", params);
 
 
 
@@ -170,6 +168,29 @@
         waddresses2.add("DB100.190");
         waddresses2.add("DB100.146");
         waddresses2.add("DB100.162-175");
+
+        List<String> waddresses3 = new ArrayList<>();
+        waddresses3.add("DB101.4.0");
+        waddresses3.add("DB101.4.3");
+        waddresses3.add("DB101.3.6");
+        waddresses3.add("DB101.4.1");
+        waddresses3.add("DB101.4.4");
+        waddresses3.add("DB101.4.6");
+
+
+        List<String> waddresses4 = new ArrayList<>();
+        waddresses4.add("DB101.3.7");
+        waddresses4.add("DB101.4.2");
+        waddresses4.add("DB101.4.5");
+        waddresses4.add("DB101.4.7");
+
+
+
+
+
+
+
+
 
 
 
@@ -201,16 +222,16 @@
               }
             }
             if (!sValue.isEmpty()) {
-              S7control.getinstance().WriteWord(waddresses1, sValue);
+          S7control.getinstance().WriteWord(waddresses1, sValue);
               System.out.println("Values " + sValue + " written to PLC at address " + waddresses1);
             }
           }
 
           if (messageArray.getJSONArray(1).size() > 0) {
-            JSONArray jsonArray = messageArray.getJSONArray(1);
+            JSONArray jsonArray2 = messageArray.getJSONArray(1);
             List<Short> sValue2 = new ArrayList<>();
-            for (int i = 0; i < jsonArray.size(); i++) {
-              Object value = jsonArray.get(i);
+            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-]", "");
@@ -224,11 +245,60 @@
               }
             }
             if (!sValue2.isEmpty()) {
-              S7control.getinstance().WriteWord(waddresses2, sValue2);
+            S7control.getinstance().WriteWord(waddresses2, sValue2);
               System.out.println("Values " + sValue2 + " written to PLC at address " + waddresses2);
             }
           }
 
+
+
+          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(waddresses3, sValue3);
+              System.out.println("Values " + sValue3 + " written to PLC at address " + waddresses3);
+            }
+          }
+
+
+          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);
+            }
+          }
+
           // 娓呯┖娑堟伅鍒楄〃
           webSocketServer.clearMessages();
         }

--
Gitblit v1.8.0