From c4d56f4a2c7687739f3bf0f43bcc1f35c9bbeb8b Mon Sep 17 00:00:00 2001
From: liurunyu <lry9898@163.com>
Date: 星期三, 14 五月 2025 15:18:44 +0800
Subject: [PATCH] 1、表阀一体协议解析同步新版本;2、默认设备是表阀一体(0x02)

---
 pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/global/GlCreate.java |   90 +++++++++++++++++++++++++++++++-------------
 1 files changed, 63 insertions(+), 27 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 d2ac976..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,12 +1,8 @@
 package com.dy.common.mw.protocol.p206V202404.parse.global;
 
-import com.dy.common.mw.protocol.p206V1_0_0.ProtocolConstantV206V1_0_0;
 import com.dy.common.mw.protocol.p206V202404.CommonV202404;
 import com.dy.common.mw.protocol.p206V202404.ProtocolConstantV206V202404;
-import com.dy.common.util.ByteUtil;
-import com.dy.common.util.ByteUtilUnsigned;
-import com.dy.common.util.CRC8_for_2_0;
-import com.dy.common.util.DateTime;
+import com.dy.common.util.*;
 
 public class GlCreate {
     /**
@@ -38,6 +34,21 @@
         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 ;
+        }
+    }
+
     /**
      * 鐢熸垚鎺у埗鍣ㄥ湴鍧�
      * 6瀛楄妭BCD鐮侊紙12浣嶈鏀垮尯鍒掞級 + 2瀛楄妭HEX
@@ -55,6 +66,16 @@
 
         Integer rtuAddr2Int = Integer.parseInt(rtuAddr2) ;
         ByteUtilUnsigned.short2Bytes_LE(bs, rtuAddr2Int.shortValue(), index);
+    }
+    /**
+     * 涓哄崌绾у崗璁�
+     * @param rtuAddr
+     * @param bs
+     * @param index
+     * @throws Exception
+     */
+    public static void createRtuAddr4PUg(String rtuAddr, byte[] bs, int index) throws Exception {
+        ByteUtil.string2BCD_BE(bs, rtuAddr, index) ;
     }
 
     /**
@@ -114,18 +135,16 @@
         ByteUtil.string2BCD_BE(bs, DateTime.mm(), index + 1) ;
         ByteUtil.string2BCD_BE(bs, DateTime.HH(), index + 2) ;
         ByteUtil.string2BCD_BE(bs, DateTime.dd(), index + 3) ;
-        //浠ヤ笅鍐欐硶鑷劧涔熸槸BCD
-        bs[index + 4] = (byte)((DateTime.week_Int().byteValue() << 5 | Byte.parseByte(DateTime.MM()))) ;
-        ByteUtil.string2BCD_BE(bs, DateTime.yy(), index + 5) ;
 
-        /*
-        bs[index] = Byte.parseByte(DateTime.ss()) ;
-        bs[index + 1] = Byte.parseByte(DateTime.mm()) ;
-        bs[index + 2] = Byte.parseByte(DateTime.HH()) ;
-        bs[index + 3] = Byte.parseByte(DateTime.dd()) ;
-        bs[index + 4] = (byte)(DateTime.week_Int().byteValue() << 5 | Byte.parseByte(DateTime.MM())) ;
-        bs[index + 5] = Byte.parseByte(DateTime.yy()) ;
-        */
+        byte week = DateTime.week_Int().byteValue() ;
+        byte month = Byte.parseByte(DateTime.MM()) ;
+        if(month < 10){
+            bs[index + 4] = (byte)((week << 5) | month) ;
+        }else{
+            bs[index + 4] = (byte)((week << 5) | 0x10 | (month - 10)) ;
+        }
+
+        ByteUtil.string2BCD_BE(bs, DateTime.yy(), index + 5) ;
     }
 
     public static void createS2D(byte[] bs, int index) throws Exception {
@@ -133,24 +152,41 @@
         ByteUtil.string2BCD_BE(bs, DateTime.mm(), index + 1) ;
         ByteUtil.string2BCD_BE(bs, DateTime.HH(), index + 2) ;
         ByteUtil.string2BCD_BE(bs, DateTime.dd(), index + 3) ;
-        /*
-        bs[index] = Byte.parseByte(DateTime.ss()) ;
-        bs[index + 1] = Byte.parseByte(DateTime.mm()) ;
-        bs[index + 2] = Byte.parseByte(DateTime.HH()) ;
-        bs[index + 3] = Byte.parseByte(DateTime.dd()) ;
-        */
     }
 
     public static void createLen(byte[] bsNoTail) throws Exception {
-        int len = bsNoTail.length - ProtocolConstantV206V1_0_0.lenHead2ctrl;
-        bsNoTail[ProtocolConstantV206V1_0_0.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.short2Bytes_LE((short)len) ;
+        if(bs != null && bs.length == 1){
+            bytes[1] = 0 ;
+            bytes[2] = bs[0] ;
+        }else if(bs != null && bs.length > 1){
+            bytes[1] = bs[1] ;
+            bytes[2] = bs[0] ;
+        }
     }
 
     public static byte[] createCrcTail(byte[] bsNoTail) throws Exception {
-        int crc = new CRC8_for_2_0().CRC8(bsNoTail, ProtocolConstantV206V1_0_0.ctrlIndex, bsNoTail.length -1) ;
-        byte[] bytes = new byte[ProtocolConstantV206V1_0_0.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_0_0.P_Tail_Byte ;
+        bytes[1] = ProtocolConstantV206V202404.P_Tail_Byte ;
+        return bytes ;
+    }
+
+    public static byte[] createCrcTail4Ug(byte[] bsNoTail) throws Exception {
+        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