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