From 9d5ec7599f3abe0cebb76ce1df3c3b8c4e0aa51e Mon Sep 17 00:00:00 2001
From: hxp <ale99527@vip.qq.com>
Date: 星期二, 10 二月 2026 11:40:15 +0800
Subject: [PATCH] 66 【公会】基础主体-服务端(跨服聊天;)

---
 ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/ChPyNetSendPack.py |  204 +++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 175 insertions(+), 29 deletions(-)

diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/ChPyNetSendPack.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/ChPyNetSendPack.py
index 4de6d42..f3609e7 100644
--- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/ChPyNetSendPack.py
+++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/ChPyNetSendPack.py
@@ -2386,6 +2386,127 @@
 
 
 #------------------------------------------------------
+# A1 31 前端自定义保存的设置内容信息 #tagSCSettingDataInfo
+
+class  tagSCSettingData(Structure):
+    KeyNum = 0    #(BYTE KeyNum)// 自定义key编号,后端使用数字key存储,前端自行进行转换定义,限制100个
+    DataLen = 0    #(BYTE DataLen)
+    SetData = ""    #(String SetData)//自定义保存的内容
+    data = None
+
+    def __init__(self):
+        self.Clear()
+        return
+
+    def ReadData(self, _lpData, _pos=0, _Len=0):
+        self.Clear()
+        self.KeyNum,_pos = CommFunc.ReadBYTE(_lpData, _pos)
+        self.DataLen,_pos = CommFunc.ReadBYTE(_lpData, _pos)
+        self.SetData,_pos = CommFunc.ReadString(_lpData, _pos,self.DataLen)
+        return _pos
+
+    def Clear(self):
+        self.KeyNum = 0
+        self.DataLen = 0
+        self.SetData = ""
+        return
+
+    def GetLength(self):
+        length = 0
+        length += 1
+        length += 1
+        length += len(self.SetData)
+
+        return length
+
+    def GetBuffer(self):
+        data = ''
+        data = CommFunc.WriteBYTE(data, self.KeyNum)
+        data = CommFunc.WriteBYTE(data, self.DataLen)
+        data = CommFunc.WriteString(data, self.DataLen, self.SetData)
+        return data
+
+    def OutputString(self):
+        DumpString = '''
+                                KeyNum:%d,
+                                DataLen:%d,
+                                SetData:%s
+                                '''\
+                                %(
+                                self.KeyNum,
+                                self.DataLen,
+                                self.SetData
+                                )
+        return DumpString
+
+
+class  tagSCSettingDataInfo(Structure):
+    Head = tagHead()
+    DataCnt = 0    #(WORD DataCnt)
+    SettingDataList = list()    #(vector<tagSCSettingData> SettingDataList)
+    data = None
+
+    def __init__(self):
+        self.Clear()
+        self.Head.Cmd = 0xA1
+        self.Head.SubCmd = 0x31
+        return
+
+    def ReadData(self, _lpData, _pos=0, _Len=0):
+        self.Clear()
+        _pos = self.Head.ReadData(_lpData, _pos)
+        self.DataCnt,_pos = CommFunc.ReadWORD(_lpData, _pos)
+        for i in range(self.DataCnt):
+            temSettingDataList = tagSCSettingData()
+            _pos = temSettingDataList.ReadData(_lpData, _pos)
+            self.SettingDataList.append(temSettingDataList)
+        return _pos
+
+    def Clear(self):
+        self.Head = tagHead()
+        self.Head.Clear()
+        self.Head.Cmd = 0xA1
+        self.Head.SubCmd = 0x31
+        self.DataCnt = 0
+        self.SettingDataList = list()
+        return
+
+    def GetLength(self):
+        length = 0
+        length += self.Head.GetLength()
+        length += 2
+        for i in range(self.DataCnt):
+            length += self.SettingDataList[i].GetLength()
+
+        return length
+
+    def GetBuffer(self):
+        data = ''
+        data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer())
+        data = CommFunc.WriteWORD(data, self.DataCnt)
+        for i in range(self.DataCnt):
+            data = CommFunc.WriteString(data, self.SettingDataList[i].GetLength(), self.SettingDataList[i].GetBuffer())
+        return data
+
+    def OutputString(self):
+        DumpString = '''
+                                Head:%s,
+                                DataCnt:%d,
+                                SettingDataList:%s
+                                '''\
+                                %(
+                                self.Head.OutputString(),
+                                self.DataCnt,
+                                "..."
+                                )
+        return DumpString
+
+
+m_NAtagSCSettingDataInfo=tagSCSettingDataInfo()
+ChNetPackDict[eval("0x%02x%02x"%(m_NAtagSCSettingDataInfo.Head.Cmd,m_NAtagSCSettingDataInfo.Head.SubCmd))] = m_NAtagSCSettingDataInfo
+
+
+#------------------------------------------------------
 #A1 26 准备切换地图 #tagMCPrepareChangeMap
 
 class  tagMCPrepareChangeMap(Structure):
@@ -27476,7 +27597,7 @@
 
 class  tagSCTravelInfo(Structure):
     Head = tagHead()
-    Energy = 0    #(BYTE Energy)//剩余体力
+    Energy = 0    #(DWORD Energy)//剩余体力
     EnergyTime = 0    #(DWORD EnergyTime)//上次恢复体力时间戳
     TravelCnt = 0    #(DWORD TravelCnt)//累计游历次数
     SceneryType = 0    #(BYTE SceneryType)//景观类型
@@ -27497,7 +27618,7 @@
     def ReadData(self, _lpData, _pos=0, _Len=0):
         self.Clear()
         _pos = self.Head.ReadData(_lpData, _pos)
