From 6366979426fccd97c0cb0bd384ada3a8b9843a24 Mon Sep 17 00:00:00 2001 From: xdh <xiefantasy@qq.com> Date: 星期四, 25 十月 2018 14:37:22 +0800 Subject: [PATCH] 2198 【主干】仙盟盟主5天没上线,盟主没有主动传位 --- ServerPython/CoreServerGroup/GameServer/Script/ChPyNetPack.py | 1135 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 1,135 insertions(+), 0 deletions(-) diff --git a/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetPack.py b/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetPack.py index a5d719d..bd72882 100644 --- a/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetPack.py +++ b/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetPack.py @@ -808,6 +808,91 @@ #------------------------------------------------------ +# A4 12 搜索家族 #tagCGPySearchFamily + +class tagCGPySearchFamily(Structure): + Head = tagHead() + MsgLen = 0 #(BYTE MsgLen)//模糊搜索家族,如果输入为空,则为不限制该条件 + Msg = "" #(String Msg)//size = MsgLen + LV = 0 #(BYTE LV)//最低家族等级,如果为0,则不限制该条件 + MaxCount = 0 #(BYTE MaxCount)//搜索结果所需最大条数,后端限制最多返回20条 + IsSearching = 0 #(BYTE IsSearching)//默认1,如果有指定其他值,则返回指定值 + data = None + + def __init__(self): + self.Clear() + self.Head.Cmd = 0xA4 + self.Head.SubCmd = 0x12 + return + + def ReadData(self, _lpData, _pos=0, _Len=0): + self.Clear() + _pos = self.Head.ReadData(_lpData, _pos) + self.MsgLen,_pos = CommFunc.ReadBYTE(_lpData, _pos) + self.Msg,_pos = CommFunc.ReadString(_lpData, _pos,self.MsgLen) + self.LV,_pos = CommFunc.ReadBYTE(_lpData, _pos) + self.MaxCount,_pos = CommFunc.ReadBYTE(_lpData, _pos) + self.IsSearching,_pos = CommFunc.ReadBYTE(_lpData, _pos) + return _pos + + def Clear(self): + self.Head = tagHead() + self.Head.Clear() + self.Head.Cmd = 0xA4 + self.Head.SubCmd = 0x12 + self.MsgLen = 0 + self.Msg = "" + self.LV = 0 + self.MaxCount = 0 + self.IsSearching = 0 + return + + def GetLength(self): + length = 0 + length += self.Head.GetLength() + length += 1 + length += len(self.Msg) + length += 1 + length += 1 + length += 1 + + return length + + def GetBuffer(self): + data = '' + data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) + data = CommFunc.WriteBYTE(data, self.MsgLen) + data = CommFunc.WriteString(data, self.MsgLen, self.Msg) + data = CommFunc.WriteBYTE(data, self.LV) + data = CommFunc.WriteBYTE(data, self.MaxCount) + data = CommFunc.WriteBYTE(data, self.IsSearching) + return data + + def OutputString(self): + DumpString = ''' + Head:%s, + MsgLen:%d, + Msg:%s, + LV:%d, + MaxCount:%d, + IsSearching:%d + '''\ + %( + self.Head.OutputString(), + self.MsgLen, + self.Msg, + self.LV, + self.MaxCount, + self.IsSearching + ) + return DumpString + + +m_NAtagCGPySearchFamily=tagCGPySearchFamily() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCGPySearchFamily.Head.Cmd,m_NAtagCGPySearchFamily.Head.SubCmd))] = m_NAtagCGPySearchFamily + + +#------------------------------------------------------ #A4 01 查看家族第N页#tagCGViewFamilyPage class tagCGViewFamilyPage(Structure): @@ -1359,6 +1444,58 @@ #------------------------------------------------------ +# AC 05 召集仙盟成员打boss #tagCGCallupFamilyMemberToBoss + +class tagCGCallupFamilyMemberToBoss(Structure): + _pack_ = 1 + _fields_ = [ + ("Cmd", c_ubyte), + ("SubCmd", c_ubyte), + ("NPCID", c_int), + ] + + def __init__(self): + self.Clear() + self.Cmd = 0xAC + self.SubCmd = 0x05 + 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 = 0xAC + self.SubCmd = 0x05 + self.NPCID = 0 + return + + def GetLength(self): + return sizeof(tagCGCallupFamilyMemberToBoss) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// AC 05 召集仙盟成员打boss //tagCGCallupFamilyMemberToBoss: + Cmd:%s, + SubCmd:%s, + NPCID:%d + '''\ + %( + self.Cmd, + self.SubCmd, + self.NPCID + ) + return DumpString + + +m_NAtagCGCallupFamilyMemberToBoss=tagCGCallupFamilyMemberToBoss() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCGCallupFamilyMemberToBoss.Cmd,m_NAtagCGCallupFamilyMemberToBoss.SubCmd))] = m_NAtagCGCallupFamilyMemberToBoss + + +#------------------------------------------------------ # AC 02 仙魔之争战斗结束 #tagCGXMZZOver class tagCGXMZZOver(Structure): @@ -1482,6 +1619,54 @@ m_NAtagCGJoinXMZZ=tagCGJoinXMZZ() ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCGJoinXMZZ.Cmd,m_NAtagCGJoinXMZZ.SubCmd))] = m_NAtagCGJoinXMZZ + + +#------------------------------------------------------ +# AC 04 查询仙盟抢Boss所有Boss当前进度 #tagCGQueryAllFamilyBossHurt + +class tagCGQueryAllFamilyBossHurt(Structure): + _pack_ = 1 + _fields_ = [ + ("Cmd", c_ubyte), + ("SubCmd", c_ubyte), + ] + + def __init__(self): + self.Clear() + self.Cmd = 0xAC + self.SubCmd = 0x04 + 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 = 0xAC + self.SubCmd = 0x04 + return + + def GetLength(self): + return sizeof(tagCGQueryAllFamilyBossHurt) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// AC 04 查询仙盟抢Boss所有Boss当前进度 //tagCGQueryAllFamilyBossHurt: + Cmd:%s, + SubCmd:%s + '''\ + %( + self.Cmd, + self.SubCmd + ) + return DumpString + + +m_NAtagCGQueryAllFamilyBossHurt=tagCGQueryAllFamilyBossHurt() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCGQueryAllFamilyBossHurt.Cmd,m_NAtagCGQueryAllFamilyBossHurt.SubCmd))] = m_NAtagCGQueryAllFamilyBossHurt #------------------------------------------------------ @@ -2456,6 +2641,62 @@ m_NAtagCGInvitePlayerJoinTeam=tagCGInvitePlayerJoinTeam() ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCGInvitePlayerJoinTeam.Cmd,m_NAtagCGInvitePlayerJoinTeam.SubCmd))] = m_NAtagCGInvitePlayerJoinTeam + + +#------------------------------------------------------ +# B9 0A 按条件邀请玩家加入队伍 #tagCGInvitePlayerJoinTeamByLV + +class tagCGInvitePlayerJoinTeamByLV(Structure): + _pack_ = 1 + _fields_ = [ + ("Cmd", c_ubyte), + ("SubCmd", c_ubyte), + ("LVLimit", c_ushort), # 目标玩家大于等于此等级 + ("InviteCnt", c_ubyte), # 邀请玩家个数 + ] + + def __init__(self): + self.Clear() + self.Cmd = 0xB9 + self.SubCmd = 0x0A + 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 = 0xB9 + self.SubCmd = 0x0A + self.LVLimit = 0 + self.InviteCnt = 0 + return + + def GetLength(self): + return sizeof(tagCGInvitePlayerJoinTeamByLV) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// B9 0A 按条件邀请玩家加入队伍 //tagCGInvitePlayerJoinTeamByLV: + Cmd:%s, + SubCmd:%s, + LVLimit:%d, + InviteCnt:%d + '''\ + %( + self.Cmd, + self.SubCmd, + self.LVLimit, + self.InviteCnt + ) + return DumpString + + +m_NAtagCGInvitePlayerJoinTeamByLV=tagCGInvitePlayerJoinTeamByLV() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCGInvitePlayerJoinTeamByLV.Cmd,m_NAtagCGInvitePlayerJoinTeamByLV.SubCmd))] = m_NAtagCGInvitePlayerJoinTeamByLV #------------------------------------------------------ @@ -4012,6 +4253,151 @@ #------------------------------------------------------ +# A2 28 查询仙盟抢Boss伤血列表 #tagCMQueryFamilyBossHurt + +class tagCMQueryFamilyBossHurt(Structure): + _pack_ = 1 + _fields_ = [ + ("Cmd", c_ubyte), + ("SubCmd", c_ubyte), + ("ObjID", c_int), + ("NPCID", c_int), + ("QueryType", c_ubyte), # 0-实时仙盟伤血,1-历史仙盟伤血,2-实时玩家伤血,3-历史玩家伤血 + ] + + def __init__(self): + self.Clear() + self.Cmd = 0xA2 + self.SubCmd = 0x28 + 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 = 0xA2 + self.SubCmd = 0x28 + self.ObjID = 0 + self.NPCID = 0 + self.QueryType = 0 + return + + def GetLength(self): + return sizeof(tagCMQueryFamilyBossHurt) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// A2 28 查询仙盟抢Boss伤血列表 //tagCMQueryFamilyBossHurt: + Cmd:%s, + SubCmd:%s, + ObjID:%d, + NPCID:%d, + QueryType:%d + '''\ + %( + self.Cmd, + self.SubCmd, + self.ObjID, + self.NPCID, + self.QueryType + ) + return DumpString + + +m_NAtagCMQueryFamilyBossHurt=tagCMQueryFamilyBossHurt() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMQueryFamilyBossHurt.Cmd,m_NAtagCMQueryFamilyBossHurt.SubCmd))] = m_NAtagCMQueryFamilyBossHurt + + +#------------------------------------------------------ +# A2 27 查询地图NPC数量信息 #tagCMQueryNPCCntInfo + +class tagCMQueryNPCCntInfo(Structure): + Head = tagHead() + MapID = 0 #(DWORD MapID)// 目标地图ID + LineID = 0 #(WORD LineID)// 线路ID + IsNoTimeLimit = 0 #(BYTE IsNoTimeLimit)//是否没有查询时间限制,默认有限制 + NPCIDListLen = 0 #(BYTE NPCIDListLen) + NPCIDList = "" #(String NPCIDList)// 需要查询的NPCID列表 + data = None + + def __init__(self): + self.Clear() + self.Head.Cmd = 0xA2 + self.Head.SubCmd = 0x27 + return + + def ReadData(self, _lpData, _pos=0, _Len=0): + self.Clear() + _pos = self.Head.ReadData(_lpData, _pos) + self.MapID,_pos = CommFunc.ReadDWORD(_lpData, _pos) + self.LineID,_pos = CommFunc.ReadWORD(_lpData, _pos) + self.IsNoTimeLimit,_pos = CommFunc.ReadBYTE(_lpData, _pos) + self.NPCIDListLen,_pos = CommFunc.ReadBYTE(_lpData, _pos) + self.NPCIDList,_pos = CommFunc.ReadString(_lpData, _pos,self.NPCIDListLen) + return _pos + + def Clear(self): + self.Head = tagHead() + self.Head.Clear() + self.Head.Cmd = 0xA2 + self.Head.SubCmd = 0x27 + self.MapID = 0 + self.LineID = 0 + self.IsNoTimeLimit = 0 + self.NPCIDListLen = 0 + self.NPCIDList = "" + return + + def GetLength(self): + length = 0 + length += self.Head.GetLength() + length += 4 + length += 2 + length += 1 + length += 1 + length += len(self.NPCIDList) + + return length + + def GetBuffer(self): + data = '' + data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) + data = CommFunc.WriteDWORD(data, self.MapID) + data = CommFunc.WriteWORD(data, self.LineID) + data = CommFunc.WriteBYTE(data, self.IsNoTimeLimit) + data = CommFunc.WriteBYTE(data, self.NPCIDListLen) + data = CommFunc.WriteString(data, self.NPCIDListLen, self.NPCIDList) + return data + + def OutputString(self): + DumpString = ''' + Head:%s, + MapID:%d, + LineID:%d, + IsNoTimeLimit:%d, + NPCIDListLen:%d, + NPCIDList:%s + '''\ + %( + self.Head.OutputString(), + self.MapID, + self.LineID, + self.IsNoTimeLimit, + self.NPCIDListLen, + self.NPCIDList + ) + return DumpString + + +m_NAtagCMQueryNPCCntInfo=tagCMQueryNPCCntInfo() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMQueryNPCCntInfo.Head.Cmd,m_NAtagCMQueryNPCCntInfo.Head.SubCmd))] = m_NAtagCMQueryNPCCntInfo + + +#------------------------------------------------------ # A2 13 查询地图NPC信息 #tagCMQueryNPCInfo class tagCMQueryNPCInfo(Structure): @@ -5506,6 +5892,58 @@ #------------------------------------------------------ +# A3 13 物品拆解 #tagCMItemDecompound + +class tagCMItemDecompound(Structure): + _pack_ = 1 + _fields_ = [ + ("Cmd", c_ubyte), + ("SubCmd", c_ubyte), + ("Index", c_ubyte), # 拆解物品所在背包索引 + ] + + def __init__(self): + self.Clear() + self.Cmd = 0xA3 + 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 = 0xA3 + self.SubCmd = 0x13 + self.Index = 0 + return + + def GetLength(self): + return sizeof(tagCMItemDecompound) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// A3 13 物品拆解 //tagCMItemDecompound: + Cmd:%s, + SubCmd:%s, + Index:%d + '''\ + %( + self.Cmd, + self.SubCmd, + self.Index + ) + return DumpString + + +m_NAtagCMItemDecompound=tagCMItemDecompound() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMItemDecompound.Cmd,m_NAtagCMItemDecompound.SubCmd))] = m_NAtagCMItemDecompound + + +#------------------------------------------------------ #A3 02 丢弃背包物品 #tagPlayerDropItem class tagPlayerDropItem(Structure): @@ -6526,6 +6964,58 @@ m_NAtagCMActiveAllEquipAttr=tagCMActiveAllEquipAttr() ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMActiveAllEquipAttr.Cmd,m_NAtagCMActiveAllEquipAttr.SubCmd))] = m_NAtagCMActiveAllEquipAttr + + +#------------------------------------------------------ +# A5 12 激活法宝之魂 #tagCMActiveMWSoul + +class tagCMActiveMWSoul(Structure): + _pack_ = 1 + _fields_ = [ + ("Cmd", c_ubyte), + ("SubCmd", c_ubyte), + ("ID", c_ubyte), #编号 + ] + + def __init__(self): + self.Clear() + self.Cmd = 0xA5 + self.SubCmd = 0x12 + 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 = 0x12 + self.ID = 0 + return + + def GetLength(self): + return sizeof(tagCMActiveMWSoul) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// A5 12 激活法宝之魂 //tagCMActiveMWSoul: + Cmd:%s, + SubCmd:%s, + ID:%d + '''\ + %( + self.Cmd, + self.SubCmd, + self.ID + ) + return DumpString + + +m_NAtagCMActiveMWSoul=tagCMActiveMWSoul() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMActiveMWSoul.Cmd,m_NAtagCMActiveMWSoul.SubCmd))] = m_NAtagCMActiveMWSoul #------------------------------------------------------ @@ -7665,6 +8155,331 @@ #------------------------------------------------------ +# A5 C2 神兽变更助战状态 #tagCMDogzBattleStateChange + +class tagCMDogzBattleStateChange(Structure): + _pack_ = 1 + _fields_ = [ + ("Cmd", c_ubyte), + ("SubCmd", c_ubyte), + ("DogzID", c_ubyte), # 神兽ID + ("BatteState", c_ubyte), #助战状态,0-召回,1-助战 + ] + + def __init__(self): + self.Clear() + self.Cmd = 0xA5 + self.SubCmd = 0xC2 + 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 = 0xC2 + self.DogzID = 0 + self.BatteState = 0 + return + + def GetLength(self): + return sizeof(tagCMDogzBattleStateChange) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// A5 C2 神兽变更助战状态 //tagCMDogzBattleStateChange: + Cmd:%s, + SubCmd:%s, + DogzID:%d, + BatteState:%d + '''\ + %( + self.Cmd, + self.SubCmd, + self.DogzID, + self.BatteState + ) + return DumpString + + +m_NAtagCMDogzBattleStateChange=tagCMDogzBattleStateChange() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMDogzBattleStateChange.Cmd,m_NAtagCMDogzBattleStateChange.SubCmd))] = m_NAtagCMDogzBattleStateChange + + +#------------------------------------------------------ +# A5 C3 神兽购买助战位 #tagCMDogzBuyBatteCount + +class tagCMDogzBuyBatteCount(Structure): + _pack_ = 1 + _fields_ = [ + ("Cmd", c_ubyte), + ("SubCmd", c_ubyte), + ] + + def __init__(self): + self.Clear() + self.Cmd = 0xA5 + self.SubCmd = 0xC3 + 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 = 0xC3 + return + + def GetLength(self): + return sizeof(tagCMDogzBuyBatteCount) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// A5 C3 神兽购买助战位 //tagCMDogzBuyBatteCount: + Cmd:%s, + SubCmd:%s + '''\ + %( + self.Cmd, + self.SubCmd + ) + return DumpString + + +m_NAtagCMDogzBuyBatteCount=tagCMDogzBuyBatteCount() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMDogzBuyBatteCount.Cmd,m_NAtagCMDogzBuyBatteCount.SubCmd))] = m_NAtagCMDogzBuyBatteCount + + +#------------------------------------------------------ +# A5 C0 神兽穿戴装备 #tagCMDogzEquipItem + +class tagCMDogzEquipItem(Structure): + Head = tagHead() + DogzID = 0 #(BYTE DogzID)// 神兽ID + EquipIndexCount = 0 #(BYTE EquipIndexCount) + EquipIndexList = list() #(vector<BYTE> EquipIndexList)//神兽装备所在神兽背包索引列表 + data = None + + def __init__(self): + self.Clear() + self.Head.Cmd = 0xA5 + self.Head.SubCmd = 0xC0 + return + + def ReadData(self, _lpData, _pos=0, _Len=0): + self.Clear() + _pos = self.Head.ReadData(_lpData, _pos) + self.DogzID,_pos = CommFunc.ReadBYTE(_lpData, _pos) + self.EquipIndexCount,_pos = CommFunc.ReadBYTE(_lpData, _pos) + for i in range(self.EquipIndexCount): + value,_pos=CommFunc.ReadBYTE(_lpData,_pos) + self.EquipIndexList.append(value) + return _pos + + def Clear(self): + self.Head = tagHead() + self.Head.Clear() + self.Head.Cmd = 0xA5 + self.Head.SubCmd = 0xC0 + self.DogzID = 0 + self.EquipIndexCount = 0 + self.EquipIndexList = list() + return + + def GetLength(self): + length = 0 + length += self.Head.GetLength() + length += 1 + length += 1 + length += 1 * self.EquipIndexCount + + return length + + def GetBuffer(self): + data = '' + data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) + data = CommFunc.WriteBYTE(data, self.DogzID) + data = CommFunc.WriteBYTE(data, self.EquipIndexCount) + for i in range(self.EquipIndexCount): + data = CommFunc.WriteBYTE(data, self.EquipIndexList[i]) + return data + + def OutputString(self): + DumpString = ''' + Head:%s, + DogzID:%d, + EquipIndexCount:%d, + EquipIndexList:%s + '''\ + %( + self.Head.OutputString(), + self.DogzID, + self.EquipIndexCount, + "..." + ) + return DumpString + + +m_NAtagCMDogzEquipItem=tagCMDogzEquipItem() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMDogzEquipItem.Head.Cmd,m_NAtagCMDogzEquipItem.Head.SubCmd))] = m_NAtagCMDogzEquipItem + + +#------------------------------------------------------ +# A5 C4 神兽装备强化 #tagCMDogzEquipPlus + +class tagCMDogzEquipPlus(Structure): + Head = tagHead() + EquipIndex = 0 #(BYTE EquipIndex)//神兽装备背包中索引 + IndexCount = 0 #(BYTE IndexCount)//材料所在神兽物品背包索引的数量 + IndexList = list() #(vector<BYTE> IndexList)//材料所在神兽物品背包索引列表 + IndexUseCountList = list() #(vector<DWORD> IndexUseCountList)//材料所在神兽物品背包索引对应使用个数列表 + IsDouble = 0 #(BYTE IsDouble)//是否双倍强化 + data = None + + def __init__(self): + self.Clear() + self.Head.Cmd = 0xA5 + self.Head.SubCmd = 0xC4 + return + + def ReadData(self, _lpData, _pos=0, _Len=0): + self.Clear() + _pos = self.Head.ReadData(_lpData, _pos) + self.EquipIndex,_pos = CommFunc.ReadBYTE(_lpData, _pos) + self.IndexCount,_pos = CommFunc.ReadBYTE(_lpData, _pos) + 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 + + def Clear(self): + self.Head = tagHead() + self.Head.Clear() + self.Head.Cmd = 0xA5 + self.Head.SubCmd = 0xC4 + self.EquipIndex = 0 + self.IndexCount = 0 + self.IndexList = list() + self.IndexUseCountList = list() + self.IsDouble = 0 + return + + def GetLength(self): + length = 0 + length += self.Head.GetLength() + length += 1 + length += 1 + length += 1 * self.IndexCount + length += 4 * self.IndexCount + length += 1 + + return length + + def GetBuffer(self): + data = '' + data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) + data = CommFunc.WriteBYTE(data, self.EquipIndex) + 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 + + def OutputString(self): + DumpString = ''' + Head:%s, + EquipIndex:%d, + IndexCount:%d, + IndexList:%s, + IndexUseCountList:%s, + IsDouble:%d + '''\ + %( + self.Head.OutputString(), + self.EquipIndex, + self.IndexCount, + "...", + "...", + self.IsDouble + ) + return DumpString + + +m_NAtagCMDogzEquipPlus=tagCMDogzEquipPlus() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMDogzEquipPlus.Head.Cmd,m_NAtagCMDogzEquipPlus.Head.SubCmd))] = m_NAtagCMDogzEquipPlus + + +#------------------------------------------------------ +# A5 C1 神兽卸下装备 #tagCMDogzUnEquipItem + +class tagCMDogzUnEquipItem(Structure): + _pack_ = 1 + _fields_ = [ + ("Cmd", c_ubyte), + ("SubCmd", c_ubyte), + ("DogzID", c_ubyte), # 神兽ID + ("EquipPlace", c_ubyte), #卸下的装备位, 0代表卸下全部 + ] + + def __init__(self): + self.Clear() + self.Cmd = 0xA5 + self.SubCmd = 0xC1 + 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 = 0xC1 + self.DogzID = 0 + self.EquipPlace = 0 + return + + def GetLength(self): + return sizeof(tagCMDogzUnEquipItem) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// A5 C1 神兽卸下装备 //tagCMDogzUnEquipItem: + Cmd:%s, + SubCmd:%s, + DogzID:%d, + EquipPlace:%d + '''\ + %( + self.Cmd, + self.SubCmd, + self.DogzID, + self.EquipPlace + ) + return DumpString + + +m_NAtagCMDogzUnEquipItem=tagCMDogzUnEquipItem() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMDogzUnEquipItem.Cmd,m_NAtagCMDogzUnEquipItem.SubCmd))] = m_NAtagCMDogzUnEquipItem + + +#------------------------------------------------------ # A5 48 兑换大师等级经验 #tagCMExchangeMasterEXP class tagCMExchangeMasterEXP(Structure): @@ -8659,6 +9474,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): @@ -9464,6 +10327,54 @@ #------------------------------------------------------ +# A5 17 绑玉转盘开始 #tagCMStartBindJadeWheel + +class tagCMStartBindJadeWheel(Structure): + _pack_ = 1 + _fields_ = [ + ("Cmd", c_ubyte), + ("SubCmd", c_ubyte), + ] + + def __init__(self): + self.Clear() + self.Cmd = 0xA5 + self.SubCmd = 0x17 + 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 = 0x17 + return + + def GetLength(self): + return sizeof(tagCMStartBindJadeWheel) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// A5 17 绑玉转盘开始 //tagCMStartBindJadeWheel: + Cmd:%s, + SubCmd:%s + '''\ + %( + self.Cmd, + self.SubCmd + ) + return DumpString + + +m_NAtagCMStartBindJadeWheel=tagCMStartBindJadeWheel() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMStartBindJadeWheel.Cmd,m_NAtagCMStartBindJadeWheel.SubCmd))] = m_NAtagCMStartBindJadeWheel + + +#------------------------------------------------------ # A5 11 试用首充武器 #tagCMTryFirstGoldItem class tagCMTryFirstGoldItem(Structure): @@ -9561,6 +10472,58 @@ m_NAtagCMUnLockBirthChartHole=tagCMUnLockBirthChartHole() ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMUnLockBirthChartHole.Cmd,m_NAtagCMUnLockBirthChartHole.SubCmd))] = m_NAtagCMUnLockBirthChartHole + + +#------------------------------------------------------ +# 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 #------------------------------------------------------ @@ -10417,6 +11380,178 @@ #------------------------------------------------------ +# AA 07 许愿池活动刷新奖池 #tagCMActWishingRefresh + +class tagCMActWishingRefresh(Structure): + _pack_ = 1 + _fields_ = [ + ("Cmd", c_ubyte), + ("SubCmd", c_ubyte), + ("IsFree", c_ubyte), # 是否免费刷新 + ] + + def __init__(self): + self.Clear() + self.Cmd = 0xAA + self.SubCmd = 0x07 + 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 = 0xAA + self.SubCmd = 0x07 + self.IsFree = 0 + return + + def GetLength(self): + return sizeof(tagCMActWishingRefresh) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// AA 07 许愿池活动刷新奖池 //tagCMActWishingRefresh: + Cmd:%s, + SubCmd:%s, + IsFree:%d + '''\ + %( + self.Cmd, + self.SubCmd, + self.IsFree + ) + return DumpString + + +m_NAtagCMActWishingRefresh=tagCMActWishingRefresh() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMActWishingRefresh.Cmd,m_NAtagCMActWishingRefresh.SubCmd))] = m_NAtagCMActWishingRefresh + + +#------------------------------------------------------ +# AA 06 许愿池活动许愿 #tagCMActWishing + +class tagCMActWishing(Structure): + _pack_ = 1 + _fields_ = [ + ("Cmd", c_ubyte), + ("SubCmd", c_ubyte), + ("SrcWellType", c_ubyte), # 来源库 0-可选库 1-结果库 + ("SrcIndex", c_ubyte), # 来源索引 + ("DesWellType", c_ubyte), # 目标库 0-可选库 1-结果库 + ("DesIndex", c_ubyte), # 目标索引 + ] + + def __init__(self): + self.Clear() + self.Cmd = 0xAA + self.SubCmd = 0x06 + 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 = 0xAA + self.SubCmd = 0x06 + self.SrcWellType = 0 + self.SrcIndex = 0 + self.DesWellType = 0 + self.DesIndex = 0 + return + + def GetLength(self): + return sizeof(tagCMActWishing) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// AA 06 许愿池活动许愿 //tagCMActWishing: + Cmd:%s, + SubCmd:%s, + SrcWellType:%d, + SrcIndex:%d, + DesWellType:%d, + DesIndex:%d + '''\ + %( + self.Cmd, + self.SubCmd, + self.SrcWellType, + self.SrcIndex, + self.DesWellType, + self.DesIndex + ) + return DumpString + + +m_NAtagCMActWishing=tagCMActWishing() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMActWishing.Cmd,m_NAtagCMActWishing.SubCmd))] = m_NAtagCMActWishing + + +#------------------------------------------------------ +# AA 05 限时抢购预约 #tagCMFlashSaleAppointment + +class tagCMFlashSaleAppointment(Structure): + _pack_ = 1 + _fields_ = [ + ("Cmd", c_ubyte), + ("SubCmd", c_ubyte), + ("GoodsID", c_int), # 抢购商品标识 + ("State", c_ubyte), # 1-预约 0-取消 + ] + + def __init__(self): + self.Clear() + self.Cmd = 0xAA + self.SubCmd = 0x05 + 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 = 0xAA + self.SubCmd = 0x05 + self.GoodsID = 0 + self.State = 0 + return + + def GetLength(self): + return sizeof(tagCMFlashSaleAppointment) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// AA 05 限时抢购预约 //tagCMFlashSaleAppointment: + Cmd:%s, + SubCmd:%s, + GoodsID:%d, + State:%d + '''\ + %( + self.Cmd, + self.SubCmd, + self.GoodsID, + self.State + ) + return DumpString + + +m_NAtagCMFlashSaleAppointment=tagCMFlashSaleAppointment() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMFlashSaleAppointment.Cmd,m_NAtagCMFlashSaleAppointment.SubCmd))] = m_NAtagCMFlashSaleAppointment + + +#------------------------------------------------------ # AA 02 领取升阶功能特惠奖励 #tagCMGetClassUPDayAward class tagCMGetClassUPDayAward(Structure): -- Gitblit v1.8.0