From 78b52c20a27a02466c8af9c0c8222b9f2f3ff20c Mon Sep 17 00:00:00 2001 From: whycq <913841844@qq.com> Date: 星期四, 18 一月 2024 19:59:47 +0800 Subject: [PATCH] # --- src/main/java/com/zy/core/thread/SiemensDevpThread.java | 63 +++++++++++++++++++++++++++++-- 1 files changed, 59 insertions(+), 4 deletions(-) diff --git a/src/main/java/com/zy/core/thread/SiemensDevpThread.java b/src/main/java/com/zy/core/thread/SiemensDevpThread.java index 3ef813e..979e434 100644 --- a/src/main/java/com/zy/core/thread/SiemensDevpThread.java +++ b/src/main/java/com/zy/core/thread/SiemensDevpThread.java @@ -72,6 +72,17 @@ public static final ArrayList<Integer> staNosErr3 = new ArrayList<Integer>() {{ add(301); add(303); add(305); }}; + + public static final ArrayList<Integer> barcode1 = new ArrayList<Integer>() {{ + add(0); add(1); add(2); + }}; + public static final ArrayList<Integer> barcode2 = new ArrayList<Integer>() {{ + add(3); add(4); add(5); + }}; + public static final ArrayList<Integer> barcode3 = new ArrayList<Integer>() {{ + add(6); add(7); add(8); + }}; + private ArrayList<Integer> getStaNo() { switch (slave.getId()) { case 1: @@ -84,6 +95,19 @@ throw new CoolException("鑾峰彇绔欑偣澶辫触锛�"); } } + private ArrayList<Integer> getBarcodeList() { + switch (slave.getId()) { + case 1: + return barcode1; + case 2: + return barcode2; + case 3: + return barcode3; + default: + throw new CoolException("鑾峰彇绔欑偣澶辫触锛�"); + } + } + private ArrayList<Integer> getStaNoErr() { switch (slave.getId()) { case 1: @@ -219,6 +243,24 @@ staProtocol.setPakMk(true); } } + + // 鏍规嵁瀹炴椂淇℃伅鏇存柊鏁版嵁搴� + try { + List<BasDevp> basDevps = new ArrayList<>(); + for (Integer siteId : staNos) { + StaProtocol staProtocol = station.get(siteId); + basDevps.add(staProtocol.toSqlModel()); + } + + BasDevpService basDevpService = SpringUtils.getBean(BasDevpService.class); + if (null != basDevpService && !basDevpService.updateBatchById(basDevps)) { + throw new Exception("鏇存柊鏁版嵁搴撴暟鎹け璐�"); + } + } catch (Exception e) { + e.printStackTrace(); + OutputQueue.DEVP.offer(MessageFormat.format("銆恵0}銆戞洿鏂版暟鎹簱鏁版嵁澶辫触 ===>> [id:{1}] [ip:{2}] [port:{3}] [rack:{4}] [slot:{5}]", DateUtils.convert(new Date()), slave.getId(), slave.getIp(), slave.getPort(), slave.getRack(), slave.getSlot())); + News.error(methodName + ":鏇存柊鏁版嵁搴撴暟鎹け璐� ===>> [id:{}] [ip:{}] [port:{}] [rack:{}] [slot:{}]", slave.getId(), slave.getIp(), slave.getPort(), slave.getRack(), slave.getSlot()); + } } //澶栧舰妫�娴� ArrayList<Integer> staNoErrs = getStaNoErr(); @@ -241,17 +283,30 @@ //鏉$爜鎵弿鍣� // Thread.sleep(200); - OperateResultExOne<byte[]> result2 = siemensS7Net.Read("DB101.840",(short)(barcodeSize*10)); +// OperateResultExOne<byte[]> result2 = siemensS7Net.Read("DB101.840",(short)(barcodeSize*8)); +// if (result2.IsSuccess) { +// for (int i = 0; i < barcodeSize; i++) { +// String barcode = siemensS7Net.getByteTransform().TransString(result2.Content,i*8,8, "UTF-8"); +// BarcodeThread barcodeThread = (BarcodeThread) SlaveConnection.get(SlaveType.Barcode, i + 1); +// if(!Cools.isEmpty(barcodeThread) && !barcodeThread.getBarcode().equals(barcode)) { +// barcodeThread.setBarcode(barcode); +// } +// } +// } + + ArrayList<Integer> barcodeList = getBarcodeList(); + OperateResultExOne<byte[]> result2 = siemensS7Net.Read("DB101.840", (short) (barcodeList.size() * 8)); if (result2.IsSuccess) { - for (int i = 0; i < barcodeSize; i++) { + for (int i = 0; i < barcodeList.size(); i++) { + Integer barcodeId = barcodeList.get(i); String barcode = siemensS7Net.getByteTransform().TransString(result2.Content,i*8,8, "UTF-8"); - BarcodeThread barcodeThread = (BarcodeThread) SlaveConnection.get(SlaveType.Barcode, i + 1); + BarcodeThread barcodeThread = (BarcodeThread) SlaveConnection.get(SlaveType.Barcode, barcodeId + 1); if(!Cools.isEmpty(barcodeThread) && !barcodeThread.getBarcode().equals(barcode)) { barcodeThread.setBarcode(barcode); } } - } + //RGV灏忚溅 // Thread.sleep(200); OperateResultExOne<byte[]> result3 = siemensS7Net.Read("DB100.160",(short)2); -- Gitblit v1.9.1