From 1f19230e00b543b58f03853df1a38ebd8b508e55 Mon Sep 17 00:00:00 2001
From: zhubaomin <zhubaomin>
Date: 星期五, 21 二月 2025 16:55:01 +0800
Subject: [PATCH] 发布灌溉计划并生成开阀计划

---
 pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/tcpClient/upData/UpHeartBeat.java |   50 ++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 48 insertions(+), 2 deletions(-)

diff --git a/pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/tcpClient/upData/UpHeartBeat.java b/pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/tcpClient/upData/UpHeartBeat.java
index 8185fd2..6acfbcc 100644
--- a/pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/tcpClient/upData/UpHeartBeat.java
+++ b/pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/tcpClient/upData/UpHeartBeat.java
@@ -2,6 +2,8 @@
 
 import com.dy.common.mw.protocol.p206V1.parse.global.GlCreate;
 import com.dy.common.util.ByteUtil;
+import com.dy.common.util.DateTime;
+import com.dy.simRtu.ServerProperties;
 import org.apache.logging.log4j.LogManager;
 import org.apache.logging.log4j.Logger;
 
@@ -22,7 +24,12 @@
         if(upHeartBeat){
             try{
                 if(UpData.session != null && UpData.session.isConnected()){
-                    byte[] bs = createData(rtuAddr) ;
+                    byte[] bs ;
+                    if(ServerProperties.argHeardBeatBy02True81False){
+                        bs = createCd02Data(rtuAddr) ;
+                    }else{
+                        bs = createCd81Data(rtuAddr) ;
+                    }
                     UpData.upSend(bs) ;
                 }else{
                     log.error("鏈繛鎺ラ�氫俊涓棿浠讹紝涓嶈兘鍙戦�佹暟鎹�");
@@ -39,7 +46,7 @@
      * @return 瀛楄妭鏁扮粍
      * @throws Exception 寮傚父
      */
-    private static byte[] createData(String rtuAddr) throws Exception {
+    private static byte[] createCd02Data(String rtuAddr) throws Exception {
         byte[] bytes = creatHead(rtuAddr, "02", (byte)0xB0);
 
         byte[] bs = new byte[1] ;
@@ -60,4 +67,43 @@
 
         return bytes ;
     }
+
+
+
+    /**
+     * 鏋勯�犲績璺虫暟鎹�
+     * @return 瀛楄妭鏁扮粍
+     * @throws Exception 寮傚父
+     */
+    private static byte[] createCd81Data(String rtuAddr) throws Exception {
+        byte[] bytes = creatHead(rtuAddr, "81", (byte)0xB0);
+
+        int index = 0 ;
+        byte[] bs1 = new byte[4] ;
+        bs1[index++] = (byte)0x22 ;
+        bs1[index++] = (byte)0x6 ;
+        bs1[index++] = (byte)0x44 ;
+        bs1[index++] = (byte)0x00 ;
+        bytes = ByteUtil.bytesMerge(bytes, bs1) ;
+
+        int[] ymdhms = DateTime.yyyy_MM_dd_HH_MM_SS_2_ymdhmsGroup(DateTime.yyyy_MM_dd_HH_mm_ss()) ;
+        byte[] bs2 = new byte[6] ;
+        index = 0 ;
+        int index1 = 5 ;
+        bs2[index++] = ByteUtil.int2BCD_BE(ymdhms[index1--])[0] ;
+        bs2[index++] = ByteUtil.int2BCD_BE(ymdhms[index1--])[0] ;
+        bs2[index++] = ByteUtil.int2BCD_BE(ymdhms[index1--])[0] ;
+        bs2[index++] = ByteUtil.int2BCD_BE(ymdhms[index1--])[0] ;
+        bs2[index++] = ByteUtil.int2BCD_BE(ymdhms[index1--])[0] ;
+        bs2[index++] = ByteUtil.int2BCD_BE(ymdhms[index1--] - 2000)[0] ;
+        bytes = ByteUtil.bytesMerge(bytes, bs2) ;
+
+        GlCreate.createLen(bytes);//闀垮害鏀惧瓧鑺傛暟缁勪腑
+
+        byte[] bsTail = GlCreate.createCrcTail4P206(bytes) ;//CRC鍜屽熬鍙犲姞瀛楄妭鏁扮粍涓�
+
+        bytes = ByteUtil.bytesMerge(bytes, bsTail) ;
+
+        return bytes ;
+    }
 }

--
Gitblit v1.8.0