From 00620a6917d2c4b0df1f62366a489cfe6aed8be1 Mon Sep 17 00:00:00 2001 From: whycq <913841844@qq.com> Date: 星期四, 02 一月 2025 15:35:28 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/mdqdwcs' into mdqdwcs-auto --- src/main/java/com/zy/core/thread/SiemensDevpThread.java | 175 +++++++++++++++++++++++++++++++++++++++++++++++++++++----- 1 files changed, 159 insertions(+), 16 deletions(-) diff --git a/src/main/java/com/zy/core/thread/SiemensDevpThread.java b/src/main/java/com/zy/core/thread/SiemensDevpThread.java index 287bcb4..f81f389 100644 --- a/src/main/java/com/zy/core/thread/SiemensDevpThread.java +++ b/src/main/java/com/zy/core/thread/SiemensDevpThread.java @@ -42,6 +42,12 @@ private SiemensS7Net siemensS7Net; private Map<Integer, StaProtocol> station = new ConcurrentHashMap<>(); private short heartBeatVal = 1; + public Integer isCalled = 0; + public Integer isFinish = 0; + public ArrayList<Integer> weights = new ArrayList<>(); + public Integer weight = 0; + public ArrayList<Integer> halfs = new ArrayList<>(); + public Integer isHalf = 0; public static final ArrayList<Integer> staNos1 = new ArrayList<Integer>() {{ @@ -254,6 +260,26 @@ } break; + // 鍐欐暟鎹� ID+鐩爣绔� 2106鐗逛緵 + case 3: + switch (slave.getId()){ + case 2: + write2106((StaProtocol)task.getData());break; + } + + break; + case 4: + switch (slave.getId()){ + case 2: + writeIsCalled();break; + } + case 5: + switch (slave.getId()){ + case 2: + writeIsFinish();break; + } + + break; default: break; } @@ -302,6 +328,7 @@ staProtocol.setSiteId(siteId); station.put(siteId, staProtocol); } + staProtocol.setSiteId(siteId); staProtocol.setWorkNo((short) siemensS7Net.getByteTransform().TransInt32(result.Content, i * 8)); // 宸ヤ綔鍙� staProtocol.setStaNo(siemensS7Net.getByteTransform().TransInt16(result.Content, i*8 + 4 )); // 鐩爣绔� } @@ -385,7 +412,9 @@ //鎶ヨ淇℃伅 Thread.sleep(200); OperateResultExOne<byte[]> result3 = null; + OperateResultExOne<byte[]> result37new = null; result3 = siemensS7Net.Read("DB101.96.0", (short) (getErrorStaNo().size() * 4)); + result37new = siemensS7Net.Read("DB101.120", (short) 8); if (result3.IsSuccess) { for (int i = 0; i < getErrorStaNo().size(); i++) { Integer siteId = getErrorStaNo().get(i); // 绔欑偣缂栧彿 @@ -401,6 +430,19 @@ staProtocol.setBarcodeErr(status[6]); } + } + if (result37new.IsSuccess) { + StaProtocol staProtocol11 = station.get(3011); + StaProtocol staProtocol06 = station.get(3006); + short a11171 = siemensS7Net.getByteTransform().TransInt16(result37new.Content, 0); + short a11172 = siemensS7Net.getByteTransform().TransInt16(result37new.Content, 2); + + short a11173 = siemensS7Net.getByteTransform().TransInt16(result37new.Content, 4); + short a11174 = siemensS7Net.getByteTransform().TransInt16(result37new.Content, 6); + staProtocol11.setStaNoEnd(a11173); + staProtocol11.setBan(a11171==1); + staProtocol06.setStaNoEnd(a11174); + staProtocol06.setBan(a11172==1); } } @@ -435,7 +477,7 @@ private void read10() throws InterruptedException { ArrayList<Integer> staNos = getStaNo(); int staNoSize = staNos.size(); - OperateResultExOne<byte[]> result = siemensS7Net.Read("DB101.0", (short) (getStaNo().size() * 10)); + OperateResultExOne<byte[]> result = siemensS7Net.Read("DB101.0", (short) (getStaNo().size() * 12 + 78)); if (result.IsSuccess) { for (int i = 0; i < staNoSize; i++) { Integer siteId = staNos.get(i); // 绔欑偣缂栧彿 @@ -445,18 +487,22 @@ staProtocol.setSiteId(siteId); station.put(siteId, staProtocol); } - staProtocol.setWorkNo((short) siemensS7Net.getByteTransform().TransInt32(result.Content, i * 10)); // 宸ヤ綔鍙� - staProtocol.setStaNo(siemensS7Net.getByteTransform().TransInt16(result.Content, i*10 + 4 )); // 鐩爣绔� - staProtocol.setMatnr((int) siemensS7Net.getByteTransform().TransInt16(result.Content, i * 10 + 6)); // 鐩爣绔� + staProtocol.setWorkNo((short) siemensS7Net.getByteTransform().TransInt32(result.Content, i * 12)); // 宸ヤ綔鍙� + staProtocol.setStaNo(siemensS7Net.getByteTransform().TransInt16(result.Content, i*12 + 4 )); // 鐩爣绔� + if (staProtocol.getSiteId() == 2106){ + staProtocol.setMatnr(siemensS7Net.getByteTransform().TransString(result.Content, 284,22,"UTF-8")); // 鐩爣绔� + } +// staProtocol.setMatnr(""); // 鐩爣绔� + } } Thread.sleep(200); OperateResultExOne<byte[]> result1 = null; - result1 = siemensS7Net.Read("DB101.0", (short) (getStaNo().size() * 10)); + result1 = siemensS7Net.Read("DB101.10", (short) (getStaNo().size() * 12)); if (result1.IsSuccess) { for (int i = 0; i < staNoSize; i++) { Integer siteId = staNos.get(i); // 绔欑偣缂栧彿 - boolean[] status = siemensS7Net.getByteTransform().TransBool(result1.Content, i*10+8, 2); + boolean[] status = siemensS7Net.getByteTransform().TransBool(result1.Content, i*12, 2); StaProtocol staProtocol = station.get(siteId); staProtocol.setAutoing(status[0]); // 鑷姩 staProtocol.setLoading(status[1]); // 鏈夌墿 @@ -475,11 +521,56 @@ } } + OperateResultExOne<byte[]> readBatch = siemensS7Net.Read("DB101.240", (short) 20); + if (readBatch.IsSuccess){ + String batch = siemensS7Net.getByteTransform().TransString(readBatch.Content, 0, 20, "UTF-8"); + for (int i = 0; i < 1; i++) { + StaProtocol staProtocol = station.get(2106); + staProtocol.setBatch(batch); + } + } + + // 绌烘《鍑哄簱淇″彿 + OperateResultExOne<byte[]> readCall = siemensS7Net.Read("DB102", (short) 4); + if (readCall.IsSuccess){ + Integer isNeed = siemensS7Net.getByteTransform().TransInt32(result.Content, 0); // IBC瑕佹《淇″彿 + Integer isFinish = siemensS7Net.getByteTransform().TransInt32(result.Content, 2); // IBC鐏岃瀹屾垚淇″彿 + Integer weight = siemensS7Net.getByteTransform().TransInt32(result.Content, 4); // IBC鐏岃閲嶉噷 + Integer isAHalf = siemensS7Net.getByteTransform().TransInt32(result.Content, 6); // IBC鍗婃《鏍囪 + + isCalled = isNeed; + isFinish = isFinish; + weight = weight; + isHalf = isAHalf; + } + + // 瀹屾垚缃愯淇″彿 + OperateResultExOne<byte[]> finish = siemensS7Net.Read("DB105.240", (short) 4); + if (finish.IsSuccess){ + short amount = siemensS7Net.getByteTransform().TransInt16(result.Content, 0); +// isCalled = amount; + } + +// if (isCalled == 1) { +// writeIsCalled(); +// } + + OperateResultExOne<byte[]> readWeight = siemensS7Net.Read("DB101.260", (short) 2); + if (readWeight.IsSuccess){ + Short weight = siemensS7Net.getByteTransform().TransInt16(readWeight.Content,0); + for (int i = 0; i < 1; i++) { + StaProtocol staProtocol = station.get(2102); + staProtocol.setWeight(weight); + } + } + + + // 鏉$爜鎵弿鍣� if(slave.getId() == 2) { Thread.sleep(200); OperateResultExOne<byte[]> result2 = null; - result2 = siemensS7Net.Read("DB101.194.0", (short) (8)); + result2 = siemensS7Net.Read("DB101.232.0", (short) (8)); if (result2.IsSuccess) { for (int i = 0; i < 1; i++) { String barcode = siemensS7Net.getByteTransform().TransString(result2.Content, i * 8, 8, "UTF-8"); @@ -545,6 +636,7 @@ staProtocol.setOutEnable(status[3]);// 鍙嚭 staProtocol.setForce(status[4]); staProtocol.setAmount(count); + staProtocol.setLow(true); if (!staProtocol.isPakMk() && !staProtocol.isLoading()) { @@ -586,21 +678,30 @@ int staNoSize = staNos.size(); OperateResultExOne<byte[]> result = siemensS7Net.Read("DB101.0", (short) (getStaNo().size() * 8)); - result = siemensS7Net.Read("DB101.0", (short) (getStaNo().size()*30)); + result = siemensS7Net.Read("DB101.0", (short) (getStaNo().size()*82)); if (result.IsSuccess) { for (int i = 0; i < staNoSize; i++) { Integer siteId = staNos.get(i); // 绔欑偣缂栧彿 boolean[] status = siemensS7Net.getByteTransform().TransBool(result.Content, i*4, 1); short tongType = siemensS7Net.getByteTransform().TransInt16(result.Content, i * 4 + 2); - Integer matnr = siemensS7Net.getByteTransform().TransInt32(result.Content, i * 4 + 4); +// String matnr = siemensS7Net.getByteTransform().TransString(result.Content, i * 4 + 4,20, "UTF-8"); + short amount = siemensS7Net.getByteTransform().TransInt16(result.Content, i * 4 + 8); String batch = siemensS7Net.getByteTransform().TransString(result.Content, i * 4+10, 20, "UTF-8"); + short staEnd = siemensS7Net.getByteTransform().TransInt16(result.Content, i * 4 + 30); + short ban = siemensS7Net.getByteTransform().TransInt16(result.Content, i * 4 + 32); + Integer w1 = siemensS7Net.getByteTransform().TransInt32(result.Content, i * 4 + 34); + String orderNo = siemensS7Net.getByteTransform().TransString(result.Content, i * 4 + 38,22, "UTF-8"); + String matnr = siemensS7Net.getByteTransform().TransString(result.Content, i * 4 + 60,22, "UTF-8"); + + StaProtocol staProtocol = station.get(siteId); if (null == staProtocol) { staProtocol = new StaProtocol(); staProtocol.setSiteId(siteId); station.put(siteId, staProtocol); } + staProtocol.setSiteId(siteId); staProtocol.setAutoing(status[0]); // 鑷姩 staProtocol.setLoading(status[1]); // 鏈夌墿 staProtocol.setInEnable(status[2]); // 鍙叆 @@ -609,6 +710,15 @@ staProtocol.setTongType(tongType); staProtocol.setBatch(batch); staProtocol.setAmount(amount); + staProtocol.setAnfme(Double.valueOf(amount)); + staProtocol.setAnfme2(Double.valueOf(amount)); + int i1 = w1 / 100; + staProtocol.setWeight1((double) i1); +// staProtocol.setWeight2(w2); +// staProtocol.setWeight3(w3); +// staProtocol.setWeight4(w4); + staProtocol.setStaNoEnd(staEnd); + staProtocol.setBan(ban == 1); staProtocol.setLow(true); @@ -652,21 +762,27 @@ int staNoSize = staNos.size(); OperateResultExOne<byte[]> result = siemensS7Net.Read("DB101.0", (short) (getStaNo().size() * 8)); - result = siemensS7Net.Read("DB101.0", (short) (getStaNo().size()*28)); + result = siemensS7Net.Read("DB101.0", (short) (getStaNo().size()*78)); if (result.IsSuccess) { for (int i = 0; i < staNoSize; i++) { Integer siteId = staNos.get(i); // 绔欑偣缂栧彿 boolean[] status = siemensS7Net.getByteTransform().TransBool(result.Content, i*4, 1); // short tongType = siemensS7Net.getByteTransform().TransInt16(result.Content, i * 4 + 2); - Integer matnr = siemensS7Net.getByteTransform().TransInt32(result.Content, i * 4 + 2); short amount = siemensS7Net.getByteTransform().TransInt16(result.Content, i * 4 + 6); - String batch = siemensS7Net.getByteTransform().TransString(result.Content, i * 4+8, 20, "UTF-8"); + String batch = siemensS7Net.getByteTransform().TransString(result.Content,i * 4+ 8, 20, "UTF-8"); + short ban = siemensS7Net.getByteTransform().TransInt16(result.Content, i * 4 + 28); + Integer w1 = siemensS7Net.getByteTransform().TransInt32(result.Content, i * 4 + 30); + String orderNo = siemensS7Net.getByteTransform().TransString(result.Content, i * 4 + 34,22, "UTF-8"); + String matnr = siemensS7Net.getByteTransform().TransString(result.Content, i * 4 + 56,22, "UTF-8"); + + StaProtocol staProtocol = station.get(siteId); if (null == staProtocol) { staProtocol = new StaProtocol(); staProtocol.setSiteId(siteId); station.put(siteId, staProtocol); } + staProtocol.setSiteId(siteId); staProtocol.setAutoing(status[0]); // 鑷姩 staProtocol.setLoading(status[1]); // 鏈夌墿 staProtocol.setInEnable(status[2]); // 鍙叆 @@ -675,7 +791,9 @@ staProtocol.setAmount(amount); staProtocol.setBatch(batch); staProtocol.setLow(true); - + int i1 = w1 / 100; + staProtocol.setWeight1((double) i1); + staProtocol.setBan(ban == 1); if (!staProtocol.isPakMk() && !staProtocol.isLoading()) { @@ -747,9 +865,9 @@ } ArrayList<Integer> staNos = getWriteStaNo(); int index = staNos.indexOf(staProtocol.getSiteId()); - OperateResult write = siemensS7Net.Write("DB100." + index*8, staProtocol.getWorkNo().intValue()); // 宸ヤ綔鍙� - OperateResult write1 = siemensS7Net.Write("DB100." + (index*8+4), staProtocol.getStaNo()); // 鐩爣绔� - OperateResult write2 = siemensS7Net.Write("DB100." + (index*8+6), staProtocol.getMatnr()); // 鐩爣绔� + OperateResult write = siemensS7Net.Write("DB100." + index*10, staProtocol.getWorkNo().intValue()); // 宸ヤ綔鍙� + OperateResult write1 = siemensS7Net.Write("DB100." + (index*10+4), staProtocol.getStaNo()); // 鐩爣绔� + OperateResult write2 = siemensS7Net.Write("DB100." + (index*10+6), staProtocol.getMatnr()); // 鐩爣绔� if (!write.IsSuccess || !write1.IsSuccess || !write2.IsSuccess) { staProtocol = station.get(staProtocol.getSiteId()); @@ -764,6 +882,31 @@ } } + private void writeIsCalled() throws InterruptedException { + OperateResult write = siemensS7Net.Write("DB102.0" , 0); // 宸ヤ綔鍙� + } + + private void writeIsFinish() throws InterruptedException { + OperateResult finish = siemensS7Net.Write("DB102.2" , 0); // 宸ヤ綔鍙� + OperateResult half = siemensS7Net.Write("DB102.6" , 0); // 宸ヤ綔鍙� + } + + /** + * 鍐欏叆 ID+鐩爣绔� =====> 鍗曠珯鐐瑰啓鍏� + */ + private void write2106(StaProtocol staProtocol) throws InterruptedException { + + OperateResult write = siemensS7Net.Write("DB100.210", (short) 2); // 鏉$爜閲嶅鍥為�� + + if (!write.IsSuccess) { + OutputQueue.DEVP.offer(MessageFormat.format("銆恵0}銆戝啓鍏ヨ緭閫佺嚎绔欑偣鏁版嵁澶辫触銆傝緭閫佺嚎plc缂栧彿={1}锛岀珯鐐规暟鎹�={2}", slave.getId(), JSON.toJSON(staProtocol))); + log.error("鍐欏叆杈撻�佺嚎绔欑偣鏁版嵁澶辫触銆傝緭閫佺嚎plc缂栧彿={}锛岀珯鐐规暟鎹�={}", slave.getId(), JSON.toJSON(staProtocol)); + } else { + OutputQueue.DEVP.offer(MessageFormat.format("銆恵0}銆� 杈撻�佺嚎鍛戒护涓嬪彂 [id:{1}] >>>>> {2}", DateUtils.convert(new Date()), slave.getId(), JSON.toJSON(staProtocol))); + log.info("杈撻�佺嚎鍛戒护涓嬪彂 [id:{}] >>>>> 鍛戒护涓嬪彂锛� {}", slave.getId(), JSON.toJSON(staProtocol)); + } + } + /** * 蹇冭烦 */ -- Gitblit v1.9.1