-        self.Energy,_pos = CommFunc.ReadBYTE(_lpData, _pos)
+        self.Energy,_pos = CommFunc.ReadDWORD(_lpData, _pos)
         self.EnergyTime,_pos = CommFunc.ReadDWORD(_lpData, _pos)
         self.TravelCnt,_pos = CommFunc.ReadDWORD(_lpData, _pos)
         self.SceneryType,_pos = CommFunc.ReadBYTE(_lpData, _pos)
@@ -27532,7 +27653,7 @@
     def GetLength(self):
         length = 0
         length += self.Head.GetLength()
-        length += 1
+        length += 4
         length += 4
         length += 4
         length += 1
@@ -27549,7 +27670,7 @@
     def GetBuffer(self):
         data = ''
         data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer())
-        data = CommFunc.WriteBYTE(data, self.Energy)
+        data = CommFunc.WriteDWORD(data, self.Energy)
         data = CommFunc.WriteDWORD(data, self.EnergyTime)
         data = CommFunc.WriteDWORD(data, self.TravelCnt)
         data = CommFunc.WriteBYTE(data, self.SceneryType)
@@ -45593,60 +45714,85 @@
 # C2 03 跨服中心事件同步 #tagSSCrossCenterEvent
 
 class  tagSSCrossCenterEvent(Structure):
-    _pack_ = 1
-    _fields_ = [
-                  ("Cmd", c_ubyte),
-                  ("SubCmd", c_ubyte),
-                  ("ServerID", c_int),    
-                  ("ServerType", c_ubyte),    #服务器类型
-                  ("EventValue", c_int),    #事件值,yyyyMMddhh用于判断过天等
-                  ]
+    Head = tagHead()
+    ServerID = 0    #(DWORD ServerID)
+    ServerType = 0    #(BYTE ServerType)//服务器类型
+    EventValue = 0    #(DWORD EventValue)//事件值,yyyyMMddhh用于判断过天等
+    GMLen = 0    #(BYTE GMLen)
+    GMEvent = ""    #(String GMEvent)
+    data = None
 
     def __init__(self):
         self.Clear()
-        self.Cmd = 0xC2
-        self.SubCmd = 0x03
+        self.Head.Cmd = 0xC2
+        self.Head.SubCmd = 0x03
         return
 
-    def ReadData(self, stringData, _pos=0, _len=0):
+    def ReadData(self, _lpData, _pos=0, _Len=0):
         self.Clear()
-        memmove(addressof(self), stringData[_pos:], self.GetLength())
-        return _pos + self.GetLength()
+        _pos = self.Head.ReadData(_lpData, _pos)
+        self.ServerID,_pos = CommFunc.ReadDWORD(_lpData, _pos)
+        self.ServerType,_pos = CommFunc.ReadBYTE(_lpData, _pos)
+        self.EventValue,_pos = CommFunc.ReadDWORD(_lpData, _pos)
+        self.GMLen,_pos = CommFunc.ReadBYTE(_lpData, _pos)
+        self.GMEvent,_pos = CommFunc.ReadString(_lpData, _pos,self.GMLen)
+        return _pos
 
     def Clear(self):
-        self.Cmd = 0xC2
-        self.SubCmd = 0x03
+        self.Head = tagHead()
+        self.Head.Clear()
+        self.Head.Cmd = 0xC2
+        self.Head.SubCmd = 0x03
         self.ServerID = 0
         self.ServerType = 0
         self.EventValue = 0
+        self.GMLen = 0
+        self.GMEvent = ""
         return
 
     def GetLength(self):
-        return sizeof(tagSSCrossCenterEvent)
+        length = 0
+        length += self.Head.GetLength()
+        length += 4
+        length += 1
+        length += 4
+        length += 1
+        length += len(self.GMEvent)
+
+        return length
 
     def GetBuffer(self):
-        return string_at(addressof(self), self.GetLength())
+        data = ''
+        data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer())
+        data = CommFunc.WriteDWORD(data, self.ServerID)
+        data = CommFunc.WriteBYTE(data, self.ServerType)
+        data = CommFunc.WriteDWORD(data, self.EventValue)
+        data = CommFunc.WriteBYTE(data, self.GMLen)
+        data = CommFunc.WriteString(data, self.GMLen, self.GMEvent)
+        return data
 
     def OutputString(self):
-        DumpString = '''// C2 03 跨服中心事件同步 //tagSSCrossCenterEvent:
-                                Cmd:%s,
-                                SubCmd:%s,
+        DumpString = '''
+                                Head:%s,
                                 ServerID:%d,
                                 ServerType:%d,
-                                EventValue:%d
+                                EventValue:%d,
+                                GMLen:%d,
+                                GMEvent:%s
                                 '''\
                                 %(
-                                self.Cmd,
-                                self.SubCmd,
+                                self.Head.OutputString(),
                                 self.ServerID,
                                 self.ServerType,
-                                self.EventValue
+                                self.EventValue,
+                                self.GMLen,
+                                self.GMEvent
                                 )
         return DumpString
 
 
 m_NAtagSSCrossCenterEvent=tagSSCrossCenterEvent()
-ChNetPackDict[eval("0x%02x%02x"%(m_NAtagSSCrossCenterEvent.Cmd,m_NAtagSSCrossCenterEvent.SubCmd))] = m_NAtagSSCrossCenterEvent
+ChNetPackDict[eval("0x%02x%02x"%(m_NAtagSSCrossCenterEvent.Head.Cmd,m_NAtagSSCrossCenterEvent.Head.SubCmd))] = m_NAtagSSCrossCenterEvent
 
 
 #------------------------------------------------------

--
Gitblit v1.8.0