From 7f85ca5468e097f1749ab1ed812046cb8eb979b7 Mon Sep 17 00:00:00 2001 From: liurunyu <lry9898@163.com> Date: 星期日, 27 四月 2025 17:58:48 +0800 Subject: [PATCH] 表阀一体机与测控一体阀协议中的阀门状态不兼容,做兼容处理。 --- pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/global/GlCreate.java | 43 ++++++++++++++++++++++++++++++------------- 1 files changed, 30 insertions(+), 13 deletions(-) diff --git a/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/global/GlCreate.java b/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/global/GlCreate.java index 1e026f1..49f7648 100644 --- a/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/global/GlCreate.java +++ b/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/global/GlCreate.java @@ -1,7 +1,5 @@ package com.dy.common.mw.protocol.p206V202404.parse.global; -import com.dy.common.mw.protocol.p206V1.ProtocolConstantV206V1; -import com.dy.common.mw.protocol.p206V2.ProtocolConstantV206V2; import com.dy.common.mw.protocol.p206V202404.CommonV202404; import com.dy.common.mw.protocol.p206V202404.ProtocolConstantV206V202404; import com.dy.common.util.*; @@ -34,6 +32,21 @@ ByteUtil.hex2Bytes(commandCode, bsHead, index) ; return bsHead ; + } + + + /** + * 0xf0闃�闂� 0x00姘存车 + * @param controllerTypeByHex + * @param bs + * @param index + */ + public static void createValveOrPump(String controllerTypeByHex, byte[] bs, int index){ + if(controllerTypeByHex != null && controllerTypeByHex.equals("57")){ + bs[index] = (byte)0x00 ; + }else{ + bs[index] = (byte)0xF0 ; + } } /** @@ -142,15 +155,16 @@ } public static void createLen(byte[] bsNoTail) throws Exception { - int len = bsNoTail.length - ProtocolConstantV206V1.lenHead2ctrl; - bsNoTail[ProtocolConstantV206V1.dataLenIndex] = (byte)len ; + int len = bsNoTail.length - ProtocolConstantV206V202404.lenHead2ctrl; + bsNoTail[ProtocolConstantV206V202404.dataLenIndex] = (byte)len ; } public static void createLen4PUg(byte[] bytes) throws Exception { int len = bytes.length - 4; - byte[] bs = ByteUtil.int2BCD_LE(len) ; + byte[] bs = ByteUtil.short2Bytes_LE((short)len) ; if(bs != null && bs.length == 1){ - bytes[1] = bs[0] ; + bytes[1] = 0 ; + bytes[2] = bs[0] ; }else if(bs != null && bs.length > 1){ bytes[1] = bs[1] ; bytes[2] = bs[0] ; @@ -158,18 +172,21 @@ } public static byte[] createCrcTail(byte[] bsNoTail) throws Exception { - int crc = new CRC8_for_2_0().CRC8(bsNoTail, ProtocolConstantV206V1.ctrlIndex, bsNoTail.length -1) ; - byte[] bytes = new byte[ProtocolConstantV206V1.lenTail] ; + int crc = new CRC8_for_2_0().CRC8(bsNoTail, ProtocolConstantV206V202404.ctrlIndex, bsNoTail.length -1) ; + byte[] bytes = new byte[ProtocolConstantV206V202404.lenTail] ; bytes[0] = (byte)crc ; - bytes[1] = ProtocolConstantV206V1.P_Tail_Byte ; + bytes[1] = ProtocolConstantV206V202404.P_Tail_Byte ; return bytes ; } public static byte[] createCrcTail4Ug(byte[] bsNoTail) throws Exception { - int crc = new CRC16().CRC(bsNoTail, 0, bsNoTail.length -1) ; - byte[] bytes = new byte[ProtocolConstantV206V2.UG_lenTail] ; - ByteUtilUnsigned.short2Bytes_BE(bytes, crc, 0); - bytes[2] = ProtocolConstantV206V2.P_Tail_Byte ; + int crc = new CRC16().CRC16_table(bsNoTail, 0, bsNoTail.length -1) ; + byte[] crcBs = new byte[4] ; + ByteUtil.int2Bytes_BE(crcBs, crc, 0); + byte[] bytes = new byte[ProtocolConstantV206V202404.UG_lenTail] ; + bytes[0] = crcBs[2] ; + bytes[1] = crcBs[3] ; + bytes[2] = ProtocolConstantV206V202404.P_Tail_Byte ; return bytes ; } -- Gitblit v1.8.0