From e47aa1b3ca12923e194d6e88187d2ecdb29eb186 Mon Sep 17 00:00:00 2001 From: wuyouming666 <2265557248@qq.com> Date: 星期二, 05 十二月 2023 16:09:04 +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 | 276 +++++++++++++++++++++++++++--------------------------- 1 files changed, 139 insertions(+), 137 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 465dfe3..01b178d 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 @@ -11,40 +11,17 @@ import java.util.List; public class PlcServoManualone extends Thread { - String name = ""; - Integer count = 0; - public static String readFileToString(String filePath) throws IOException { - File file = new File(filePath); - return FileUtils.readFileToString(file, "UTF-8"); + + + private Configuration config; + + public PlcServoManualone() throws IOException { + config = new Configuration("config.properties"); } - - -// 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 >= 13) { -// for (byte b : byteData) { -// rangeData.add((short) b); -// } -// } else { -// // 璇诲彇鏁版嵁澶辫触锛屾坊鍔犻粯璁ゅ�� -// for (int i = 0; i < 14; i++) { -// rangeData.add((short) -1); -// } -// } -// -// list.addAll(insertIndex, rangeData); -// }else{ -// List<Short> rangeData = new ArrayList<>(); -// rangeData.add((short) 0); -// list.addAll(insertIndex, rangeData); -// } -// } - +//璇诲彇id public StringBuilder queGlassid(String address,int count) { StringBuilder writedstrIdOut = new StringBuilder(); byte[] writedglassidbytesOut = S7control.getinstance().ReadByte(address, count); @@ -56,7 +33,7 @@ } return writedstrIdOut; } - +//鍐欏叆id public void outmesid(String glassid,String address) { //System.out.println("outmesid:" + glassid); List<Byte> glassidlist = new ArrayList(); @@ -66,7 +43,7 @@ } byte[] bytes = Bytes.toArray(glassidlist); System.out.println("outmesidbytes:" + bytes.length); - S7control.getinstance().WriteByte(address, bytes);// 娲惧彂鍑虹墖id + S7control.getinstance().WriteByte(address, bytes); } @Override @@ -79,68 +56,74 @@ e.printStackTrace(); } - - List<String> addresses = new ArrayList<>(); - addresses.add("DB103.32"); - addresses.add("DB100.144"); - addresses.add("DB100.184"); - addresses.add("DB100.186"); - addresses.add("DB100.180"); - addresses.add("DB100.182"); +//A01缁勫悎涓湴鍧�琛ㄩ泦鍚� + List<String> addresses = Arrays.asList(config.getProperty("A01.addresses").split(",")); + //System.out.println(addresses); 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"); +//A02缁勫悎涓湴鍧�琛ㄩ泦鍚� + List<String> addresses2 = Arrays.asList(config.getProperty("A02.addresses").split(",")); 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"); + + //A01缈昏浆鍦板潃 + List<String> addresses3 = Arrays.asList(config.getProperty("A01.flipAddress")); List<Short> arraylist3 = S7control.getinstance().readWords(addresses3); - List<String> addresses4 = new ArrayList<>(); - addresses4.add("DB103.46"); + //A02缈昏浆鍦板潃 + List<String> addresses4 = Arrays.asList(config.getProperty("A02.flipAddress")); + List<Short> arraylist4 = S7control.getinstance().readWords(addresses4); - - List<Short> arraylist5 = S7control.getinstance().ReadWord("DB103.27", 2); - List<Short> arraylist6 = S7control.getinstance().ReadWord("DB103.29", 2); - List<String> addresses7 = new ArrayList<>(); - addresses7.add("DB104.1.4"); - addresses7.add("DB104.1.5"); - addresses7.add("DB104.1.2"); - addresses7.add("DB104.1.3"); - addresses7.add("DB104.1.6"); - addresses7.add("DB104.1.7"); + //B01缁勫悎涓湴鍧� + String b01Address = config.getProperty("B01.address"); + List<Short> arraylist5 = S7control.getinstance().ReadWord(b01Address, 2); + //B02缁勫悎鍦板潃 + String b02Address = config.getProperty("B02.address"); + List<Short> arraylist6 = S7control.getinstance().ReadWord(b02Address, 2); + 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鍚姩鍦板潃 + List<String> A02start = Arrays.asList(config.getProperty("A02start")); +//A01鍗婅嚜鍔ㄥ湴鍧� + List<String> A01Bstart = Arrays.asList(config.getProperty("A01Bstart")); + //A02鍗婅嚜鍔ㄥ湴鍧� + List<String> A02Bstart = Arrays.asList(config.getProperty("A02Bstart")); + //鍥為浂鎸夐挳鍦板潃 + List<String> waddresses4 = Arrays.asList(config.getProperty("HomedButtonAddresses").split(",")); + // 鎵�鏈夊浣嶆寜閽湴鍧� + List<String> Reset = Arrays.asList(config.getProperty("resetButtonAddresses")); + // 鎵�鏈夋湭鍥為浂鎸夐挳鍦板潃 + List<String> addresses8 = Arrays.asList(config.getProperty("notHomedButtonAddresses")); - +// 鎵�鏈夋晠闅滄寜閽浆鎹负1鍜�0 short[] params2 = new short[arraylist7.size()]; for (int i = 0; i < arraylist7.size(); i++) { boolean value = arraylist7.get(i); params2[i] = value ? (short) 1 : (short) 0; } - List<String> addresses8 = new ArrayList<>(); - addresses8.add("DB104.9.0"); - addresses8.add("DB104.9.1"); - addresses8.add("DB104.9.0"); - addresses8.add("DB104.9.1"); - addresses8.add("DB104.9.4"); - addresses8.add("DB104.9.5"); + + List<Boolean> Reset1 = S7control.getinstance().readBits(Reset); + +// 鎵�鏈夋晠闅滄寜閽浆鎹负1鍜�0 + short[] rReset = new short[Reset1.size()]; + for (int i = 0; i < Reset1.size(); i++) { + boolean value = Reset1.get(i); + rReset[i] = value ? (short) 1 : (short) 0; + } + + + List<Boolean> arraylist8 = S7control.getinstance().readBits(addresses8); short[] params = new short[arraylist8.size()]; for (int i = 0; i < arraylist8.size(); i++) { @@ -149,8 +132,6 @@ } - StringBuilder queueid1 = queGlassid("DB100.148", 14); - StringBuilder queueid2 = queGlassid("DB100.162", 14); @@ -200,6 +181,7 @@ jsonObject.append("weihuiling", params); jsonObject.append("jinpianid", queueid1); jsonObject.append("qupianid", queueid2); + jsonObject.append("fuwei", rReset); @@ -211,45 +193,6 @@ WebSocketServer webSocketServer = WebSocketServer.sessionMap.get("ServoManualone"); if (webSocketServer != null) { List<String> messages = webSocketServer.getMessages(); - List<String> waddresses1 = new ArrayList<>(); - waddresses1.add("DB103.32"); - waddresses1.add("DB100.144"); -// waddresses1.add("DB100.148-161"); - waddresses1.add("DB100.184"); - waddresses1.add("DB100.186"); - waddresses1.add("DB100.180"); - waddresses1.add("DB100.182"); - - List<String> waddresses2 = new ArrayList<>(); - waddresses2.add("DB103.26"); - waddresses2.add("DB100.188"); - 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"); - - - - -String waddresses5="DB100.148"; -String waddresses6="DB100.162"; - - - @@ -260,10 +203,8 @@ JSONArray messageArray = new JSONArray(lastMessage); - - - // 鍐欏叆绗竴涓湴鍧� - if (messageArray.getJSONArray(0).size() > 0) { + // 鍐欏叆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++) { @@ -281,11 +222,17 @@ } } if (!sValue.isEmpty()) { - S7control.getinstance().WriteWord(waddresses1, sValue); - System.out.println("Values " + sValue + " written to PLC at address " + waddresses1); + + 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<>(); @@ -304,13 +251,17 @@ } } if (!sValue2.isEmpty()) { - S7control.getinstance().WriteWord(waddresses2, sValue2); - System.out.println("Values " + sValue2 + " written to PLC at address " + waddresses2); + 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); } } - + // 澶嶄綅鎸夐挳鍐欏叆 if (messageArray.getJSONArray(2).size() > 0) { JSONArray jsonArray3 = messageArray.getJSONArray(2); List<Boolean> sValue3 = new ArrayList<>(); @@ -329,12 +280,12 @@ } } if (!sValue3.isEmpty()) { - S7control.getinstance().WriteBit(waddresses3, sValue3); - System.out.println("Values " + sValue3 + " written to PLC at address " + waddresses3); + 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<>(); @@ -358,26 +309,77 @@ } } + + //杩涚墖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,waddresses5); - System.out.println("Values " + jsonArray5 + " written to PLC at address " + waddresses5); + 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,waddresses6); - System.out.println("Values " + value2 + " written to PLC at address " + waddresses6); + 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