From 1eeafb1d1b85887bec13d693d4658fbe0770a512 Mon Sep 17 00:00:00 2001
From: wuyouming666 <2265557248@qq.com>
Date: 星期一, 27 十一月 2023 13:39:52 +0800
Subject: [PATCH] 更新PLC地址

---
 springboot-vue3/src/main/java/com/example/springboot/component/S7control.java |  151 ++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 144 insertions(+), 7 deletions(-)

diff --git a/springboot-vue3/src/main/java/com/example/springboot/component/S7control.java b/springboot-vue3/src/main/java/com/example/springboot/component/S7control.java
index 9b9a66e..e207db3 100644
--- a/springboot-vue3/src/main/java/com/example/springboot/component/S7control.java
+++ b/springboot-vue3/src/main/java/com/example/springboot/component/S7control.java
@@ -79,16 +79,38 @@
      * @param datas   word鐨勫��
      */
     public void WriteWord(List<String> address, List<Short> datas) {
-        if (s7PLC==null)
+        if (s7PLC == null)
             return;
-        // s7PLC.write(address, data);
 
-        MultiAddressWrite addressWrite = new MultiAddressWrite();
         for (int i = 0; i < address.size(); i++) {
-            addressWrite.addInt16(address.get(i), datas.get(i));
+            String addr = address.get(i);
+            short data = datas.get(i);
+
+            if (addr.contains("-")) {
+                // 澶勭悊鑼冨洿鍦板潃
+                String[] range = addr.split("-");
+                if (range.length == 2) {
+                    String startAddr = range[0].trim();
+                    String endAddr = range[1].trim();
+
+                    int startIndex = Integer.parseInt(startAddr.substring(startAddr.indexOf('.') + 1));
+                    int endIndex = Integer.parseInt(endAddr.substring(endAddr.indexOf('.') + 1));
+
+                    for (int j = startIndex; j <= endIndex; j++) {
+                        String currentAddress = startAddr.substring(0, startAddr.indexOf('.') + 1) + j;
+                        s7PLC.writeInt16(currentAddress, data); // 灏嗘暟鎹啓鍏ュ綋鍓嶅湴鍧�
+                    }
+                }
+            } else {
+                // 澶勭悊鍗曚釜鍦板潃
+                s7PLC.writeInt16(addr, data); // 灏嗘暟鎹啓鍏ュ崟涓湴鍧�
+            }
         }
-        s7PLC.writeMultiData(addressWrite);
     }
