From 31101f632c27c05d15f30ca3084e3ed3da2a29af Mon Sep 17 00:00:00 2001 From: wu <731351411@qq.com> Date: 星期五, 08 十二月 2023 11:42:08 +0800 Subject: [PATCH] Merge branch 'master' of http://10.153.19.25:10101/r/CanadaMes --- springboot-vue3/src/main/java/com/example/springboot/component/PlcManualonePosition2.java | 109 ++++++++++++++++++++++++++++++++---------------------- 1 files changed, 64 insertions(+), 45 deletions(-) diff --git a/springboot-vue3/src/main/java/com/example/springboot/component/PlcManualonePosition2.java b/springboot-vue3/src/main/java/com/example/springboot/component/PlcManualonePosition2.java index 61e8c6f..9fd9c89 100644 --- a/springboot-vue3/src/main/java/com/example/springboot/component/PlcManualonePosition2.java +++ b/springboot-vue3/src/main/java/com/example/springboot/component/PlcManualonePosition2.java @@ -10,52 +10,41 @@ import java.util.List; public class PlcManualonePosition2 extends Thread { - String name = ""; - Integer count = 0; + private Configuration config; - public static String readFileToString(String filePath) throws IOException { - File file = new File(filePath); - return FileUtils.readFileToString(file, "UTF-8"); + public PlcManualonePosition2() throws IOException { + config = new Configuration("config.properties"); } - 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 static class PLCBooleanConverter { + + public static short[] convertListsToBinaryShortArray(List<Boolean>... lists) { + // 璁$畻鎵�鏈夊垪琛ㄤ腑鍏冪礌鐨勬�绘暟 + int totalSize = 0; + for (List<Boolean> list : lists) { + totalSize += list.size(); } - // 灏唖tr瀛楃涓叉牸寮忚浆涓簀son - JSONObject jsonObject = new JSONObject(str); + // 鍒涘缓涓�涓冻澶熷ぇ鐨勬暟缁勬潵瀛樻斁鎵�鏈夌殑浜岃繘鍒跺�� + short[] binaryShortArray = new short[totalSize]; - // 鑾峰彇json涓殑鍊� - JSONArray address = jsonObject.getJSONArray("ServoManualone"); - for (int i = 0; i < address.size(); i++) { - JSONObject ress = (JSONObject) address.get(i); + // 褰撳墠鏁扮粍濉厖浣嶇疆鎸囬拡 + int currentIndex = 0; - this.name = ress.getStr("name"); - this.count = ress.getInt("count"); - + // 閬嶅巻鎵�鏈夌殑鍒楄〃 + for (List<Boolean> list : lists) { + // 灏嗘瘡涓竷灏斿�艰浆鎹负 0 鎴� 1 骞跺~鍏ユ暟缁� + for (Boolean value : list) { + binaryShortArray[currentIndex++] = (short) (value ? 1 : 0); + } } - } catch (FileNotFoundException e) { - e.printStackTrace(); - } catch (UnsupportedEncodingException e) { - e.printStackTrace(); - } catch (IOException e) { - e.printStackTrace(); + return binaryShortArray; } } + + + @Override public void run() { @@ -120,12 +109,30 @@ params3[i] = value ? (short) 1 : (short) 0; } + + + //A01鍚姩鍦板潃 + List<String> A01start = Arrays.asList(config.getProperty("mlp2.A01start")); + //A02鍚姩鍦板潃 + List<String> A02start = Arrays.asList(config.getProperty("mlp2.A02start")); + + + + List<Boolean> A01readstart = S7control.getinstance().readBits(A01start); + List<Boolean> A02readstart = S7control.getinstance().readBits(A02start); + + + short[] combinedBinaryShortArray = PlcManualonePosition2.PLCBooleanConverter.convertListsToBinaryShortArray( + A01readstart, A02readstart + ); + JSONObject jsonObject = new JSONObject(); jsonObject.append("zuhe1", arraylist); jsonObject.append("zuhe2", arraylist2); jsonObject.append("guzhang", params2); jsonObject.append("weihuiling", params3); + jsonObject.append("qidong", combinedBinaryShortArray); // System.out.println(jsonObject); WebSocketServer sendwServer = WebSocketServer.sessionMap.get("ManualonePosition2"); if (sendwServer != null) { @@ -186,11 +193,17 @@ } if (!sValue.isEmpty()) { S7control.getinstance().WriteWord(waddresses1, sValue); - List<String> A01start = new ArrayList<>(); - A01start.add("DB101.2.0"); - Boolean[] a01values7 = { true}; - List<Boolean> a01startval = new ArrayList<>(Arrays.asList(a01values7)); - S7control.getinstance().WriteBit(A01start, a01startval); + if (A01readstart != null && !A01readstart.isEmpty()) { + // 鍒涘缓涓�涓柊鐨勫垪琛ㄧ敤浜庡啓鍏ユ柊鍊� + List<Boolean> a01startval = new ArrayList<>(); + // 閬嶅巻鎵�鏈夎鍙栧埌鐨勪綅鍊� + for (Boolean bit : A01readstart) { + // 鍙栧弽褰撳墠浣嶇殑鍊煎苟娣诲姞鍒版柊鐨勫垪琛ㄤ腑 + a01startval.add(!bit); + } + // 鍐欏叆鏂扮殑浣嶅�煎垪琛� + S7control.getinstance().WriteBit(A01start, a01startval); + } System.out.println("Values " + sValue + " written to PLC at address " + waddresses1); } } @@ -215,11 +228,17 @@ } if (!sValue2.isEmpty()) { S7control.getinstance().WriteWord(waddresses2, sValue2); - List<String> A02start = new ArrayList<>(); - A02start.add("DB101.2.1"); - Boolean[] a02values7 = { true}; - List<Boolean> a01startval = new ArrayList<>(Arrays.asList(a02values7)); - S7control.getinstance().WriteBit(A02start, a01startval); + if (A02readstart != null && !A02readstart.isEmpty()) { + // 鍒涘缓涓�涓柊鐨勫垪琛ㄧ敤浜庡啓鍏ユ柊鍊� + List<Boolean> a02startval = new ArrayList<>(); + // 閬嶅巻鎵�鏈夎鍙栧埌鐨勪綅鍊� + for (Boolean bit : A02readstart) { + // 鍙栧弽褰撳墠浣嶇殑鍊煎苟娣诲姞鍒版柊鐨勫垪琛ㄤ腑 + a02startval.add(!bit); + } + // 鍐欏叆鏂扮殑浣嶅�煎垪琛� + S7control.getinstance().WriteBit(A02start, a02startval); + } System.out.println("Values " + sValue2 + " written to PLC at address " + waddresses2); } } -- Gitblit v1.8.0