From ad54981b1831bd6e31f45901bb2b08b8d7a3ff68 Mon Sep 17 00:00:00 2001 From: LSH Date: 星期三, 31 五月 2023 15:36:11 +0800 Subject: [PATCH] # --- src/main/java/com/zy/core/thread/SiemensDevpThread.java | 57 +++++++++++++++++++++++++++++++++++++++++++++++---------- 1 files changed, 47 insertions(+), 10 deletions(-) diff --git a/src/main/java/com/zy/core/thread/SiemensDevpThread.java b/src/main/java/com/zy/core/thread/SiemensDevpThread.java index ea0e6b9..b4ee00b 100644 --- a/src/main/java/com/zy/core/thread/SiemensDevpThread.java +++ b/src/main/java/com/zy/core/thread/SiemensDevpThread.java @@ -42,18 +42,19 @@ private Map<Integer, StaProtocol> station = new ConcurrentHashMap<>(); private short heartBeatVal = 1; public static final ArrayList<Integer> staNos = new ArrayList<Integer>() {{ - add(101);add(102);add(103);add(104);add(105);add(106);add(107);add(108);add(109); -// add(201);add(202);add(203);add(204); -// add(301);add(302);add(303);add(304);add(305);add(306); + add(101);add(102);add(103);add(104); + add(201);add(202);add(203);add(204);add(205);add(206); + add(207);add(208);add(209);add(210);add(211);add(212); + add(213);add(105); }}; /** * 鏉$爜鏁伴噺 */ - private int barcodeSize = 1; + private int barcodeSize = 2; public IoModeType ioMode = IoModeType.NONE; - public int[] startSignal = new int[48]; + public int[][] startSignal = new int[48][2]; public SiemensDevpThread(DevpSlave slave) { this.slave = slave; @@ -78,6 +79,15 @@ // 鍐欐暟鎹� ID+鐩爣绔� case 2: write((StaProtocol)task.getData()); + break; + // 鍐欐暟鎹� 103绔欑偣鍐欏叆PACK鐮� + case 4: + write103((String)task.getData()); + break; + // 鐏淇″彿 + case 5: + StaProtocol staProtocol2 = (StaProtocol)task.getData(); + siemensS7Net.Write("DB102.0" + staProtocol2.getSiteId(), staProtocol2.getStaNo()==1); break; //澶嶄綅娴嬭瘯淇″彿 case 3: @@ -175,23 +185,32 @@ } Thread.sleep(200); - OperateResultExOne<byte[]> result2 = siemensS7Net.Read("DB100.190",(short)(barcodeSize*12)); + OperateResultExOne<byte[]> result2 = siemensS7Net.Read("DB100.190",(short)(26)); + OperateResultExOne<byte[]> result5 = siemensS7Net.Read("DB100.216",(short)(6)); if (result2.IsSuccess) { - for (int i = 0; i < barcodeSize; i++) { - String barcode = siemensS7Net.getByteTransform().TransString(result2.Content,i*12,12, "UTF-8"); + String barcode =siemensS7Net.getByteTransform().TransString(result2.Content,0,26, "UTF-8"); // String barcode=new String(result2.Content,i*12,12); - BarcodeThread barcodeThread = (BarcodeThread) SlaveConnection.get(SlaveType.Barcode, i + 1); + BarcodeThread barcodeThread = (BarcodeThread) SlaveConnection.get(SlaveType.Barcode, 1); if(!Cools.isEmpty(barcodeThread) && !barcodeThread.getBarcode().equals(barcode)) { barcodeThread.setBarcode(barcode); } + } + if (result5.IsSuccess) { + String barcode =siemensS7Net.getByteTransform().TransString(result5.Content,0,6, "UTF-8"); +// String barcode=new String(result2.Content,i*12,12); + BarcodeThread barcodeThread = (BarcodeThread) SlaveConnection.get(SlaveType.Barcode, 2); + if(!Cools.isEmpty(barcodeThread) && !barcodeThread.getBarcode().equals(barcode)) { + barcodeThread.setBarcode(barcode); } } Thread.sleep(200); OperateResultExOne<byte[]> result3 = siemensS7Net.Read("DB102.0", (short) 96); + OperateResultExOne<byte[]> result4 = siemensS7Net.Read("DB102.0", (short) 96); if(result3.IsSuccess) { for(int i=0; i<48; i++){ - startSignal[i] = siemensS7Net.getByteTransform().TransInt16(result3.Content, i*2); + startSignal[i][0] = siemensS7Net.getByteTransform().TransInt16(result3.Content, i*2); + startSignal[i][1] = siemensS7Net.getByteTransform().TransInt16(result4.Content, i*2); } } // OperateResultExOne<Short> result2 = siemensS7Net.ReadInt16("DB200.0"); @@ -228,6 +247,24 @@ } /** + * 鍐欏叆 pack鐮� =====> 鍗曠珯鐐瑰啓鍏� + */ + private void write103(String packNo){ + try{ + OperateResult write = siemensS7Net.Write("DB100.", packNo); + if (!write.IsSuccess) { + OutputQueue.DEVP.offer(MessageFormat.format("銆恵0}銆戝啓鍏ヨ緭閫佺嚎绔欑偣鏁版嵁澶辫触銆傝緭閫佺嚎plc缂栧彿={1}锛岀珯鐐规暟鎹�={2}", slave.getId(), JSON.toJSON(packNo))); + log.error("鍐欏叆杈撻�佺嚎绔欑偣鏁版嵁澶辫触銆傝緭閫佺嚎plc缂栧彿={}锛岀珯鐐规暟鎹�={}", slave.getId(), JSON.toJSON(packNo)); + } else { + OutputQueue.DEVP.offer(MessageFormat.format("銆恵0}銆� 杈撻�佺嚎鍛戒护涓嬪彂 [id:{1}] >>>>> {2}", DateUtils.convert(new Date()), slave.getId(), JSON.toJSON(packNo))); + log.info("杈撻�佺嚎鍛戒护涓嬪彂 [id:{}] >>>>> 鍛戒护涓嬪彂锛� {}", slave.getId(), JSON.toJSON(packNo)); + } + }catch (Exception e){ + log.error("103绔欑偣鍐欏叆鏁版嵁澶辫触锛岃緭閫佺嚎绾跨▼write103"); + } + } + + /** * 鍐欏叆 ID+鐩爣绔� =====> 鍗曠珯鐐瑰啓鍏� */ private void write(StaProtocol staProtocol) throws InterruptedException { -- Gitblit v1.9.1