From 00fd3eb5037f07763d4e8d3e5729066d3dc097ea Mon Sep 17 00:00:00 2001
From: whycq <913841844@qq.com>
Date: 星期三, 08 一月 2025 14:47:43 +0800
Subject: [PATCH] #

---
 app/src/main/java/com/example/agvcontroller/protocol/ProtocolEncoder.java |   63 ++++++++++++++++++++++---------
 1 files changed, 45 insertions(+), 18 deletions(-)

diff --git a/app/src/main/java/com/example/agvcontroller/protocol/ProtocolEncoder.java b/app/src/main/java/com/example/agvcontroller/protocol/ProtocolEncoder.java
index 04a396a..9cb2cd5 100644
--- a/app/src/main/java/com/example/agvcontroller/protocol/ProtocolEncoder.java
+++ b/app/src/main/java/com/example/agvcontroller/protocol/ProtocolEncoder.java
@@ -1,20 +1,14 @@
-package com.zy.acs.gateway.handler.coder;
+package com.example.agvcontroller.protocol;
 
-import com.core.common.RadixTools;
-import com.zy.acs.common.utils.Utils;
-import com.zy.acs.gateway.config.SystemProperties;
-import com.zy.acs.gateway.constant.PackagePart;
-import com.zy.acs.gateway.domain.AgvPackage;
-import com.zy.acs.gateway.utils.ValidUtil;
+import com.example.agvcontroller.socket.RadixTools;
+
+import java.util.logging.Logger;
+
 import io.netty.buffer.ByteBuf;
 import io.netty.buffer.ByteBufUtil;
 import io.netty.channel.ChannelHandler;
 import io.netty.channel.ChannelHandlerContext;
 import io.netty.handler.codec.MessageToByteEncoder;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.stereotype.Component;
 
 /**
  * 缂栫爜鍣�
@@ -22,13 +16,13 @@
  * 澶勭悊鏂瑰紡: 寮傛垨鍜�
  * Created by vincent on 2019-04-02
  */
-@Component
+//@Component
 @ChannelHandler.Sharable
 public class ProtocolEncoder extends MessageToByteEncoder<Object> {
 
-    private static final Logger log = LoggerFactory.getLogger(ProtocolEncoder.class);
+    //private static final Logger log = LoggerFactory.getLogger(ProtocolEncoder.class);
 
-    @Autowired
+    //@Autowired
     private SystemProperties systemProperties;
 
     @Override
@@ -40,6 +34,39 @@
         } else if (obj instanceof byte[]){
             out.writeBytes((byte[]) obj);
 
+
+        } else if (obj instanceof AgvAction<?>){
+
+
+            AgvAction action = (AgvAction)obj;
+
+            String uniqueNo = action.getAgvNo();
+
+            byte[] uniqueNoBytes = RadixTools.intToBytes(Integer.parseInt(uniqueNo));   // uniqueno
+
+            byte[] bodyBytes = action.writeToBytes();
+
+
+            int len = PackagePart.UNIQUENO.getLen()     // len
+                    + PackagePart.TIMESTAMP.getLen()
+                    + PackagePart.COMMAND_MARK.getLen()
+                    + bodyBytes.length;
+
+            out.writeByte((byte)0xEE)         // symbol
+                    .writeShortLE(len)
+                    .writeBytes(Utils.reverse(uniqueNoBytes))       // uniqueno
+                    .writeIntLE((int) (System.currentTimeMillis() / 1000))   // timestamp
+                    .writeByte(ProtocolPojoType.ACTION_COMMAND.protocolType.getCode()) // type
+                    .writeBytes(bodyBytes)                          // body
+                    .writeShort((short)0)                 // valid
+            ;
+
+            int validCode = ValidUtil.calculateValidByteFromBuff(out);
+            out.resetReaderIndex();
+
+            out.writerIndex(out.readableBytes() - 2);
+            out.writeShortLE(validCode);
+
         } else if (obj instanceof AgvPackage){
 
             AgvPackage pac = (AgvPackage)obj;
@@ -48,9 +75,9 @@
 
             byte[] bodyBytes = pac.getBody().getMessageBody().writeToBytes();   // body
 
-            String uniqueNo = pac.getHeader().getUniqueNo();
+            //String uniqueNo = pac.getHeader().getUniqueNo();
 
-                byte[] uniquenoBytes = RadixTools.intToBytes(Integer.parseInt(pac.getHeader().getUniqueNo()));   // uniqueno
+            //byte[] uniquenoBytes = RadixTools.intToBytes(Integer.parseInt(pac.getHeader().getUniqueNo()));   // uniqueno
 
 
             int len = PackagePart.UNIQUENO.getLen()     // len
@@ -60,7 +87,7 @@
 
             out.writeByte(pac.getHeader().getStartSymbol())         // symbol
                     .writeShortLE(len)
-                    .writeBytes(Utils.reverse(uniquenoBytes))       // uniqueno
+                    //.writeBytes(Utils.reverse(uniquenoBytes))       // uniqueno
                     .writeIntLE((int) (System.currentTimeMillis() / 1000))   // timestamp
                     .writeByte(pac.getHeader().getProtocolType().getCode()) // type
                     .writeBytes(bodyBytes)                          // body
@@ -75,7 +102,7 @@
 
 
             if (systemProperties.isPrintPacLog()){
-                log.info("Agv [{}] 涓嬭 [{}] >>> {}", uniqueNo, pac.getHeader().getProtocolType().getDes(), ByteBufUtil.hexDump(out).toUpperCase());
+                //log.info("Agv [{}] 涓嬭 [{}] >>> {}", uniqueNo, pac.getHeader().getProtocolType().getDes(), ByteBufUtil.hexDump(out).toUpperCase());
             }
 
         }

--
Gitblit v1.9.1