+
+
+
+
 
     /**
      * 鎸夋寚瀹氱殑鍦板潃 鍐欏叆涓�涓狟it
@@ -137,6 +159,18 @@
         }
         s7PLC.writeMultiData(addressWrite);
     }
+     /**
+     * 鎸夋寚瀹氱殑鍦板潃 鍐欏叆澶氫釜byte
+     * 
+     * @param address 鍦板潃
+     * @param datas   byte鐨勫��
+     */
+    public void WriteByte(String address, byte[] datas) {
+        if (s7PLC==null)
+            return;
+        // s7PLC.write(address, data); 
+        s7PLC.writeByte(address, datas);
+    }
 
     /**
      * 鎸夋寚瀹氱殑鍦板潃 璇诲彇word缁撴灉闆�
@@ -148,6 +182,56 @@
         if (s7PLC==null)
               return null;
         return s7PLC.readInt16(address);
+    }
+
+    public List<Short> readWords(List<String> addresses) {
+        if (s7PLC == null) {
+            return null;
+        }
+
+        List<Short> data = new ArrayList<>();
+
+        for (String address : addresses) {
+            if (address.contains("-")) {
+                String[] range = address.split("-");
+                String startAddress = range[0];
+                String endAddress = range[1];
+
+                if (startAddress.equals(endAddress)) {
+                    // 鍗曚釜鍦板潃
+                    Short value = s7PLC.readInt16(startAddress);
+                    data.add(value);
+                } else {
+                    // 鑼冨洿鍦板潃
+                    int startIndex = getIndexFromAddress(startAddress);
+                    int endIndex = getIndexFromAddress(endAddress);
+
+                    for (int i = startIndex; i <= endIndex; i++) {
+                        String currentAddress = getAddressFromIndex(i);
+                        Short value = s7PLC.readInt16(currentAddress);
+                        data.add(value);
+                    }
+                }
+            } else {
+                // 鍗曚釜鍦板潃
+                Short value = s7PLC.readInt16(address);
+                data.add(value);
+            }
+        }
+
+        return data;
+    }
+
+    private int getIndexFromAddress(String address) {
+
+        // 鍙互瑙f瀽鍑哄湴鍧�涓殑鏁板瓧閮ㄥ垎锛屽苟杞崲涓烘暣鏁�
+        return 0;
+    }
+
+    private String getAddressFromIndex(int index) {
+
+        // 鏁存暟杞崲涓哄湴鍧�鏍煎紡鐨勫瓧绗︿覆
+        return "";
     }
 
     /**
@@ -164,6 +248,20 @@
         List<String> addresslist = GetAddressList(address, count, 16);
         return s7PLC.readInt16(addresslist);
     }
+    /**
+     * 鎸夋寚瀹氱殑鍦板潃 璇诲彇byte缁撴灉闆�
+     * 
+     * @param address 鍦板潃
+     * @param count   杩炵画璇诲灏戜釜byte
+     * @return 缁撴灉
+     */
+    public byte[] ReadByte(String address, int count) {
+        if (s7PLC==null)
+             return null;
+
+       // List<String> addresslist = GetAddressList(address, count, 16);
+        return s7PLC.readByte(address,count);
+    }
 
     /**
      * 鎸夋寚瀹氱殑鍦板潃 鎸塨it浣� 0 flase 1 true 璇诲彇缁撴灉
@@ -176,6 +274,42 @@
              return null;
         return s7PLC.readBoolean(addresslist);
     }
+
+    public List<Boolean> readBits(List<String> addressList) {
+        if (s7PLC == null)
+            return null;
+
+        List<Boolean> result = new ArrayList<>();
+
+        for (String address : addressList) {
+            if (address.contains("~")) {
+                String[] range = address.split("~");
+                String startAddress = range[0];
+                String endAddress = range[1];
+
+                int startIndex = extractAddressNumber(startAddress);
+                int endIndex = extractAddressNumber(endAddress);
+
+                String prefix = startAddress.substring(0, startAddress.indexOf(".") + 1);
+
+                for (int i = startIndex; i <= endIndex; i++) {
+                    String newAddress = prefix + i;
+                    result.add(s7PLC.readBoolean(newAddress));
+                }
+            } else {
+                result.add(s7PLC.readBoolean(address));
+            }
+        }
+
+        return result;
+    }
+
+
+    private int extractAddressNumber(String address) {
+        String numberStr = address.replaceAll("\\D+", ""); // 浣跨敤姝e垯琛ㄨ揪寮忔彁鍙栨暟瀛楅儴鍒�
+        return Integer.parseInt(numberStr);
+    }
+
 
     /**
      * 浠庢寚瀹氱殑鍦板潃寮�濮� 杩炵画鎸塨it浣嶈鍙�
@@ -206,7 +340,8 @@
         } else
             return null;
 
-        for (int i = 0; i < count; i++) {
+            addresslist.add(address);
+        for (int i = 0; i < count-1; i++) {
 
             int bitcurrent = bitindex + addedbit;
             if (bitcurrent > 7) {
@@ -214,7 +349,9 @@
                 bitindex = 0;
             } else
                 bitindex = bitcurrent;
-            addresslist.add(stringdatas[0] + "." + dbwindex + "." + bitindex);
+
+                String endstr=stringdatas.length==3?"." + bitindex:"";
+            addresslist.add(stringdatas[0] + "." + dbwindex + endstr);
         }
         return addresslist;
     }

--
Gitblit v1.8.0