From 65bed7f78be75f0ba279885de647d76bc91d9336 Mon Sep 17 00:00:00 2001
From: wu <731351411@qq.com>
Date: 星期五, 19 一月 2024 14:33:13 +0800
Subject: [PATCH] Merge branch 'master' of http://10.153.19.25:10101/r/CanadaMes

---
 springboot-vue3/src/main/java/com/example/springboot/component/Plchome.java |  298 +++++++++++++++++++++++++++++++++++++++--------------------
 1 files changed, 197 insertions(+), 101 deletions(-)

diff --git a/springboot-vue3/src/main/java/com/example/springboot/component/Plchome.java b/springboot-vue3/src/main/java/com/example/springboot/component/Plchome.java
index 32c2368..019d969 100644
--- a/springboot-vue3/src/main/java/com/example/springboot/component/Plchome.java
+++ b/springboot-vue3/src/main/java/com/example/springboot/component/Plchome.java
@@ -1,5 +1,6 @@
 package com.example.springboot.component;
 
+import cn.hutool.json.JSONArray;
 import cn.hutool.json.JSONObject;
 
 import java.io.IOException;
@@ -8,18 +9,16 @@
 import java.util.Arrays;
 import java.util.List;
 
+import com.example.springboot.service.*;
 import org.springframework.beans.factory.annotation.Autowired;
 
 import com.example.springboot.entity.Out_slice;
 import com.example.springboot.entity.Queue;
 import com.example.springboot.entity.StorageCage;
 import com.example.springboot.entity.alarmmg;
+import com.example.springboot.entity.north_glass_buffer1;
 import com.example.springboot.mapper.HomeMapper;
 import com.example.springboot.mapper.SpianMapper;
