Junjie
2023-12-14 c516156f45ce4cea49a13bd62839346547d5a991
src/main/java/com/zy/core/thread/SiemensDevpThread.java
@@ -58,6 +58,38 @@
        add(309);add(312);
    }};
    public static final ArrayList<Integer> staNos2 = new ArrayList<Integer>() {{
        add(302);add(304);
        add(305);add(306);
        add(307);add(308);
        add(310);add(311);
        add(312);add(313);
        add(314);add(315);
        add(316);add(318);
        add(319);add(320);
        add(321);add(322);
        add(323);add(324);
        add(326);add(327);
        add(328);add(329);
        add(330);add(332);
        add(334);add(335);
        add(336);add(337);
        add(338);add(342);
        add(343);add(344);
    }};
    public static final ArrayList<Integer> staNos3 = new ArrayList<Integer>() {{//218
        add(302);add(304);
        add(315);add(322);
        add(324);add(330);
        add(332);add(337);
    }};
    public static final ArrayList<Integer> staNos4 = new ArrayList<Integer>() {{//250
        add(318);add(320);
        add(343);
    }};
    //高低信号站点
    public static final ArrayList<Integer> locType1StaNos = new ArrayList<Integer>() {{
        add(100);add(103);
@@ -250,6 +282,71 @@
            }
        }
        Thread.sleep(100);
        for (Integer staNo : staNos2) {
            OperateResultExOne<byte[]> result5 = siemensS7Net.Read("DB" + staNo + ".0", (short) 48);
            if (result5.IsSuccess) {
                StaProtocol staProtocol = station.get(staNo);
                StaProtocol staProtocol300 = station.get(300);
                if (null == staProtocol) {
                    staProtocol = new StaProtocol();
                    staProtocol.setSiteId(staNo);
                    station.put(staNo, staProtocol);
                }
                boolean[] status1 = siemensS7Net.getByteTransform().TransBool(result5.Content, 1, 1);
                staProtocol.setAutoing(staProtocol300.isAutoing());  // 自动
                staProtocol.setLoading(!status1[2]);  // 有物
                if (staNos3.contains(staNo) || staNos4.contains(staNo)) {
                    continue;
                }
                if (staNo == 344) {
                    staProtocol.setWorkNo(siemensS7Net.getByteTransform().TransInt16(result5.Content, 34));     // 工作号
                }else {
                    staProtocol.setWorkNo(siemensS7Net.getByteTransform().TransInt16(result5.Content, 22));     // 工作号
                }
            }
        }
        Thread.sleep(100);
        for (Integer staNo : staNos3) {
            OperateResultExOne<byte[]> result5 = siemensS7Net.Read("DB" + staNo + ".22.0", (short) 2);
            OperateResultExOne<byte[]> result6 = siemensS7Net.Read("DB" + staNo + ".218.0", (short) 2);
            if (result5.IsSuccess && result6.IsSuccess) {
                StaProtocol staProtocol = station.get(staNo);
                short wrkNo1 = siemensS7Net.getByteTransform().TransInt16(result5.Content, 0);
                short wrkNo2 = siemensS7Net.getByteTransform().TransInt16(result6.Content, 0);
                short wrkNo = 0;
                if (wrkNo1 != 0) {
                    wrkNo = wrkNo1;
                }
                if (wrkNo2 != 0) {
                    wrkNo = wrkNo2;
                }
                staProtocol.setWorkNo(wrkNo);     // 工作号
            }
        }
        Thread.sleep(100);
        for (Integer staNo : staNos4) {
            OperateResultExOne<byte[]> result5 = siemensS7Net.Read("DB" + staNo + ".22.0", (short) 2);
            OperateResultExOne<byte[]> result6 = siemensS7Net.Read("DB" + staNo + ".250.0", (short) 2);
            if (result5.IsSuccess && result6.IsSuccess) {
                StaProtocol staProtocol = station.get(staNo);
                short wrkNo1 = siemensS7Net.getByteTransform().TransInt16(result5.Content, 0);
                short wrkNo2 = siemensS7Net.getByteTransform().TransInt16(result6.Content, 0);
                short wrkNo = 0;
                if (wrkNo1 != 0) {
                    wrkNo = wrkNo1;
                }
                if (wrkNo2 != 0) {
                    wrkNo = wrkNo2;
                }
                staProtocol.setWorkNo(wrkNo);     // 工作号
            }
        }
        if (result.IsSuccess && result1.IsSuccess) {
            OutputQueue.DEVP.offer(MessageFormat.format("【{0}】[id:{1}] <<<<< 实时数据更新成功",DateUtils.convert(new Date()), slave.getId()));
@@ -338,8 +435,8 @@
            OutputQueue.DEVP.offer(MessageFormat.format("【{0}】写入输送线命令尝试5次失败。输送线plc编号={1},站点数据={2}", slave.getId(), JSON.toJSON(staProtocol)));
            log.error("写入输送线命令尝试5次失败。输送线plc编号={},站点数据={}", slave.getId(), JSON.toJSON(staProtocol));
            //重新添加数据到任务队列
            boolean result = MessageQueue.offer(SlaveType.Devp, slave.getId(), new Task(2, staProtocol));
//            //重新添加数据到任务队列
//            boolean result = MessageQueue.offer(SlaveType.Devp, slave.getId(), new Task(2, staProtocol));
            read();//读取1次设备状态
            return;
        } else {