From a446066c5f3cedc33e035b2bbc9ad36b5aa18512 Mon Sep 17 00:00:00 2001 From: ZengTao <2773468879@qq.com> Date: 星期四, 14 十二月 2023 08:25:11 +0800 Subject: [PATCH] 调整提示框字体大小 --- springboot-vue3/src/main/java/com/example/springboot/component/PlcServoManualone.java | 333 ++++++++++++++++++++----------------------------------- 1 files changed, 121 insertions(+), 212 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..7d5e20e 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,34 @@ 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( + A01readBstart, A01readstart, A02readsBtart,A02readstart + ); + +// System.out.println(A01readBstart); // 鎵�鏈夋晠闅滄寜閽浆鎹负1鍜�0 short[] params2 = new short[arraylist7.size()]; @@ -112,9 +151,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 +168,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 +227,71 @@ 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); - } - } - } - if (!sValue.isEmpty()) { + // 鍐欏叆AO1缁勫悎 + customS7Control.WriteWordToPLC(messageArray, addresses,0); - 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); + //A01鍗婅嚜鍔ㄥ惎鍔� + customS7Control.writeBitToPLC( messageArray, A01start,8); + + + // 鍐欏叆AO2缁勫悎 + customS7Control.WriteWordToPLC(messageArray, addresses2,1); + //A02鍗婅嚜鍔ㄥ惎鍔� + + customS7Control.writeBitToPLC( messageArray, A02start,9); + + + + // 澶嶄綅鎸夐挳鍐欏叆 + 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(); } } - - - //// 鍐欏叆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); - } - } - } - 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); - } - } - - - // 澶嶄綅鎸夐挳鍐欏叆 - 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