From 001f24d4efd7b818bc2224b976c82faf4f9e564c Mon Sep 17 00:00:00 2001
From: liurunyu <lry9898@163.com>
Date: 星期五, 01 十一月 2024 11:25:00 +0800
Subject: [PATCH] 1、通信协议要增加版本号(目的为远程升级准备),原来没有版本号的协议默认为版本号为1,所以调整了程序命名; 2、流浪控制器与控制器数据库表都增加了协议版本号字段; 3、VO中Double和Float类型的属性增加注解@JsonFormat(shape = JsonFormat.Shape.NUMBER_FLOAT, pattern="0.00" )

---
 pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/global/GlCreate.java |   61 +++++++++++++++++++-----------
 1 files changed, 38 insertions(+), 23 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 f428bde..e473475 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,6 +1,6 @@
 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.p206V1.ProtocolConstantV206V1;
 import com.dy.common.mw.protocol.p206V202404.CommonV202404;
 import com.dy.common.mw.protocol.p206V202404.ProtocolConstantV206V202404;
 import com.dy.common.util.ByteUtil;
@@ -32,7 +32,7 @@
 
         index++ ;
         GlCreate.createRtuAddr(rtuAddr, bsHead, index);
-        index += 7 ;
+        index += 8 ;
 
         ByteUtil.hex2Bytes(commandCode, bsHead, index) ;
         return bsHead ;
@@ -95,12 +95,12 @@
     }
 
     public static void createDt(byte[] bs, int index) throws Exception {
-        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.parseByte(DateTime.MM()) ;
-        bs[index + 5] = Byte.parseByte(DateTime.yy()) ;
+        ByteUtil.string2BCD_BE(bs, DateTime.ss(), index) ; ;
+        ByteUtil.string2BCD_BE(bs, DateTime.mm(), index + 1) ;
+        ByteUtil.string2BCD_BE(bs, DateTime.HH(), index + 2) ;
+        ByteUtil.string2BCD_BE(bs, DateTime.dd(), index + 3) ;
+        ByteUtil.string2BCD_BE(bs, DateTime.MM(), index + 4) ;
+        ByteUtil.string2BCD_BE(bs, DateTime.yy(), index + 5) ;
     }
 
 
@@ -110,31 +110,46 @@
     }
 
     public static void createTp(byte[] bs, int index) throws Exception {
-        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()) ;
+        ByteUtil.string2BCD_BE(bs, DateTime.ss(), index) ; ;
+        ByteUtil.string2BCD_BE(bs, DateTime.mm(), index + 1) ;
+        ByteUtil.string2BCD_BE(bs, DateTime.HH(), index + 2) ;
+        ByteUtil.string2BCD_BE(bs, DateTime.dd(), index + 3) ;
+
+        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 {
-        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()) ;
+        ByteUtil.string2BCD_BE(bs, DateTime.ss(), index) ; ;
+        ByteUtil.string2BCD_BE(bs, DateTime.mm(), index + 1) ;
+        ByteUtil.string2BCD_BE(bs, DateTime.HH(), index + 2) ;
+        ByteUtil.string2BCD_BE(bs, DateTime.dd(), index + 3) ;
     }
 
     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 - ProtocolConstantV206V1.lenHead2ctrl;
+        bsNoTail[ProtocolConstantV206V1.dataLenIndex] = (byte)len ;
     }
 
     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, ProtocolConstantV206V1.ctrlIndex, bsNoTail.length -1) ;
+        byte[] bytes = new byte[ProtocolConstantV206V1.lenTail] ;
         bytes[0] = (byte)crc ;
-        bytes[1] = ProtocolConstantV206V1_0_0.P_Tail_Byte ;
+        bytes[1] = ProtocolConstantV206V1.P_Tail_Byte ;
         return bytes ;
     }
+
+    public static void main(String[] args)throws Exception{
+        byte[] bs = new byte[6] ;
+        createTp(bs, 0) ;
+        String hex = ByteUtil.bytes2Hex(bs,true, 0, 6) ;
+        System.out.println(hex);
+    }
 }

--
Gitblit v1.8.0