From f8c4038119f81caeb58f9d28ca73478bb6c9a0fe Mon Sep 17 00:00:00 2001 From: hxp <ale99527@vip.qq.com> Date: 星期三, 26 九月 2018 21:19:22 +0800 Subject: [PATCH] 3878 【后端】神兽装备评分参数(增加真实伤害、真实抵抗参数) --- ServerPython/CoreServerGroup/GameServer/Script/ChPyNetPack.py | 110 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 110 insertions(+), 0 deletions(-) diff --git a/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetPack.py b/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetPack.py index a919a41..8213deb 100644 --- a/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetPack.py +++ b/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetPack.py @@ -8270,6 +8270,7 @@ EquipIndex = 0 #(BYTE EquipIndex)//神兽装备背包中索引 IndexCount = 0 #(BYTE IndexCount)//材料所在神兽物品背包索引的数量 IndexList = list() #(vector<BYTE> IndexList)//材料所在神兽物品背包索引列表 + IndexUseCountList = list() #(vector<DWORD> IndexUseCountList)//材料所在神兽物品背包索引对应使用个数列表 IsDouble = 0 #(BYTE IsDouble)//是否双倍强化 data = None @@ -8287,6 +8288,9 @@ for i in range(self.IndexCount): value,_pos=CommFunc.ReadBYTE(_lpData,_pos) self.IndexList.append(value) + for i in range(self.IndexCount): + value,_pos=CommFunc.ReadDWORD(_lpData,_pos) + self.IndexUseCountList.append(value) self.IsDouble,_pos = CommFunc.ReadBYTE(_lpData, _pos) return _pos @@ -8298,6 +8302,7 @@ self.EquipIndex = 0 self.IndexCount = 0 self.IndexList = list() + self.IndexUseCountList = list() self.IsDouble = 0 return @@ -8307,6 +8312,7 @@ length += 1 length += 1 length += 1 * self.IndexCount + length += 4 * self.IndexCount length += 1 return length @@ -8318,6 +8324,8 @@ data = CommFunc.WriteBYTE(data, self.IndexCount) for i in range(self.IndexCount): data = CommFunc.WriteBYTE(data, self.IndexList[i]) + for i in range(self.IndexCount): + data = CommFunc.WriteDWORD(data, self.IndexUseCountList[i]) data = CommFunc.WriteBYTE(data, self.IsDouble) return data @@ -8327,12 +8335,14 @@ EquipIndex:%d, IndexCount:%d, IndexList:%s, + IndexUseCountList:%s, IsDouble:%d '''\ %( self.Head.OutputString(), self.EquipIndex, self.IndexCount, + "...", "...", self.IsDouble ) @@ -9394,6 +9404,54 @@ #------------------------------------------------------ +# A5 14 祈福丹药 #tagCMPrayElixir + +class tagCMPrayElixir(Structure): + _pack_ = 1 + _fields_ = [ + ("Cmd", c_ubyte), + ("SubCmd", c_ubyte), + ] + + def __init__(self): + self.Clear() + self.Cmd = 0xA5 + self.SubCmd = 0x14 + return + + def ReadData(self, stringData, _pos=0, _len=0): + self.Clear() + memmove(addressof(self), stringData[_pos:], self.GetLength()) + return _pos + self.GetLength() + + def Clear(self): + self.Cmd = 0xA5 + self.SubCmd = 0x14 + return + + def GetLength(self): + return sizeof(tagCMPrayElixir) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// A5 14 祈福丹药 //tagCMPrayElixir: + Cmd:%s, + SubCmd:%s + '''\ + %( + self.Cmd, + self.SubCmd + ) + return DumpString + + +m_NAtagCMPrayElixir=tagCMPrayElixir() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMPrayElixir.Cmd,m_NAtagCMPrayElixir.SubCmd))] = m_NAtagCMPrayElixir + + +#------------------------------------------------------ #A5 34 查询天梯竞技场状态#tagCMQueryHighLadderState class tagCMQueryHighLadderState(Structure): @@ -10299,6 +10357,58 @@ #------------------------------------------------------ +# A5 13 解锁符印孔 #tagCMUnlockRuneHole + +class tagCMUnlockRuneHole(Structure): + _pack_ = 1 + _fields_ = [ + ("Cmd", c_ubyte), + ("SubCmd", c_ubyte), + ("HoleIndex", c_ubyte), # 孔索引 + ] + + def __init__(self): + self.Clear() + self.Cmd = 0xA5 + self.SubCmd = 0x13 + return + + def ReadData(self, stringData, _pos=0, _len=0): + self.Clear() + memmove(addressof(self), stringData[_pos:], self.GetLength()) + return _pos + self.GetLength() + + def Clear(self): + self.Cmd = 0xA5 + self.SubCmd = 0x13 + self.HoleIndex = 0 + return + + def GetLength(self): + return sizeof(tagCMUnlockRuneHole) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// A5 13 解锁符印孔 //tagCMUnlockRuneHole: + Cmd:%s, + SubCmd:%s, + HoleIndex:%d + '''\ + %( + self.Cmd, + self.SubCmd, + self.HoleIndex + ) + return DumpString + + +m_NAtagCMUnlockRuneHole=tagCMUnlockRuneHole() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMUnlockRuneHole.Cmd,m_NAtagCMUnlockRuneHole.SubCmd))] = m_NAtagCMUnlockRuneHole + + +#------------------------------------------------------ #A5 10 使用新手卡 #tagUseNewGuyCard class tagUseNewGuyCard(Structure): -- Gitblit v1.8.0