-import com.example.springboot.service.JdbcConnections;
-import com.example.springboot.service.North_Glass_Buffer1Service;
-import com.example.springboot.service.OutSliceServive;
-import com.example.springboot.service.SpianService;
 
 public class Plchome extends Thread {
 
@@ -33,19 +32,22 @@
     // 鍑虹墖闃熷垪鏄惁鍏佽鍑虹墖
     public static Boolean isAllowQueue = true;
     public static Boolean isAllowReordering = true;
+    // 鍑虹墖闃熷垪璀﹀憡
+    public static Boolean isQueueWarning = false;
     // 閾濇id
-    public static String FrameNo="";
+    public static String FrameNo = "";
     // 鏄惁闇�瑕佹墜鍔ㄧ‘璁ょ幓鐠�
     public static Boolean isConfirm = false;
+    // 寰呯‘璁ょ殑鍑虹墖闃熷垪
+    public static List<north_glass_buffer1> AluminumFrame;
 
-    private Configuration config;
+    // private Configuration config;
 
+    private StorageCageService storageCageService;
 
-
-
-    public Plchome() throws IOException {
-        config = new Configuration("config.properties");
-    }
+    // public Plchome() throws IOException {
+    // config = new Configuration("config.properties");
+    // }
 
     // public static Map b=new HashMap<>();
     // b.put()
@@ -61,6 +63,7 @@
             JSONObject jsonObject = new JSONObject();
 
             // 娉ㄥ叆mapper
+
             homeMapper = WebSocketServer.applicationContext.getBean(HomeMapper.class);
             spianMapper = WebSocketServer.applicationContext.getBean(SpianMapper.class);
             spianService = WebSocketServer.applicationContext.getBean(SpianService.class);
@@ -106,103 +109,185 @@
             jsonObject.append("listoutslice", listoutslice);
             // 鑾峰彇褰撳墠鍑虹墖闃熷垪鍑虹墖鐘舵��
             jsonObject.append("isAllowQueue", Plchome.isAllowQueue);
+            // 鑾峰彇鍑虹墖闃熷垪璀﹀憡鐘舵��
+            jsonObject.append("isQueueWarning", Plchome.isQueueWarning);
             // 鑾峰彇褰撳墠鍑虹墖闃熷垪璋冨簭鐘舵��
             jsonObject.append("isAllowReordering", Plchome.isAllowReordering);
             // 鏄惁闇�瑕佷汉宸ョ‘璁や笂鐗囩幓鐠�
             jsonObject.append("isConfirm", isConfirm);
+            // 鏌ヨ褰撳墠閾濇淇℃伅
+            Out_slice CurrentFrame = outSliceServive.SelectCurrentFrame();
+            jsonObject.append("CurrentFrame", CurrentFrame);
 
-             // 璇诲幓Plc杩涚墖杞︿笌鍑虹墖杞︿綅缃甒
-             List<String> addressList = new ArrayList<String>();
-             addressList.add("DB106.12");
-             addressList.add("DB106.0");
-             List<Short> paramlist = S7control.getinstance().ReadWord(addressList);
-             if (paramlist != null) {
-                 jsonObject.append("params", paramlist);
-             }
-             // 鑾峰彇杩涚墖杞︾姸鎬�
-             List<Short> datas1ListState = S7control.getinstance().ReadWord("DB106.8",
-                     1);// 鑾峰彇杩涚墖杞︾姸鎬�
-             boolean exist1 = datas1ListState.contains((short) 0);
-             jsonObject.append("zhuangtai", exist1);
-             // 鑾峰彇杩涚墖鐜荤拑淇℃伅
-             List<Short> inglassInfo = S7control.getinstance().ReadWord("DB106.24", 1);
-             if (inglassInfo != null) {
-                 if (inglassInfo.size() > 0)
-                     jsonObject.append("loadglassheight", inglassInfo.get(0) * 70);
-             }
-
-             // 鑾峰彇閾濇idDB106.DBW64
-             String frameno = spianService.queGlassid("DB103.270", 14).toString();
-             // String frameno="X12345611002GV";
-             if (!frameno.equals(Plchome.FrameNo)) {
-                 Plchome.FrameNo = frameno;
-                 try {
-                     north_Glass_Buffer1Service.AddOutSliceS(Plchome.FrameNo);
-                 } catch (SQLException e) {
-                     // TODO Auto-generated catch block
-                     e.printStackTrace();
-                 }
-             }
-
-             // 鑾峰彇杩涚墖璇锋眰鐘舵��
-             List<Short> D01Request = S7control.getinstance().ReadWord("DB106.24", 1);
-             boolean D01RequestState = D01Request.contains((short) 1);
-             // boolean D01RequestState =true;
-             jsonObject.append("D01RequestState", D01RequestState);
-
-             // 澶嶄綅鍊掕鏃�
-             // 鍦板潃104.9.6
-             List<Boolean> countdown = S7control.getinstance().ReadBits("DB104.9.6", 1);
-             for (Boolean countdowns : countdown) {
-                 jsonObject.append("countdown", countdowns);
-             }
-             // jsonObject.append("countdown", true);
-             // 澶嶄綅瀹屾垚淇″彿
-             List<Boolean> resets = S7control.getinstance().ReadBits("DB103.284", 1);
-             for (Boolean reset : resets) {
-                 jsonObject.append("reset", reset);
-             }
-
-             // 鏄惁鎬ュ仠
-             List<Boolean> emergencystops = S7control.getinstance().ReadBits("DB104.5.1", 1);
-             for (Boolean emergencystop : emergencystops) {
-                 jsonObject.append("emergencystop", emergencystop);
-             }
-
-             //缁堟缁х画鎸夐挳
-            List<String> niuanaddressList3 = Arrays.asList(config.getProperty("Parameter2.stop").split(","));
-            List<Boolean> anniuread = S7control.getinstance().readBits(niuanaddressList3);
-
-            short[] anniuparams = new short[anniuread.size()];
-            for (int i = 0; i < anniuread.size(); i++) {
-                boolean value = anniuread.get(i);
-                anniuparams[i] = value ? (short) 1 : (short) 0;
-            }
-            jsonObject.append("Abort", anniuparams);
-            // 閾濇绾夸氦浜�
-
-            // //閾濇id璇锋眰瀛�
-            // List<Short> framerequest = S7control.getinstance().ReadWord("閾濇id璇锋眰瀛楀湴鍧�", 1);
-            // if(framerequest!=null){
-            // //閾濇id
-            // String franmeno= spianService.queGlassid("閾濇id鍦板潃", 14).toString();
-            // String position;
+            // List<Short> listd17 = S7control.getinstance().ReadWord("DB17.0",10);
+            // String id=spianService.queGlassid("DB17.10", 14).toString();
+            // 
+            // // 閾濇绾夸氦浜�
             // try {
-            // position=dbserve.SelectPositionByFrameBarcode(franmeno);
-            // } catch (SQLException e) {
-            // // TODO Auto-generated catch block
-            // position="0";
-            // e.printStackTrace();
-            // }
-            // Short send;
-            // if(position=="0"){
-            // send=0;
-            // }else{
-            // send=1;
-            // }
-            // S7control.getinstance().WriteWord("閾濇缈昏浆鍙戦�佸湴鍧�", (short)send);
+            //     if (CurrentFrame != null) {
+            //         spianService.outmesid(CurrentFrame.getBarCode(), "DB17.0");
+            //     }
+            //     List<Short> framerequests = S7control.getinstance().ReadWord("閾濇id璇锋眰瀛楀湴鍧�", 1);
+            //     for (Short framerequest : framerequests) {
+            //         if (framerequest == 1) {
+            //             // 閾濇id
+            //             String franmeno = spianService.queGlassid("DB17.10", 14).toString();
+            //             String position;
+            //             try {
+            //                 position = dbserve.SelectPositionByFrameBarcode(franmeno);
+            //             } catch (SQLException e) {
+            //                 // TODO Auto-generated catch block
+            //                 position = "0";
+            //                 e.printStackTrace();
+            //             }
+            //             Short send;
+            //             if (position == "0") {
+            //                 send = 0;
+            //             } else {
+            //                 send = 1;
+            //             }
+            //             S7control.getinstance().WriteWord("閾濇缈昏浆鍙戦�佸湴鍧�", (short) send);
+            //         }
+            //     }
+            // } catch (Exception e) {
+            //     // TODO: handle exception
             // }
 
+            if (S7control.getinstance().CheckConnected() == true) {
+                // 鑾峰彇褰撳墠鎵爜鏂瑰紡
+                List<Short> Scanningmethod = S7control.getinstance().ReadWord("DB103.255", 1);
+                jsonObject.append("Scanningmethod", Scanningmethod);
+                // 鑾峰彇D01-D06,A01,A02,B01,B02鐘舵��
+                List<Short> DeviceList = S7control.getinstance().ReadWord("DB103.0", 10);
+                jsonObject.append("DeviceList", DeviceList);
+                // 鑾峰彇D01-D06,A01,A02,B01,B02鐜荤拑id
+                List<String> GlassIdList = new ArrayList<String>();
+                GlassIdList.add(spianService.queGlassid("DB103.40", 14).toString());
+                GlassIdList.add(spianService.queGlassid("DB103.58", 14).toString());
+
+                GlassIdList.add(spianService.queGlassid("DB103.184", 14).toString());
+                GlassIdList.add(spianService.queGlassid("DB103.212", 14).toString());
+
+                GlassIdList.add(spianService.queGlassid("DB103.128", 14).toString());
+                GlassIdList.add(spianService.queGlassid("DB103.142", 14).toString());
+                GlassIdList.add(spianService.queGlassid("DB103.156", 14).toString());
+
+                GlassIdList.add(spianService.queGlassid("DB103.72", 14).toString());
+                GlassIdList.add(spianService.queGlassid("DB103.86", 14).toString());
+                GlassIdList.add(spianService.queGlassid("DB103.100", 14).toString());
+                GlassIdList.add(spianService.queGlassid("DB103.114", 14).toString());
+                jsonObject.append("GlassIdList", GlassIdList);
+
+                // 璇诲幓Plc杩涚墖杞︿笌鍑虹墖杞︿綅缃甒
+                List<String> addressList = new ArrayList<String>();
+                addressList.add("DB106.12");
+                addressList.add("DB106.0");
+                List<Short> paramlist = S7control.getinstance().ReadWord(addressList);
+                if (paramlist != null) {
+                    jsonObject.append("params", paramlist);
+                }
+                // 鑾峰彇杩涚墖杞︾姸鎬�
+                List<Short> datas1ListState = S7control.getinstance().ReadWord("DB106.8",
+                        1);// 鑾峰彇杩涚墖杞︾姸鎬�
+                if (datas1ListState != null) {
+                    boolean exist1 = datas1ListState.contains((short) 0);
+                    jsonObject.append("zhuangtai", exist1);
+                }
+
+                // 鑾峰彇杩涚墖鐜荤拑淇℃伅
+                List<Short> inglassInfo = S7control.getinstance().ReadWord("DB106.24", 1);
+                if (inglassInfo != null) {
+                    if (inglassInfo.size() > 0) {
+                        jsonObject.append("loadglassheight", inglassInfo.get(0) * 70);
+                    }
+
+                }
+                // // 鑾峰彇閾濇idDB106.DBW64锛屾坊鍔犲埌鍑虹墖闃熷垪
+                // String frameno="X21763329601FB";
+                String frameno = spianService.queGlassid("DB103.270", 14).toString();
+                if (!frameno.equals(Plchome.FrameNo)) {
+                    Plchome.FrameNo = frameno;
+                    try {
+                        Short num = 0;
+                        List<north_glass_buffer1> north_glass_buffer1s = north_Glass_Buffer1Service
+                                .SelectAluminumFrameInfoById(Plchome.FrameNo);
+                        for (north_glass_buffer1 north_glass_buffer1 : north_glass_buffer1s) {
+                            if (north_glass_buffer1.getstorageCage() == null) {
+                                break;
+                            }
+                            num++;
+                        }
+                        if (num == north_glass_buffer1s.size()) {
+                            north_Glass_Buffer1Service.AddOutSliceS(Plchome.FrameNo);
+                        } else {
+                            Plchome.AluminumFrame = north_glass_buffer1s;
+                        }
+                    } catch (SQLException e) {
+                        // TODO Auto-generated catch block
+                        e.printStackTrace();
+                    }
+                }
+                if (AluminumFrame != null) {
+                    jsonObject.append("AluminumFrame", AluminumFrame);
+                }
+
+                // 鑾峰彇杩涚墖璇锋眰鐘舵��
+                List<Short> D01Request = S7control.getinstance().ReadWord("DB106.24", 1);
+                boolean D01RequestState = D01Request.contains((short) 1);
+                // boolean D01RequestState =true;
+                jsonObject.append("D01RequestState", D01RequestState);
+
+                // 澶嶄綅鍊掕鏃�
+                // 鍦板潃104.9.6
+                List<Boolean> countdown = S7control.getinstance().ReadBits("DB104.9.6", 1);
+                for (Boolean countdowns : countdown) {
+                    jsonObject.append("countdown", countdowns);
+                }
+                // jsonObject.append("countdown", true);
+                // 澶嶄綅瀹屾垚淇″彿ss
+                List<Boolean> resetss = S7control.getinstance().ReadBits("DB103.284", 1);
+                for (Boolean reset : resetss) {
+                    jsonObject.append("reset", reset);
+                }
+
+                // 鏄惁鎬ュ仠
+                List<Boolean> emergencystops = S7control.getinstance().ReadBits("DB104.5.1", 1);
+                for (Boolean emergencystop : emergencystops) {
+                    jsonObject.append("emergencystop", emergencystop);
+                }
+
+                // // 缁堟缁х画鎸夐挳
+                // List<String> niuanaddressList3 =
+                // Arrays.asList(config.getProperty("Parameter2.stop").split(","));
+                // List<Boolean> anniuread =
+                // S7control.getinstance().readBits(niuanaddressList3);
+                // // Boolean[] value4 = { false, false};
+                // // List<Boolean> anniuread = new ArrayList<>(Arrays.asList(value4));
+                // Boolean[] value5 = { true };
+                // List<Boolean> resets = new ArrayList<>(Arrays.asList(value5));
+                // short[] anniuparams = new short[anniuread.size()];
+                // for (int i = 0; i < anniuread.size(); i++) {
+                // boolean value = anniuread.get(i);
+                // anniuparams[i] = value ? (short) 1 : (short) 0;
+                // }
+
+                // short[] resets2 = new short[resets.size()];
+                // for (int i = 0; i < resets.size(); i++) {
+                // boolean value = resets.get(i);
+                // resets2[i] = value ? (short) 1 : (short) 0;
+                // }
+
+                // for (short number : resets2) {
+
+                // if (number == 1) {
+                // jsonObject.append("Abort", anniuparams);
+
+                // }
+
+                // }
+            }
+
+            storageCageService = WebSocketServer.applicationContext.getBean(StorageCageService.class);
             dbserve = WebSocketServer.applicationContext.getBean(JdbcConnections.class);
             boolean dbconnected = false;
             try {
@@ -218,9 +303,20 @@
             if (sendwServer != null) {
                 for (WebSocketServer webserver : sendwServer) {
                     webserver.sendMessage(jsonObject.toString());
+
+                    if (webserver != null) {
+
+                        List<String> messages = webserver.getMessages();
+
+                        if (!messages.isEmpty()) {
+                            // // 灏嗘渶鍚庝竴涓秷鎭浆鎹负鏁存暟绫诲瀷鐨勫垪琛�
+                            webserver.clearMessages();
+                        }
+
+                    }
+
                 }
             }
-
         }
     }
 }

--
Gitblit v1.8.0