From 80553df5d1632cd762253e4d2cfb9963e7752453 Mon Sep 17 00:00:00 2001 From: zjj <3272660260@qq.com> Date: 星期三, 12 三月 2025 19:22:47 +0800 Subject: [PATCH] # --- src/main/java/com/zy/core/thread/SiemensDevpThread.java | 96 +++++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 90 insertions(+), 6 deletions(-) diff --git a/src/main/java/com/zy/core/thread/SiemensDevpThread.java b/src/main/java/com/zy/core/thread/SiemensDevpThread.java index 7f95c11..70a9fef 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>() {{ @@ -259,6 +265,18 @@ 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; @@ -511,6 +529,30 @@ staProtocol.setBatch(batch); } } + + // 绌烘《鍑哄簱淇″彿 + OperateResultExOne<byte[]> readCall = siemensS7Net.Read("DB102.0", (short) 8); + if (readCall.IsSuccess){ + int isNeed = siemensS7Net.getByteTransform().TransInt16(readCall.Content, 0); // IBC瑕佹《淇″彿 + int Finish = siemensS7Net.getByteTransform().TransInt16(readCall.Content, 2); // IBC鐏岃瀹屾垚淇″彿 + int weight1 = siemensS7Net.getByteTransform().TransInt16(readCall.Content, 4); // IBC鐏岃閲嶉噷 + int isAHalf = siemensS7Net.getByteTransform().TransInt16(readCall.Content, 6); // IBC鍗婃《鏍囪 + isCalled = isNeed; + isFinish = Finish; + weight = weight1; + isHalf = isAHalf; + } + + // 瀹屾垚缃愯淇″彿 +// OperateResultExOne<byte[]> finish = siemensS7Net.Read("DB105.240", (short) 4); +// if (finish.IsSuccess){ +// short amount = siemensS7Net.getByteTransform().TransInt16(finish.Content, 0); +//// isCalled = amount; +// } + +// if (isCalled == 1) { +// writeIsCalled(); +// } OperateResultExOne<byte[]> readWeight = siemensS7Net.Read("DB101.260", (short) 2); if (readWeight.IsSuccess){ @@ -796,9 +838,23 @@ } ArrayList<Integer> staNos = getWriteStaNo(); int index = staNos.indexOf(staProtocol.getSiteId()); - OperateResult write = siemensS7Net.Write("DB100." + index*6, staProtocol.getWorkNo().intValue()); // 宸ヤ綔鍙� - Thread.sleep(500); - OperateResult write1 = siemensS7Net.Write("DB100." + (index*6+4), staProtocol.getStaNo()); // 鐩爣绔� + OperateResult write = null; + OperateResult write1 = null; + //浠诲姟涓嬪彂娆℃暟 + int writeCount = 0; + do { + write = siemensS7Net.Write("DB100." + index*6, staProtocol.getWorkNo()); // 宸ヤ綔鍙� + Thread.sleep(200); + write1 = siemensS7Net.Write("DB100." + (index*6+4), staProtocol.getStaNo().shortValue()); // 鐩爣绔� + if(write.IsSuccess && write1.IsSuccess){ + log.error("鍐欏叆杈撻�佺嚎鍛戒护鎴愬姛銆傝緭閫佺嚎plc缂栧彿={}锛岀珯鐐规暟鎹�={},鍐欏叆娆℃暟={}", slave.getId(), JSON.toJSON(staProtocol), writeCount); + break; + } + else { + writeCount++; + log.error("鍐欏叆杈撻�佺嚎鍛戒护澶辫触銆傝緭閫佺嚎plc缂栧彿={}锛岀珯鐐规暟鎹�={},鍐欏叆娆℃暟={}", slave.getId(), JSON.toJSON(staProtocol), writeCount); + } + }while (writeCount<5); if (!write.IsSuccess || !write1.IsSuccess) { staProtocol = station.get(staProtocol.getSiteId()); @@ -822,9 +878,27 @@ } ArrayList<Integer> staNos = getWriteStaNo(); int index = staNos.indexOf(staProtocol.getSiteId()); - 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()); // 鐩爣绔� + + OperateResult write = null; + OperateResult write1 = null; + OperateResult write2 = null; + //浠诲姟涓嬪彂娆℃暟 + int writeCount = 0; + do { + write = siemensS7Net.Write("DB100." + index*6, staProtocol.getWorkNo()); // 宸ヤ綔鍙� + Thread.sleep(100); + write1 = siemensS7Net.Write("DB100." + (index*6+4), staProtocol.getStaNo().shortValue()); // 鐩爣绔� + Thread.sleep(100); + write2 = siemensS7Net.Write("DB100." + (index*10+6), staProtocol.getMatnr()); // 鐩爣绔� + if(write.IsSuccess && write1.IsSuccess){ + log.error("鍐欏叆杈撻�佺嚎鍛戒护鎴愬姛銆傝緭閫佺嚎plc缂栧彿={}锛岀珯鐐规暟鎹�={},鍐欏叆娆℃暟={}", slave.getId(), JSON.toJSON(staProtocol), writeCount); + break; + } + else { + writeCount++; + log.error("鍐欏叆杈撻�佺嚎鍛戒护澶辫触銆傝緭閫佺嚎plc缂栧彿={}锛岀珯鐐规暟鎹�={},鍐欏叆娆℃暟={}", slave.getId(), JSON.toJSON(staProtocol), writeCount); + } + }while (writeCount<5); if (!write.IsSuccess || !write1.IsSuccess || !write2.IsSuccess) { staProtocol = station.get(staProtocol.getSiteId()); @@ -838,6 +912,16 @@ log.info("杈撻�佺嚎鍛戒护涓嬪彂 [id:{}] >>>>> 鍛戒护涓嬪彂锛� {}", slave.getId(), JSON.toJSON(staProtocol)); } } + + private void writeIsCalled() throws InterruptedException { + OperateResult write = siemensS7Net.Write("DB102.0" , (short) 0); // 宸ヤ綔鍙� + } + + private void writeIsFinish() throws InterruptedException { + OperateResult finish = siemensS7Net.Write("DB102.2" , (short)0); // 宸ヤ綔鍙� + OperateResult half = siemensS7Net.Write("DB102.6" , (short)0); // 宸ヤ綔鍙� + } + /** * 鍐欏叆 ID+鐩爣绔� =====> 鍗曠珯鐐瑰啓鍏� */ -- Gitblit v1.9.1