From d7f44d8d871a90c818bdb3ffe9a60af875b7100a Mon Sep 17 00:00:00 2001 From: hxp <ale99527@vip.qq.com> Date: 星期二, 30 九月 2025 10:12:23 +0800 Subject: [PATCH] 135 【挑战】战锤秘境-服务端(白骨盈野;副本基础;副本扫荡;广告奖励支持;) --- ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/ChPyNetSendPack.py | 2383 +++++++++++++---------------------------------------------- 1 files changed, 524 insertions(+), 1,859 deletions(-) diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/ChPyNetSendPack.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/ChPyNetSendPack.py index 62b85f1..dafb1ce 100644 --- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/ChPyNetSendPack.py +++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/ChPyNetSendPack.py @@ -193,6 +193,197 @@ #------------------------------------------------------ +# A0 09 通用记录信息 #tagSCGameRecInfo + +class tagSCGameRec(Structure): + Time = 0 #(DWORD Time)//时间 + Value1 = 0 #(DWORD Value1)//值1 + Value2 = 0 #(DWORD Value2)//值2 + Value3 = 0 #(DWORD Value3)//值3 + Value4 = 0 #(DWORD Value4)//值4 + Value5 = 0 #(DWORD Value5)//值5 + Value6 = 0 #(DWORD Value6)//值6 + Value7 = 0 #(DWORD Value7)//值7 + Value8 = 0 #(DWORD Value8)//值8 + UserDataLen = 0 #(WORD UserDataLen)//扩展数据长度 + UserData = "" #(String UserData)//扩展数据 + data = None + + def __init__(self): + self.Clear() + return + + def ReadData(self, _lpData, _pos=0, _Len=0): + self.Clear() + self.Time,_pos = CommFunc.ReadDWORD(_lpData, _pos) + self.Value1,_pos = CommFunc.ReadDWORD(_lpData, _pos) + self.Value2,_pos = CommFunc.ReadDWORD(_lpData, _pos) + self.Value3,_pos = CommFunc.ReadDWORD(_lpData, _pos) + self.Value4,_pos = CommFunc.ReadDWORD(_lpData, _pos) + self.Value5,_pos = CommFunc.ReadDWORD(_lpData, _pos) + self.Value6,_pos = CommFunc.ReadDWORD(_lpData, _pos) + self.Value7,_pos = CommFunc.ReadDWORD(_lpData, _pos) + self.Value8,_pos = CommFunc.ReadDWORD(_lpData, _pos) + self.UserDataLen,_pos = CommFunc.ReadWORD(_lpData, _pos) + self.UserData,_pos = CommFunc.ReadString(_lpData, _pos,self.UserDataLen) + return _pos + + def Clear(self): + self.Time = 0 + self.Value1 = 0 + self.Value2 = 0 + self.Value3 = 0 + self.Value4 = 0 + self.Value5 = 0 + self.Value6 = 0 + self.Value7 = 0 + self.Value8 = 0 + self.UserDataLen = 0 + self.UserData = "" + return + + def GetLength(self): + length = 0 + length += 4 + length += 4 + length += 4 + length += 4 + length += 4 + length += 4 + length += 4 + length += 4 + length += 4 + length += 2 + length += len(self.UserData) + + return length + + def GetBuffer(self): + data = '' + data = CommFunc.WriteDWORD(data, self.Time) + data = CommFunc.WriteDWORD(data, self.Value1) + data = CommFunc.WriteDWORD(data, self.Value2) + data = CommFunc.WriteDWORD(data, self.Value3) + data = CommFunc.WriteDWORD(data, self.Value4) + data = CommFunc.WriteDWORD(data, self.Value5) + data = CommFunc.WriteDWORD(data, self.Value6) + data = CommFunc.WriteDWORD(data, self.Value7) + data = CommFunc.WriteDWORD(data, self.Value8) + data = CommFunc.WriteWORD(data, self.UserDataLen) + data = CommFunc.WriteString(data, self.UserDataLen, self.UserData) + return data + + def OutputString(self): + DumpString = ''' + Time:%d, + Value1:%d, + Value2:%d, + Value3:%d, + Value4:%d, + Value5:%d, + Value6:%d, + Value7:%d, + Value8:%d, + UserDataLen:%d, + UserData:%s + '''\ + %( + self.Time, + self.Value1, + self.Value2, + self.Value3, + self.Value4, + self.Value5, + self.Value6, + self.Value7, + self.Value8, + self.UserDataLen, + self.UserData + ) + return DumpString + + +class tagSCGameRecInfo(Structure): + Head = tagHead() + RecType = 0 #(WORD RecType)//记录类型 + RecID = 0 #(DWORD RecID)//自定义记录ID + Count = 0 #(WORD Count)//数量 + RecList = list() #(vector<tagSCGameRec> RecList) + data = None + + def __init__(self): + self.Clear() + self.Head.Cmd = 0xA0 + self.Head.SubCmd = 0x09 + return + + def ReadData(self, _lpData, _pos=0, _Len=0): + self.Clear() + _pos = self.Head.ReadData(_lpData, _pos) + self.RecType,_pos = CommFunc.ReadWORD(_lpData, _pos) + self.RecID,_pos = CommFunc.ReadDWORD(_lpData, _pos) + self.Count,_pos = CommFunc.ReadWORD(_lpData, _pos) + for i in range(self.Count): + temRecList = tagSCGameRec() + _pos = temRecList.ReadData(_lpData, _pos) + self.RecList.append(temRecList) + return _pos + + def Clear(self): + self.Head = tagHead() + self.Head.Clear() + self.Head.Cmd = 0xA0 + self.Head.SubCmd = 0x09 + self.RecType = 0 + self.RecID = 0 + self.Count = 0 + self.RecList = list() + return + + def GetLength(self): + length = 0 + length += self.Head.GetLength() + length += 2 + length += 4 + length += 2 + for i in range(self.Count): + length += self.RecList[i].GetLength() + + return length + + def GetBuffer(self): + data = '' + data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) + data = CommFunc.WriteWORD(data, self.RecType) + data = CommFunc.WriteDWORD(data, self.RecID) + data = CommFunc.WriteWORD(data, self.Count) + for i in range(self.Count): + data = CommFunc.WriteString(data, self.RecList[i].GetLength(), self.RecList[i].GetBuffer()) + return data + + def OutputString(self): + DumpString = ''' + Head:%s, + RecType:%d, + RecID:%d, + Count:%d, + RecList:%s + '''\ + %( + self.Head.OutputString(), + self.RecType, + self.RecID, + self.Count, + "..." + ) + return DumpString + + +m_NAtagSCGameRecInfo=tagSCGameRecInfo() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagSCGameRecInfo.Head.Cmd,m_NAtagSCGameRecInfo.Head.SubCmd))] = m_NAtagSCGameRecInfo + + +#------------------------------------------------------ # A0 07 副本地图功能线路人数 #tagGCFBLinePlayerCnt class tagGCFBLineInfo(Structure): @@ -421,190 +612,6 @@ m_NAtagOpenServerDay=tagOpenServerDay() ChNetPackDict[eval("0x%02x%02x"%(m_NAtagOpenServerDay.Cmd,m_NAtagOpenServerDay.SubCmd))] = m_NAtagOpenServerDay - - -#------------------------------------------------------ -# A0 08 玩家记录信息 #tagGCPlayerRecInfo - -class tagGCPlayerRec(Structure): - Time = 0 #(DWORD Time)//时间 - Value1 = 0 #(DWORD Value1)//值1 - Value2 = 0 #(DWORD Value2)//值2 - Value3 = 0 #(DWORD Value3)//值3 - Value4 = 0 #(DWORD Value4)//值4 - Value5 = 0 #(DWORD Value5)//值5 - Value6 = 0 #(DWORD Value6)//值6 - Value7 = 0 #(DWORD Value7)//值7 - Value8 = 0 #(DWORD Value8)//值8 - UserDataLen = 0 #(WORD UserDataLen)//扩展数据长度 - UserData = "" #(String UserData)//扩展数据 - data = None - - def __init__(self): - self.Clear() - return - - def ReadData(self, _lpData, _pos=0, _Len=0): - self.Clear() - self.Time,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.Value1,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.Value2,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.Value3,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.Value4,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.Value5,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.Value6,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.Value7,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.Value8,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.UserDataLen,_pos = CommFunc.ReadWORD(_lpData, _pos) - self.UserData,_pos = CommFunc.ReadString(_lpData, _pos,self.UserDataLen) - return _pos - - def Clear(self): - self.Time = 0 - self.Value1 = 0 - self.Value2 = 0 - self.Value3 = 0 - self.Value4 = 0 - self.Value5 = 0 - self.Value6 = 0 - self.Value7 = 0 - self.Value8 = 0 - self.UserDataLen = 0 - self.UserData = "" - return - - def GetLength(self): - length = 0 - length += 4 - length += 4 - length += 4 - length += 4 - length += 4 - length += 4 - length += 4 - length += 4 - length += 4 - length += 2 - length += len(self.UserData) - - return length - - def GetBuffer(self): - data = '' - data = CommFunc.WriteDWORD(data, self.Time) - data = CommFunc.WriteDWORD(data, self.Value1) - data = CommFunc.WriteDWORD(data, self.Value2) - data = CommFunc.WriteDWORD(data, self.Value3) - data = CommFunc.WriteDWORD(data, self.Value4) - data = CommFunc.WriteDWORD(data, self.Value5) - data = CommFunc.WriteDWORD(data, self.Value6) - data = CommFunc.WriteDWORD(data, self.Value7) - data = CommFunc.WriteDWORD(data, self.Value8) - data = CommFunc.WriteWORD(data, self.UserDataLen) - data = CommFunc.WriteString(data, self.UserDataLen, self.UserData) - return data - - def OutputString(self): - DumpString = ''' - Time:%d, - Value1:%d, - Value2:%d, - Value3:%d, - Value4:%d, - Value5:%d, - Value6:%d, - Value7:%d, - Value8:%d, - UserDataLen:%d, - UserData:%s - '''\ - %( - self.Time, - self.Value1, - self.Value2, - self.Value3, - self.Value4, - self.Value5, - self.Value6, - self.Value7, - self.Value8, - self.UserDataLen, - self.UserData - ) - return DumpString - - -class tagGCPlayerRecInfo(Structure): - Head = tagHead() - Type = 0 #(BYTE Type)//类型 - Count = 0 #(WORD Count)//数量 - PlayerRecList = list() #(vector<tagGCPlayerRec> PlayerRecList) - data = None - - def __init__(self): - self.Clear() - self.Head.Cmd = 0xA0 - self.Head.SubCmd = 0x08 - return - - def ReadData(self, _lpData, _pos=0, _Len=0): - self.Clear() - _pos = self.Head.ReadData(_lpData, _pos) - self.Type,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.Count,_pos = CommFunc.ReadWORD(_lpData, _pos) - for i in range(self.Count): - temPlayerRecList = tagGCPlayerRec() - _pos = temPlayerRecList.ReadData(_lpData, _pos) - self.PlayerRecList.append(temPlayerRecList) - return _pos - - def Clear(self): - self.Head = tagHead() - self.Head.Clear() - self.Head.Cmd = 0xA0 - self.Head.SubCmd = 0x08 - self.Type = 0 - self.Count = 0 - self.PlayerRecList = list() - return - - def GetLength(self): - length = 0 - length += self.Head.GetLength() - length += 1 - length += 2 - for i in range(self.Count): - length += self.PlayerRecList[i].GetLength() - - return length - - def GetBuffer(self): - data = '' - data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) - data = CommFunc.WriteBYTE(data, self.Type) - data = CommFunc.WriteWORD(data, self.Count) - for i in range(self.Count): - data = CommFunc.WriteString(data, self.PlayerRecList[i].GetLength(), self.PlayerRecList[i].GetBuffer()) - return data - - def OutputString(self): - DumpString = ''' - Head:%s, - Type:%d, - Count:%d, - PlayerRecList:%s - '''\ - %( - self.Head.OutputString(), - self.Type, - self.Count, - "..." - ) - return DumpString - - -m_NAtagGCPlayerRecInfo=tagGCPlayerRecInfo() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagGCPlayerRecInfo.Head.Cmd,m_NAtagGCPlayerRecInfo.Head.SubCmd))] = m_NAtagGCPlayerRecInfo #------------------------------------------------------ @@ -923,197 +930,6 @@ m_NAtagServerGmMailInfo=tagServerGmMailInfo() ChNetPackDict[eval("0x%02x%02x"%(m_NAtagServerGmMailInfo.Head.Cmd,m_NAtagServerGmMailInfo.Head.SubCmd))] = m_NAtagServerGmMailInfo - - -#------------------------------------------------------ -#A0 03 玩家信息通用记录 #tagUniversalGameRecInfo - -class tagUniversalGameRec(Structure): - Time = 0 #(DWORD Time)//时间 - StrValue1Len = 0 #(WORD StrValue1Len)//字符串1长度 - StrValue1 = "" #(String StrValue1) - StrValue2Len = 0 #(WORD StrValue2Len)//字符串2长度 - StrValue2 = "" #(String StrValue2) - StrValue3Len = 0 #(WORD StrValue3Len)//字符串3长度 - StrValue3 = "" #(String StrValue3) - Value1 = 0 #(DWORD Value1)//数值1 - Value2 = 0 #(DWORD Value2)//数值1 - Value3 = 0 #(DWORD Value3)//数值1 - Value4 = 0 #(DWORD Value4)//数值1 - Value5 = 0 #(DWORD Value5)//数值1 - data = None - - def __init__(self): - self.Clear() - return - - def ReadData(self, _lpData, _pos=0, _Len=0): - self.Clear() - self.Time,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.StrValue1Len,_pos = CommFunc.ReadWORD(_lpData, _pos) - self.StrValue1,_pos = CommFunc.ReadString(_lpData, _pos,self.StrValue1Len) - self.StrValue2Len,_pos = CommFunc.ReadWORD(_lpData, _pos) - self.StrValue2,_pos = CommFunc.ReadString(_lpData, _pos,self.StrValue2Len) - self.StrValue3Len,_pos = CommFunc.ReadWORD(_lpData, _pos) - self.StrValue3,_pos = CommFunc.ReadString(_lpData, _pos,self.StrValue3Len) - self.Value1,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.Value2,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.Value3,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.Value4,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.Value5,_pos = CommFunc.ReadDWORD(_lpData, _pos) - return _pos - - def Clear(self): - self.Time = 0 - self.StrValue1Len = 0 - self.StrValue1 = "" - self.StrValue2Len = 0 - self.StrValue2 = "" - self.StrValue3Len = 0 - self.StrValue3 = "" - self.Value1 = 0 - self.Value2 = 0 - self.Value3 = 0 - self.Value4 = 0 - self.Value5 = 0 - return - - def GetLength(self): - length = 0 - length += 4 - length += 2 - length += len(self.StrValue1) - length += 2 - length += len(self.StrValue2) - length += 2 - length += len(self.StrValue3) - length += 4 - length += 4 - length += 4 - length += 4 - length += 4 - - return length - - def GetBuffer(self): - data = '' - data = CommFunc.WriteDWORD(data, self.Time) - data = CommFunc.WriteWORD(data, self.StrValue1Len) - data = CommFunc.WriteString(data, self.StrValue1Len, self.StrValue1) - data = CommFunc.WriteWORD(data, self.StrValue2Len) - data = CommFunc.WriteString(data, self.StrValue2Len, self.StrValue2) - data = CommFunc.WriteWORD(data, self.StrValue3Len) - data = CommFunc.WriteString(data, self.StrValue3Len, self.StrValue3) - data = CommFunc.WriteDWORD(data, self.Value1) - data = CommFunc.WriteDWORD(data, self.Value2) - data = CommFunc.WriteDWORD(data, self.Value3) - data = CommFunc.WriteDWORD(data, self.Value4) - data = CommFunc.WriteDWORD(data, self.Value5) - return data - - def OutputString(self): - DumpString = ''' - Time:%d, - StrValue1Len:%d, - StrValue1:%s, - StrValue2Len:%d, - StrValue2:%s, - StrValue3Len:%d, - StrValue3:%s, - Value1:%d, - Value2:%d, - Value3:%d, - Value4:%d, - Value5:%d - '''\ - %( - self.Time, - self.StrValue1Len, - self.StrValue1, - self.StrValue2Len, - self.StrValue2, - self.StrValue3Len, - self.StrValue3, - self.Value1, - self.Value2, - self.Value3, - self.Value4, - self.Value5 - ) - return DumpString - - -class tagUniversalGameRecInfo(Structure): - Head = tagHead() - Type = 0 #(BYTE Type)//类型 - Count = 0 #(WORD Count)//数量 - UniversalGameRec = list() #(vector<tagUniversalGameRec> UniversalGameRec)///size = Count - data = None - - def __init__(self): - self.Clear() - self.Head.Cmd = 0xA0 - self.Head.SubCmd = 0x03 - return - - def ReadData(self, _lpData, _pos=0, _Len=0): - self.Clear() - _pos = self.Head.ReadData(_lpData, _pos) - self.Type,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.Count,_pos = CommFunc.ReadWORD(_lpData, _pos) - for i in range(self.Count): - temUniversalGameRec = tagUniversalGameRec() - _pos = temUniversalGameRec.ReadData(_lpData, _pos) - self.UniversalGameRec.append(temUniversalGameRec) - return _pos - - def Clear(self): - self.Head = tagHead() - self.Head.Clear() - self.Head.Cmd = 0xA0 - self.Head.SubCmd = 0x03 - self.Type = 0 - self.Count = 0 - self.UniversalGameRec = list() - return - - def GetLength(self): - length = 0 - length += self.Head.GetLength() - length += 1 - length += 2 - for i in range(self.Count): - length += self.UniversalGameRec[i].GetLength() - - return length - - def GetBuffer(self): - data = '' - data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) - data = CommFunc.WriteBYTE(data, self.Type) - data = CommFunc.WriteWORD(data, self.Count) - for i in range(self.Count): - data = CommFunc.WriteString(data, self.UniversalGameRec[i].GetLength(), self.UniversalGameRec[i].GetBuffer()) - return data - - def OutputString(self): - DumpString = ''' - Head:%s, - Type:%d, - Count:%d, - UniversalGameRec:%s - '''\ - %( - self.Head.OutputString(), - self.Type, - self.Count, - "..." - ) - return DumpString - - -m_NAtagUniversalGameRecInfo=tagUniversalGameRecInfo() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagUniversalGameRecInfo.Head.Cmd,m_NAtagUniversalGameRecInfo.Head.SubCmd))] = m_NAtagUniversalGameRecInfo #------------------------------------------------------ @@ -3825,74 +3641,6 @@ #------------------------------------------------------ -# A3 C3 竞技场玩家信息 #tagMCArenaPlayerInfo - -class tagMCArenaPlayerInfo(Structure): - _pack_ = 1 - _fields_ = [ - ("Cmd", c_ubyte), - ("SubCmd", c_ubyte), - ("IsReset", c_ubyte), #是否是重置的 - ("Score", c_int), #当前积分 - ("BattleCountToday", c_ubyte), #今日已挑战次数 - ("MatchRefreshCount", c_ubyte), #当前已刷新匹配列表次数,每次挑战后会重置 - ("ItemAddBattleCountToday", c_ubyte), #今日已使用物品增加的挑战次数 - ] - - def __init__(self): - self.Clear() - self.Cmd = 0xA3 - 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 = 0xA3 - self.SubCmd = 0xC3 - self.IsReset = 0 - self.Score = 0 - self.BattleCountToday = 0 - self.MatchRefreshCount = 0 - self.ItemAddBattleCountToday = 0 - return - - def GetLength(self): - return sizeof(tagMCArenaPlayerInfo) - - def GetBuffer(self): - return string_at(addressof(self), self.GetLength()) - - def OutputString(self): - DumpString = '''// A3 C3 竞技场玩家信息 //tagMCArenaPlayerInfo: - Cmd:%s, - SubCmd:%s, - IsReset:%d, - Score:%d, - BattleCountToday:%d, - MatchRefreshCount:%d, - ItemAddBattleCountToday:%d - '''\ - %( - self.Cmd, - self.SubCmd, - self.IsReset, - self.Score, - self.BattleCountToday, - self.MatchRefreshCount, - self.ItemAddBattleCountToday - ) - return DumpString - - -m_NAtagMCArenaPlayerInfo=tagMCArenaPlayerInfo() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCArenaPlayerInfo.Cmd,m_NAtagMCArenaPlayerInfo.SubCmd))] = m_NAtagMCArenaPlayerInfo - - -#------------------------------------------------------ # A3 0F 通知玩家悬赏任务信息 #tagMCArrestTaskInfo class tagMCArrestTaskInfo(Structure): @@ -4098,114 +3846,6 @@ m_NAtagMCBOSSAttactCnt=tagMCBOSSAttactCnt() ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCBOSSAttactCnt.Head.Cmd,m_NAtagMCBOSSAttactCnt.Head.SubCmd))] = m_NAtagMCBOSSAttactCnt - - -#------------------------------------------------------ -# A3 BD 通知玩家购买副本进入次数 #tagMCBuyEnterInfo - -class tagMCBuyInfo(Structure): - _pack_ = 1 - _fields_ = [ - ("FBID", c_int), # 副本ID - ("BuyCount", c_ubyte), # 已购买次数 - ] - - def __init__(self): - self.Clear() - 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.FBID = 0 - self.BuyCount = 0 - return - - def GetLength(self): - return sizeof(tagMCBuyInfo) - - def GetBuffer(self): - return string_at(addressof(self), self.GetLength()) - - def OutputString(self): - DumpString = '''// A3 BD 通知玩家购买副本进入次数 //tagMCBuyEnterInfo: - FBID:%d, - BuyCount:%d - '''\ - %( - self.FBID, - self.BuyCount - ) - return DumpString - - -class tagMCBuyEnterInfo(Structure): - Head = tagHead() - FBCount = 0 #(BYTE FBCount)// 副本个数 - FBInfo = list() #(vector<tagMCBuyInfo> FBInfo)// 副本信息 - data = None - - def __init__(self): - self.Clear() - self.Head.Cmd = 0xA3 - self.Head.SubCmd = 0xBD - return - - def ReadData(self, _lpData, _pos=0, _Len=0): - self.Clear() - _pos = self.Head.ReadData(_lpData, _pos) - self.FBCount,_pos = CommFunc.ReadBYTE(_lpData, _pos) - for i in range(self.FBCount): - temFBInfo = tagMCBuyInfo() - _pos = temFBInfo.ReadData(_lpData, _pos) - self.FBInfo.append(temFBInfo) - return _pos - - def Clear(self): - self.Head = tagHead() - self.Head.Clear() - self.Head.Cmd = 0xA3 - self.Head.SubCmd = 0xBD - self.FBCount = 0 - self.FBInfo = list() - return - - def GetLength(self): - length = 0 - length += self.Head.GetLength() - length += 1 - for i in range(self.FBCount): - length += self.FBInfo[i].GetLength() - - return length - - def GetBuffer(self): - data = '' - data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) - data = CommFunc.WriteBYTE(data, self.FBCount) - for i in range(self.FBCount): - data = CommFunc.WriteString(data, self.FBInfo[i].GetLength(), self.FBInfo[i].GetBuffer()) - return data - - def OutputString(self): - DumpString = ''' - Head:%s, - FBCount:%d, - FBInfo:%s - '''\ - %( - self.Head.OutputString(), - self.FBCount, - "..." - ) - return DumpString - - -m_NAtagMCBuyEnterInfo=tagMCBuyEnterInfo() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCBuyEnterInfo.Head.Cmd,m_NAtagMCBuyEnterInfo.Head.SubCmd))] = m_NAtagMCBuyEnterInfo #------------------------------------------------------ @@ -5622,111 +5262,162 @@ #------------------------------------------------------ -#A3 0A 副本鼓舞信息通知 #tagMCFBEncourageInfo +# A3 20 玩家副本相关信息 #tagSCFBInfoList -class tagMCFBEncourageCnt(Structure): - _pack_ = 1 - _fields_ = [ - ("MoneyType", c_ubyte), # 金钱类型 - ("EncourageCnt", c_ubyte), # 当前鼓舞次数 - ] +class tagSCFBInfo(Structure): + MapID = 0 #(DWORD MapID) + EnterCnt = 0 #(WORD EnterCnt)//今日累计进入次数 + ADAddCnt = 0 #(BYTE ADAddCnt)//广告增加次数 + BuyAddCnt = 0 #(BYTE BuyAddCnt)//购买增加次数 + ItemAddCnt = 0 #(WORD ItemAddCnt)//物品增加次数 + PassLineID = 0 #(DWORD PassLineID)//已过关到的lineID + PassGradeCnt = 0 #(BYTE PassGradeCnt)//星级值对应个数, 每个key存9个lineID + PassGrade = list() #(vector<DWORD> PassGrade)//副本线路对应星级值列表 + data = None def __init__(self): self.Clear() 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() + self.MapID,_pos = CommFunc.ReadDWORD(_lpData, _pos) + self.EnterCnt,_pos = CommFunc.ReadWORD(_lpData, _pos) + self.ADAddCnt,_pos = CommFunc.ReadBYTE(_lpData, _pos) + self.BuyAddCnt,_pos = CommFunc.ReadBYTE(_lpData, _pos) + self.ItemAddCnt,_pos = CommFunc.ReadWORD(_lpData, _pos) + self.PassLineID,_pos = CommFunc.ReadDWORD(_lpData, _pos) + self.PassGradeCnt,_pos = CommFunc.ReadBYTE(_lpData, _pos) + for i in range(self.PassGradeCnt): + value,_pos=CommFunc.ReadDWORD(_lpData,_pos) + self.PassGrade.append(value) + return _pos def Clear(self): - self.MoneyType = 0 - self.EncourageCnt = 0 + self.MapID = 0 + self.EnterCnt = 0 + self.ADAddCnt = 0 + self.BuyAddCnt = 0 + self.ItemAddCnt = 0 + self.PassLineID = 0 + self.PassGradeCnt = 0 + self.PassGrade = list() return def GetLength(self): - return sizeof(tagMCFBEncourageCnt) + length = 0 + length += 4 + length += 2 + length += 1 + length += 1 + length += 2 + length += 4 + length += 1 + length += 4 * self.PassGradeCnt + + return length def GetBuffer(self): - return string_at(addressof(self), self.GetLength()) + data = '' + data = CommFunc.WriteDWORD(data, self.MapID) + data = CommFunc.WriteWORD(data, self.EnterCnt) + data = CommFunc.WriteBYTE(data, self.ADAddCnt) + data = CommFunc.WriteBYTE(data, self.BuyAddCnt) + data = CommFunc.WriteWORD(data, self.ItemAddCnt) + data = CommFunc.WriteDWORD(data, self.PassLineID) + data = CommFunc.WriteBYTE(data, self.PassGradeCnt) + for i in range(self.PassGradeCnt): + data = CommFunc.WriteDWORD(data, self.PassGrade[i]) + return data def OutputString(self): - DumpString = '''//A3 0A 副本鼓舞信息通知 //tagMCFBEncourageInfo: - MoneyType:%d, - EncourageCnt:%d + DumpString = ''' + MapID:%d, + EnterCnt:%d, + ADAddCnt:%d, + BuyAddCnt:%d, + ItemAddCnt:%d, + PassLineID:%d, + PassGradeCnt:%d, + PassGrade:%s '''\ %( - self.MoneyType, - self.EncourageCnt + self.MapID, + self.EnterCnt, + self.ADAddCnt, + self.BuyAddCnt, + self.ItemAddCnt, + self.PassLineID, + self.PassGradeCnt, + "..." ) return DumpString -class tagMCFBEncourageInfo(Structure): +class tagSCFBInfoList(Structure): Head = tagHead() - Cnt = 0 #(BYTE Cnt)// - InfoList = list() #(vector<tagMCFBEncourageCnt> InfoList)// 次数信息 + FBDataCnt = 0 #(BYTE FBDataCnt)// 副本数据个数 + FBDataList = list() #(vector<tagSCFBInfo> FBDataList)// 副本数据列表 data = None def __init__(self): self.Clear() self.Head.Cmd = 0xA3 - self.Head.SubCmd = 0x0A + self.Head.SubCmd = 0x20 return def ReadData(self, _lpData, _pos=0, _Len=0): self.Clear() _pos = self.Head.ReadData(_lpData, _pos) - self.Cnt,_pos = CommFunc.ReadBYTE(_lpData, _pos) - for i in range(self.Cnt): - temInfoList = tagMCFBEncourageCnt() - _pos = temInfoList.ReadData(_lpData, _pos) - self.InfoList.append(temInfoList) + self.FBDataCnt,_pos = CommFunc.ReadBYTE(_lpData, _pos) + for i in range(self.FBDataCnt): + temFBDataList = tagSCFBInfo() + _pos = temFBDataList.ReadData(_lpData, _pos) + self.FBDataList.append(temFBDataList) return _pos def Clear(self): self.Head = tagHead() self.Head.Clear() self.Head.Cmd = 0xA3 - self.Head.SubCmd = 0x0A - self.Cnt = 0 - self.InfoList = list() + self.Head.SubCmd = 0x20 + self.FBDataCnt = 0 + self.FBDataList = list() return def GetLength(self): length = 0 length += self.Head.GetLength() length += 1 - for i in range(self.Cnt): - length += self.InfoList[i].GetLength() + for i in range(self.FBDataCnt): + length += self.FBDataList[i].GetLength() return length def GetBuffer(self): data = '' data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) - data = CommFunc.WriteBYTE(data, self.Cnt) - for i in range(self.Cnt): - data = CommFunc.WriteString(data, self.InfoList[i].GetLength(), self.InfoList[i].GetBuffer()) + data = CommFunc.WriteBYTE(data, self.FBDataCnt) + for i in range(self.FBDataCnt): + data = CommFunc.WriteString(data, self.FBDataList[i].GetLength(), self.FBDataList[i].GetBuffer()) return data def OutputString(self): DumpString = ''' Head:%s, - Cnt:%d, - InfoList:%s + FBDataCnt:%d, + FBDataList:%s '''\ %( self.Head.OutputString(), - self.Cnt, + self.FBDataCnt, "..." ) return DumpString -m_NAtagMCFBEncourageInfo=tagMCFBEncourageInfo() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCFBEncourageInfo.Head.Cmd,m_NAtagMCFBEncourageInfo.Head.SubCmd))] = m_NAtagMCFBEncourageInfo +m_NAtagSCFBInfoList=tagSCFBInfoList() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagSCFBInfoList.Head.Cmd,m_NAtagSCFBInfoList.Head.SubCmd))] = m_NAtagSCFBInfoList #------------------------------------------------------ @@ -8549,165 +8240,6 @@ #------------------------------------------------------ -# A3 20 玩家副本相关信息 #tagMCPlayerFBInfoData - -class tagMCFBInfo(Structure): - FBID = 0 #(DWORD FBID)//fbId - EnterCnt = 0 #(WORD EnterCnt)//当日进入次数 - RecoverCnt = 0 #(WORD RecoverCnt)//找回次数 - ItemAddCnt = 0 #(WORD ItemAddCnt)//物品增加次数 - PassGradeCnt = 0 #(BYTE PassGradeCnt)//星级值对应个数, 每个key存9个lineID - PassGrade = list() #(vector<DWORD> PassGrade)//副本线路对应星级值列表 - EnterCntTotal = 0 #(DWORD EnterCntTotal)//累计进入次数 - PassLineID = 0 #(DWORD PassLineID)//已过关到的lineID - data = None - - def __init__(self): - self.Clear() - return - - def ReadData(self, _lpData, _pos=0, _Len=0): - self.Clear() - self.FBID,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.EnterCnt,_pos = CommFunc.ReadWORD(_lpData, _pos) - self.RecoverCnt,_pos = CommFunc.ReadWORD(_lpData, _pos) - self.ItemAddCnt,_pos = CommFunc.ReadWORD(_lpData, _pos) - self.PassGradeCnt,_pos = CommFunc.ReadBYTE(_lpData, _pos) - for i in range(self.PassGradeCnt): - value,_pos=CommFunc.ReadDWORD(_lpData,_pos) - self.PassGrade.append(value) - self.EnterCntTotal,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.PassLineID,_pos = CommFunc.ReadDWORD(_lpData, _pos) - return _pos - - def Clear(self): - self.FBID = 0 - self.EnterCnt = 0 - self.RecoverCnt = 0 - self.ItemAddCnt = 0 - self.PassGradeCnt = 0 - self.PassGrade = list() - self.EnterCntTotal = 0 - self.PassLineID = 0 - return - - def GetLength(self): - length = 0 - length += 4 - length += 2 - length += 2 - length += 2 - length += 1 - length += 4 * self.PassGradeCnt - length += 4 - length += 4 - - return length - - def GetBuffer(self): - data = '' - data = CommFunc.WriteDWORD(data, self.FBID) - data = CommFunc.WriteWORD(data, self.EnterCnt) - data = CommFunc.WriteWORD(data, self.RecoverCnt) - data = CommFunc.WriteWORD(data, self.ItemAddCnt) - data = CommFunc.WriteBYTE(data, self.PassGradeCnt) - for i in range(self.PassGradeCnt): - data = CommFunc.WriteDWORD(data, self.PassGrade[i]) - data = CommFunc.WriteDWORD(data, self.EnterCntTotal) - data = CommFunc.WriteDWORD(data, self.PassLineID) - return data - - def OutputString(self): - DumpString = ''' - FBID:%d, - EnterCnt:%d, - RecoverCnt:%d, - ItemAddCnt:%d, - PassGradeCnt:%d, - PassGrade:%s, - EnterCntTotal:%d, - PassLineID:%d - '''\ - %( - self.FBID, - self.EnterCnt, - self.RecoverCnt, - self.ItemAddCnt, - self.PassGradeCnt, - "...", - self.EnterCntTotal, - self.PassLineID - ) - return DumpString - - -class tagMCPlayerFBInfoData(Structure): - Head = tagHead() - FBDataCnt = 0 #(BYTE FBDataCnt)// 副本数据个数 - FBDataList = list() #(vector<tagMCFBInfo> FBDataList)// 副本数据列表 - data = None - - def __init__(self): - self.Clear() - self.Head.Cmd = 0xA3 - self.Head.SubCmd = 0x20 - return - - def ReadData(self, _lpData, _pos=0, _Len=0): - self.Clear() - _pos = self.Head.ReadData(_lpData, _pos) - self.FBDataCnt,_pos = CommFunc.ReadBYTE(_lpData, _pos) - for i in range(self.FBDataCnt): - temFBDataList = tagMCFBInfo() - _pos = temFBDataList.ReadData(_lpData, _pos) - self.FBDataList.append(temFBDataList) - return _pos - - def Clear(self): - self.Head = tagHead() - self.Head.Clear() - self.Head.Cmd = 0xA3 - self.Head.SubCmd = 0x20 - self.FBDataCnt = 0 - self.FBDataList = list() - return - - def GetLength(self): - length = 0 - length += self.Head.GetLength() - length += 1 - for i in range(self.FBDataCnt): - length += self.FBDataList[i].GetLength() - - return length - - def GetBuffer(self): - data = '' - data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) - data = CommFunc.WriteBYTE(data, self.FBDataCnt) - for i in range(self.FBDataCnt): - data = CommFunc.WriteString(data, self.FBDataList[i].GetLength(), self.FBDataList[i].GetBuffer()) - return data - - def OutputString(self): - DumpString = ''' - Head:%s, - FBDataCnt:%d, - FBDataList:%s - '''\ - %( - self.Head.OutputString(), - self.FBDataCnt, - "..." - ) - return DumpString - - -m_NAtagMCPlayerFBInfoData=tagMCPlayerFBInfoData() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCPlayerFBInfoData.Head.Cmd,m_NAtagMCPlayerFBInfoData.Head.SubCmd))] = m_NAtagMCPlayerFBInfoData - - -#------------------------------------------------------ #A3 0B 玩家等级奖励领取记录信息 #tagMCPlayerLVAwardGetRecord class tagMCPlayerLVAwardGetRecord(Structure): @@ -9220,130 +8752,6 @@ m_NAtagMCRealmExpInfo=tagMCRealmExpInfo() ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCRealmExpInfo.Cmd,m_NAtagMCRealmExpInfo.SubCmd))] = m_NAtagMCRealmExpInfo - - -#------------------------------------------------------ -# A3 49 资源找回次数 #tagMCRecoverNum - -class tagMCRecoverNumInfo(Structure): - _pack_ = 1 - _fields_ = [ - ("Index", c_ubyte), # 找回项索引 - ("RecoverCnt", c_ubyte), # 可找回次数 - ("ExtraCnt", c_ubyte), # VIP额外次数 - ("ExtraData", c_ubyte), # 额外参数1 - ("ExtraData2", c_ubyte), # 额外参数2 - ("HaveRecover", c_ubyte), # 已找回 1-全部已找回 2-非VIP已找回 - ] - - def __init__(self): - self.Clear() - 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.Index = 0 - self.RecoverCnt = 0 - self.ExtraCnt = 0 - self.ExtraData = 0 - self.ExtraData2 = 0 - self.HaveRecover = 0 - return - - def GetLength(self): - return sizeof(tagMCRecoverNumInfo) - - def GetBuffer(self): - return string_at(addressof(self), self.GetLength()) - - def OutputString(self): - DumpString = '''// A3 49 资源找回次数 //tagMCRecoverNum: - Index:%d, - RecoverCnt:%d, - ExtraCnt:%d, - ExtraData:%d, - ExtraData2:%d, - HaveRecover:%d - '''\ - %( - self.Index, - self.RecoverCnt, - self.ExtraCnt, - self.ExtraData, - self.ExtraData2, - self.HaveRecover - ) - return DumpString - - -class tagMCRecoverNum(Structure): - Head = tagHead() - Num = 0 #(BYTE Num)// 找回信息数 - NumInfo = list() #(vector<tagMCRecoverNumInfo> NumInfo)// 找回信息列表 - data = None - - def __init__(self): - self.Clear() - self.Head.Cmd = 0xA3 - self.Head.SubCmd = 0x49 - return - - def ReadData(self, _lpData, _pos=0, _Len=0): - self.Clear() - _pos = self.Head.ReadData(_lpData, _pos) - self.Num,_pos = CommFunc.ReadBYTE(_lpData, _pos) - for i in range(self.Num): - temNumInfo = tagMCRecoverNumInfo() - _pos = temNumInfo.ReadData(_lpData, _pos) - self.NumInfo.append(temNumInfo) - return _pos - - def Clear(self): - self.Head = tagHead() - self.Head.Clear() - self.Head.Cmd = 0xA3 - self.Head.SubCmd = 0x49 - self.Num = 0 - self.NumInfo = list() - return - - def GetLength(self): - length = 0 - length += self.Head.GetLength() - length += 1 - for i in range(self.Num): - length += self.NumInfo[i].GetLength() - - return length - - def GetBuffer(self): - data = '' - data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) - data = CommFunc.WriteBYTE(data, self.Num) - for i in range(self.Num): - data = CommFunc.WriteString(data, self.NumInfo[i].GetLength(), self.NumInfo[i].GetBuffer()) - return data - - def OutputString(self): - DumpString = ''' - Head:%s, - Num:%d, - NumInfo:%s - '''\ - %( - self.Head.OutputString(), - self.Num, - "..." - ) - return DumpString - - -m_NAtagMCRecoverNum=tagMCRecoverNum() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCRecoverNum.Head.Cmd,m_NAtagMCRecoverNum.Head.SubCmd))] = m_NAtagMCRecoverNum #------------------------------------------------------ @@ -15811,6 +15219,114 @@ #------------------------------------------------------ +# A7 22 广告信息列表 #tagSCADInfoList + +class tagSCADInfo(Structure): + _pack_ = 1 + _fields_ = [ + ("ADID", c_ushort), #广告ID + ("ADCnt", c_ubyte), #今日已领取广告奖励次数 + ] + + def __init__(self): + self.Clear() + 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.ADID = 0 + self.ADCnt = 0 + return + + def GetLength(self): + return sizeof(tagSCADInfo) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// A7 22 广告信息列表 //tagSCADInfoList: + ADID:%d, + ADCnt:%d + '''\ + %( + self.ADID, + self.ADCnt + ) + return DumpString + + +class tagSCADInfoList(Structure): + Head = tagHead() + Count = 0 #(BYTE Count) + ADInfoList = list() #(vector<tagSCADInfo> ADInfoList) + data = None + + def __init__(self): + self.Clear() + self.Head.Cmd = 0xA7 + self.Head.SubCmd = 0x22 + return + + def ReadData(self, _lpData, _pos=0, _Len=0): + self.Clear() + _pos = self.Head.ReadData(_lpData, _pos) + self.Count,_pos = CommFunc.ReadBYTE(_lpData, _pos) + for i in range(self.Count): + temADInfoList = tagSCADInfo() + _pos = temADInfoList.ReadData(_lpData, _pos) + self.ADInfoList.append(temADInfoList) + return _pos + + def Clear(self): + self.Head = tagHead() + self.Head.Clear() + self.Head.Cmd = 0xA7 + self.Head.SubCmd = 0x22 + self.Count = 0 + self.ADInfoList = list() + return + + def GetLength(self): + length = 0 + length += self.Head.GetLength() + length += 1 + for i in range(self.Count): + length += self.ADInfoList[i].GetLength() + + return length + + def GetBuffer(self): + data = '' + data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) + data = CommFunc.WriteBYTE(data, self.Count) + for i in range(self.Count): + data = CommFunc.WriteString(data, self.ADInfoList[i].GetLength(), self.ADInfoList[i].GetBuffer()) + return data + + def OutputString(self): + DumpString = ''' + Head:%s, + Count:%d, + ADInfoList:%s + '''\ + %( + self.Head.OutputString(), + self.Count, + "..." + ) + return DumpString + + +m_NAtagSCADInfoList=tagSCADInfoList() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagSCADInfoList.Head.Cmd,m_NAtagSCADInfoList.Head.SubCmd))] = m_NAtagSCADInfoList + + +#------------------------------------------------------ # A7 04 通知世界Boss伤血列表 #tagMCBossHurtList class tagMCHurtPlayer(Structure): @@ -16495,114 +16011,6 @@ m_NAtagMCEmojiPackInfo=tagMCEmojiPackInfo() ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCEmojiPackInfo.Head.Cmd,m_NAtagMCEmojiPackInfo.Head.SubCmd))] = m_NAtagMCEmojiPackInfo - - -#------------------------------------------------------ -# A7 03 通知进入副本时间 #tagMCFBEnterTickList - -class tagMCFBEnterTick(Structure): - _pack_ = 1 - _fields_ = [ - ("MapID", c_int), # 副本地图id - ("LastEnterTick", c_int), # 上次进入副本时间 - ] - - def __init__(self): - self.Clear() - 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.MapID = 0 - self.LastEnterTick = 0 - return - - def GetLength(self): - return sizeof(tagMCFBEnterTick) - - def GetBuffer(self): - return string_at(addressof(self), self.GetLength()) - - def OutputString(self): - DumpString = '''// A7 03 通知进入副本时间 //tagMCFBEnterTickList: - MapID:%d, - LastEnterTick:%d - '''\ - %( - self.MapID, - self.LastEnterTick - ) - return DumpString - - -class tagMCFBEnterTickList(Structure): - Head = tagHead() - Cnt = 0 #(BYTE Cnt)// 信息个数 - EnterTickList = list() #(vector<tagMCFBEnterTick> EnterTickList)// 信息列表 - data = None - - def __init__(self): - self.Clear() - self.Head.Cmd = 0xA7 - self.Head.SubCmd = 0x03 - return - - def ReadData(self, _lpData, _pos=0, _Len=0): - self.Clear() - _pos = self.Head.ReadData(_lpData, _pos) - self.Cnt,_pos = CommFunc.ReadBYTE(_lpData, _pos) - for i in range(self.Cnt): - temEnterTickList = tagMCFBEnterTick() - _pos = temEnterTickList.ReadData(_lpData, _pos) - self.EnterTickList.append(temEnterTickList) - return _pos - - def Clear(self): - self.Head = tagHead() - self.Head.Clear() - self.Head.Cmd = 0xA7 - self.Head.SubCmd = 0x03 - self.Cnt = 0 - self.EnterTickList = list() - return - - def GetLength(self): - length = 0 - length += self.Head.GetLength() - length += 1 - for i in range(self.Cnt): - length += self.EnterTickList[i].GetLength() - - return length - - def GetBuffer(self): - data = '' - data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) - data = CommFunc.WriteBYTE(data, self.Cnt) - for i in range(self.Cnt): - data = CommFunc.WriteString(data, self.EnterTickList[i].GetLength(), self.EnterTickList[i].GetBuffer()) - return data - - def OutputString(self): - DumpString = ''' - Head:%s, - Cnt:%d, - EnterTickList:%s - '''\ - %( - self.Head.OutputString(), - self.Cnt, - "..." - ) - return DumpString - - -m_NAtagMCFBEnterTickList=tagMCFBEnterTickList() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCFBEnterTickList.Head.Cmd,m_NAtagMCFBEnterTickList.Head.SubCmd))] = m_NAtagMCFBEnterTickList #------------------------------------------------------ @@ -17435,6 +16843,7 @@ RealmLV = 0 #(BYTE RealmLV) Face = 0 #(DWORD Face) FacePic = 0 #(DWORD FacePic) + ModelMark = 0 #(DWORD ModelMark)//变形模型mark TitleID = 0 #(DWORD TitleID)//佩戴的称号 ServerID = 0 #(DWORD ServerID) FightPower = 0 #(DWORD FightPower) @@ -17462,6 +16871,7 @@ self.RealmLV,_pos = CommFunc.ReadBYTE(_lpData, _pos) self.Face,_pos = CommFunc.ReadDWORD(_lpData, _pos) self.FacePic,_pos = CommFunc.ReadDWORD(_lpData, _pos) + self.ModelMark,_pos = CommFunc.ReadDWORD(_lpData, _pos) self.TitleID,_pos = CommFunc.ReadDWORD(_lpData, _pos) self.ServerID,_pos = CommFunc.ReadDWORD(_lpData, _pos) self.FightPower,_pos = CommFunc.ReadDWORD(_lpData, _pos) @@ -17485,6 +16895,7 @@ self.RealmLV = 0 self.Face = 0 self.FacePic = 0 + self.ModelMark = 0 self.TitleID = 0 self.ServerID = 0 self.FightPower = 0 @@ -17511,6 +16922,7 @@ length += 4 length += 4 length += 4 + length += 4 length += 33 length += 4 length += 4 @@ -17528,6 +16940,7 @@ data = CommFunc.WriteBYTE(data, self.RealmLV) data = CommFunc.WriteDWORD(data, self.Face) data = CommFunc.WriteDWORD(data, self.FacePic) + data = CommFunc.WriteDWORD(data, self.ModelMark) data = CommFunc.WriteDWORD(data, self.TitleID) data = CommFunc.WriteDWORD(data, self.ServerID) data = CommFunc.WriteDWORD(data, self.FightPower) @@ -17549,6 +16962,7 @@ RealmLV:%d, Face:%d, FacePic:%d, + ModelMark:%d, TitleID:%d, ServerID:%d, FightPower:%d, @@ -17568,6 +16982,7 @@ self.RealmLV, self.Face, self.FacePic, + self.ModelMark, self.TitleID, self.ServerID, self.FightPower, @@ -17977,73 +17392,6 @@ m_NAtagMCGiveAwardInfo=tagMCGiveAwardInfo() ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCGiveAwardInfo.Head.Cmd,m_NAtagMCGiveAwardInfo.Head.SubCmd))] = m_NAtagMCGiveAwardInfo - - -#------------------------------------------------------ -# A8 12 守护成功拾取物品 #tagMCGuradPickupItemSucc - -class tagMCGuradPickupItemSucc(Structure): - Head = tagHead() - ItemCount = 0 #(WORD ItemCount) - MapItemID = list() #(vector<WORD> MapItemID)//size = ItemCount - data = None - - def __init__(self): - self.Clear() - self.Head.Cmd = 0xA8 - self.Head.SubCmd = 0x12 - return - - def ReadData(self, _lpData, _pos=0, _Len=0): - self.Clear() - _pos = self.Head.ReadData(_lpData, _pos) - self.ItemCount,_pos = CommFunc.ReadWORD(_lpData, _pos) - for i in range(self.ItemCount): - value,_pos=CommFunc.ReadWORD(_lpData,_pos) - self.MapItemID.append(value) - return _pos - - def Clear(self): - self.Head = tagHead() - self.Head.Clear() - self.Head.Cmd = 0xA8 - self.Head.SubCmd = 0x12 - self.ItemCount = 0 - self.MapItemID = list() - return - - def GetLength(self): - length = 0 - length += self.Head.GetLength() - length += 2 - length += 2 * self.ItemCount - - return length - - def GetBuffer(self): - data = '' - data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) - data = CommFunc.WriteWORD(data, self.ItemCount) - for i in range(self.ItemCount): - data = CommFunc.WriteWORD(data, self.MapItemID[i]) - return data - - def OutputString(self): - DumpString = ''' - Head:%s, - ItemCount:%d, - MapItemID:%s - '''\ - %( - self.Head.OutputString(), - self.ItemCount, - "..." - ) - return DumpString - - -m_NAtagMCGuradPickupItemSucc=tagMCGuradPickupItemSucc() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCGuradPickupItemSucc.Head.Cmd,m_NAtagMCGuradPickupItemSucc.Head.SubCmd))] = m_NAtagMCGuradPickupItemSucc #------------------------------------------------------ @@ -18992,127 +18340,14 @@ #------------------------------------------------------ -# A9 26 竞技场对战玩家最新信息 #tagGCArenaBattlePlayerInfo +# A9 22 演武场匹配玩家列表 #tagSCArenaMatchList -class tagGCArenaBattlePlayerInfo(Structure): - Head = tagHead() +class tagSCArenaMatchInfo(Structure): PlayerID = 0 #(DWORD PlayerID)//目标玩家ID PlayerName = "" #(char PlayerName[33]) - Job = 0 #(BYTE Job) - LV = 0 #(WORD LV)//等级 RealmLV = 0 #(WORD RealmLV)//境界,机器人读境界表取等级对应境界 - FightPower = 0 #(DWORD FightPower)//战力求余亿部分,机器人读等级表取等级对应战力 - FightPowerEx = 0 #(DWORD FightPowerEx)//战力整除亿部分,机器人读等级表取等级对应战力 - Score = 0 #(DWORD Score)//积分 - data = None - - def __init__(self): - self.Clear() - self.Head.Cmd = 0xA9 - self.Head.SubCmd = 0x26 - return - - def ReadData(self, _lpData, _pos=0, _Len=0): - self.Clear() - _pos = self.Head.ReadData(_lpData, _pos) - self.PlayerID,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.PlayerName,_pos = CommFunc.ReadString(_lpData, _pos,33) - self.Job,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.LV,_pos = CommFunc.ReadWORD(_lpData, _pos) - self.RealmLV,_pos = CommFunc.ReadWORD(_lpData, _pos) - self.FightPower,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.FightPowerEx,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.Score,_pos = CommFunc.ReadDWORD(_lpData, _pos) - return _pos - - def Clear(self): - self.Head = tagHead() - self.Head.Clear() - self.Head.Cmd = 0xA9 - self.Head.SubCmd = 0x26 - self.PlayerID = 0 - self.PlayerName = "" - self.Job = 0 - self.LV = 0 - self.RealmLV = 0 - self.FightPower = 0 - self.FightPowerEx = 0 - self.Score = 0 - return - - def GetLength(self): - length = 0 - length += self.Head.GetLength() - length += 4 - length += 33 - length += 1 - length += 2 - length += 2 - length += 4 - length += 4 - length += 4 - - return length - - def GetBuffer(self): - data = '' - data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) - data = CommFunc.WriteDWORD(data, self.PlayerID) - data = CommFunc.WriteString(data, 33, self.PlayerName) - data = CommFunc.WriteBYTE(data, self.Job) - data = CommFunc.WriteWORD(data, self.LV) - data = CommFunc.WriteWORD(data, self.RealmLV) - data = CommFunc.WriteDWORD(data, self.FightPower) - data = CommFunc.WriteDWORD(data, self.FightPowerEx) - data = CommFunc.WriteDWORD(data, self.Score) - return data - - def OutputString(self): - DumpString = ''' - Head:%s, - PlayerID:%d, - PlayerName:%s, - Job:%d, - LV:%d, - RealmLV:%d, - FightPower:%d, - FightPowerEx:%d, - Score:%d - '''\ - %( - self.Head.OutputString(), - self.PlayerID, - self.PlayerName, - self.Job, - self.LV, - self.RealmLV, - self.FightPower, - self.FightPowerEx, - self.Score - ) - return DumpString - - -m_NAtagGCArenaBattlePlayerInfo=tagGCArenaBattlePlayerInfo() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagGCArenaBattlePlayerInfo.Head.Cmd,m_NAtagGCArenaBattlePlayerInfo.Head.SubCmd))] = m_NAtagGCArenaBattlePlayerInfo - - -#------------------------------------------------------ -# A9 23 竞技场对战记录列表 #tagGCArenaBattleRecordList - -class tagGCArenaBattleRecord(Structure): - PlayerID = 0 #(DWORD PlayerID)//目标玩家ID,小于10000为机器人ID - PlayerName = "" #(char PlayerName[33]) - Job = 0 #(BYTE Job) - LV = 0 #(WORD LV)//等级 - RealmLV = 0 #(WORD RealmLV)//境界,机器人读境界表取等级对应境界 - FightPower = 0 #(DWORD FightPower)//战力求余亿部分,机器人读等级表取等级对应战力 - FightPowerEx = 0 #(DWORD FightPowerEx)//战力整除亿部分,机器人读等级表取等级对应战力 - Score = 0 #(DWORD Score)//积分 - AddScoreLen = 0 #(BYTE AddScoreLen) - AddScore = "" #(String AddScore)//本次对战增加的积分,有正负 - IsWin = 0 #(BYTE IsWin)//是否获胜 - Time = 0 #(DWORD Time)//时间戳 + FightPower = 0 #(DWORD FightPower)//战力求余亿部分 + FightPowerEx = 0 #(DWORD FightPowerEx)//战力整除亿部分 Face = 0 #(DWORD Face)//基本脸型 FacePic = 0 #(DWORD FacePic)//头像框 data = None @@ -19125,16 +18360,9 @@ self.Clear() self.PlayerID,_pos = CommFunc.ReadDWORD(_lpData, _pos) self.PlayerName,_pos = CommFunc.ReadString(_lpData, _pos,33) - self.Job,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.LV,_pos = CommFunc.ReadWORD(_lpData, _pos) self.RealmLV,_pos = CommFunc.ReadWORD(_lpData, _pos) self.FightPower,_pos = CommFunc.ReadDWORD(_lpData, _pos) self.FightPowerEx,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.Score,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.AddScoreLen,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.AddScore,_pos = CommFunc.ReadString(_lpData, _pos,self.AddScoreLen) - self.IsWin,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.Time,_pos = CommFunc.ReadDWORD(_lpData, _pos) self.Face,_pos = CommFunc.ReadDWORD(_lpData, _pos) self.FacePic,_pos = CommFunc.ReadDWORD(_lpData, _pos) return _pos @@ -19142,16 +18370,9 @@ def Clear(self): self.PlayerID = 0 self.PlayerName = "" - self.Job = 0 - self.LV = 0 self.RealmLV = 0 self.FightPower = 0 self.FightPowerEx = 0 - self.Score = 0 - self.AddScoreLen = 0 - self.AddScore = "" - self.IsWin = 0 - self.Time = 0 self.Face = 0 self.FacePic = 0 return @@ -19160,196 +18381,7 @@ length = 0 length += 4 length += 33 - length += 1 length += 2 - length += 2 - length += 4 - length += 4 - length += 4 - length += 1 - length += len(self.AddScore) - length += 1 - length += 4 - length += 4 - length += 4 - - return length - - def GetBuffer(self): - data = '' - data = CommFunc.WriteDWORD(data, self.PlayerID) - data = CommFunc.WriteString(data, 33, self.PlayerName) - data = CommFunc.WriteBYTE(data, self.Job) - data = CommFunc.WriteWORD(data, self.LV) - data = CommFunc.WriteWORD(data, self.RealmLV) - data = CommFunc.WriteDWORD(data, self.FightPower) - data = CommFunc.WriteDWORD(data, self.FightPowerEx) - data = CommFunc.WriteDWORD(data, self.Score) - data = CommFunc.WriteBYTE(data, self.AddScoreLen) - data = CommFunc.WriteString(data, self.AddScoreLen, self.AddScore) - data = CommFunc.WriteBYTE(data, self.IsWin) - data = CommFunc.WriteDWORD(data, self.Time) - data = CommFunc.WriteDWORD(data, self.Face) - data = CommFunc.WriteDWORD(data, self.FacePic) - return data - - def OutputString(self): - DumpString = ''' - PlayerID:%d, - PlayerName:%s, - Job:%d, - LV:%d, - RealmLV:%d, - FightPower:%d, - FightPowerEx:%d, - Score:%d, - AddScoreLen:%d, - AddScore:%s, - IsWin:%d, - Time:%d, - Face:%d, - FacePic:%d - '''\ - %( - self.PlayerID, - self.PlayerName, - self.Job, - self.LV, - self.RealmLV, - self.FightPower, - self.FightPowerEx, - self.Score, - self.AddScoreLen, - self.AddScore, - self.IsWin, - self.Time, - self.Face, - self.FacePic - ) - return DumpString - - -class tagGCArenaBattleRecordList(Structure): - Head = tagHead() - RecordCount = 0 #(BYTE RecordCount) - BattleRecordList = list() #(vector<tagGCArenaBattleRecord> BattleRecordList)// 对战列表 - data = None - - def __init__(self): - self.Clear() - self.Head.Cmd = 0xA9 - self.Head.SubCmd = 0x23 - return - - def ReadData(self, _lpData, _pos=0, _Len=0): - self.Clear() - _pos = self.Head.ReadData(_lpData, _pos) - self.RecordCount,_pos = CommFunc.ReadBYTE(_lpData, _pos) - for i in range(self.RecordCount): - temBattleRecordList = tagGCArenaBattleRecord() - _pos = temBattleRecordList.ReadData(_lpData, _pos) - self.BattleRecordList.append(temBattleRecordList) - return _pos - - def Clear(self): - self.Head = tagHead() - self.Head.Clear() - self.Head.Cmd = 0xA9 - self.Head.SubCmd = 0x23 - self.RecordCount = 0 - self.BattleRecordList = list() - return - - def GetLength(self): - length = 0 - length += self.Head.GetLength() - length += 1 - for i in range(self.RecordCount): - length += self.BattleRecordList[i].GetLength() - - return length - - def GetBuffer(self): - data = '' - data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) - data = CommFunc.WriteBYTE(data, self.RecordCount) - for i in range(self.RecordCount): - data = CommFunc.WriteString(data, self.BattleRecordList[i].GetLength(), self.BattleRecordList[i].GetBuffer()) - return data - - def OutputString(self): - DumpString = ''' - Head:%s, - RecordCount:%d, - BattleRecordList:%s - '''\ - %( - self.Head.OutputString(), - self.RecordCount, - "..." - ) - return DumpString - - -m_NAtagGCArenaBattleRecordList=tagGCArenaBattleRecordList() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagGCArenaBattleRecordList.Head.Cmd,m_NAtagGCArenaBattleRecordList.Head.SubCmd))] = m_NAtagGCArenaBattleRecordList - - -#------------------------------------------------------ -# A9 22 竞技场匹配玩家列表 #tagGCArenaMatchList - -class tagGCArenaMatchInfo(Structure): - PlayerID = 0 #(DWORD PlayerID)//目标玩家ID,小于10000为机器人ID - PlayerName = "" #(char PlayerName[33]) - Job = 0 #(BYTE Job) - LV = 0 #(WORD LV)//等级 - RealmLV = 0 #(WORD RealmLV)//境界,机器人读境界表取等级对应境界 - FightPower = 0 #(DWORD FightPower)//战力求余亿部分,机器人读等级表取等级对应战力 - FightPowerEx = 0 #(DWORD FightPowerEx)//战力整除亿部分,机器人读等级表取等级对应战力 - Score = 0 #(DWORD Score)//积分 - Face = 0 #(DWORD Face)//基本脸型 - FacePic = 0 #(DWORD FacePic)//头像框 - data = None - - def __init__(self): - self.Clear() - return - - def ReadData(self, _lpData, _pos=0, _Len=0): - self.Clear() - self.PlayerID,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.PlayerName,_pos = CommFunc.ReadString(_lpData, _pos,33) - self.Job,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.LV,_pos = CommFunc.ReadWORD(_lpData, _pos) - self.RealmLV,_pos = CommFunc.ReadWORD(_lpData, _pos) - self.FightPower,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.FightPowerEx,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.Score,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.Face,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.FacePic,_pos = CommFunc.ReadDWORD(_lpData, _pos) - return _pos - - def Clear(self): - self.PlayerID = 0 - self.PlayerName = "" - self.Job = 0 - self.LV = 0 - self.RealmLV = 0 - self.FightPower = 0 - self.FightPowerEx = 0 - self.Score = 0 - self.Face = 0 - self.FacePic = 0 - return - - def GetLength(self): - length = 0 - length += 4 - length += 33 - length += 1 - length += 2 - length += 2 - length += 4 length += 4 length += 4 length += 4 @@ -19361,12 +18393,9 @@ data = '' data = CommFunc.WriteDWORD(data, self.PlayerID) data = CommFunc.WriteString(data, 33, self.PlayerName) - data = CommFunc.WriteBYTE(data, self.Job) - data = CommFunc.WriteWORD(data, self.LV) data = CommFunc.WriteWORD(data, self.RealmLV) data = CommFunc.WriteDWORD(data, self.FightPower) data = CommFunc.WriteDWORD(data, self.FightPowerEx) - data = CommFunc.WriteDWORD(data, self.Score) data = CommFunc.WriteDWORD(data, self.Face) data = CommFunc.WriteDWORD(data, self.FacePic) return data @@ -19375,34 +18404,28 @@ DumpString = ''' PlayerID:%d, PlayerName:%s, - Job:%d, - LV:%d, RealmLV:%d, FightPower:%d, FightPowerEx:%d, - Score:%d, Face:%d, FacePic:%d '''\ %( self.PlayerID, self.PlayerName, - self.Job, - self.LV, self.RealmLV, self.FightPower, self.FightPowerEx, - self.Score, self.Face, self.FacePic ) return DumpString -class tagGCArenaMatchList(Structure): +class tagSCArenaMatchList(Structure): Head = tagHead() MatchCount = 0 #(BYTE MatchCount) - MatchList = list() #(vector<tagGCArenaMatchInfo> MatchList)// 匹配列表 + MatchList = list() #(vector<tagSCArenaMatchInfo> MatchList)// 匹配列表,从高分到低分 data = None def __init__(self): @@ -19416,7 +18439,7 @@ _pos = self.Head.ReadData(_lpData, _pos) self.MatchCount,_pos = CommFunc.ReadBYTE(_lpData, _pos) for i in range(self.MatchCount): - temMatchList = tagGCArenaMatchInfo() + temMatchList = tagSCArenaMatchInfo() _pos = temMatchList.ReadData(_lpData, _pos) self.MatchList.append(temMatchList) return _pos @@ -19461,8 +18484,60 @@ return DumpString -m_NAtagGCArenaMatchList=tagGCArenaMatchList() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagGCArenaMatchList.Head.Cmd,m_NAtagGCArenaMatchList.Head.SubCmd))] = m_NAtagGCArenaMatchList +m_NAtagSCArenaMatchList=tagSCArenaMatchList() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagSCArenaMatchList.Head.Cmd,m_NAtagSCArenaMatchList.Head.SubCmd))] = m_NAtagSCArenaMatchList + + +#------------------------------------------------------ +# A9 23 演武场玩家信息 #tagSCArenaPlayerInfo + +class tagSCArenaPlayerInfo(Structure): + _pack_ = 1 + _fields_ = [ + ("Cmd", c_ubyte), + ("SubCmd", c_ubyte), + ("Score", c_int), #当前积分 + ] + + def __init__(self): + self.Clear() + self.Cmd = 0xA9 + self.SubCmd = 0x23 + 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 = 0xA9 + self.SubCmd = 0x23 + self.Score = 0 + return + + def GetLength(self): + return sizeof(tagSCArenaPlayerInfo) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// A9 23 演武场玩家信息 //tagSCArenaPlayerInfo: + Cmd:%s, + SubCmd:%s, + Score:%d + '''\ + %( + self.Cmd, + self.SubCmd, + self.Score + ) + return DumpString + + +m_NAtagSCArenaPlayerInfo=tagSCArenaPlayerInfo() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagSCArenaPlayerInfo.Cmd,m_NAtagSCArenaPlayerInfo.SubCmd))] = m_NAtagSCArenaPlayerInfo #------------------------------------------------------ @@ -31501,22 +30576,17 @@ #------------------------------------------------------ -# AA 02 首充信息 #tagMCFirstGoldInfo +# AA 02 首充信息 #tagSCFirstChargeInfo -class tagMCFirstGoldInfo(Structure): +class tagSCFirstCharge(Structure): _pack_ = 1 _fields_ = [ - ("Cmd", c_ubyte), - ("SubCmd", c_ubyte), - ("FirstGoldRewardState", c_ubyte), #首充奖励领奖记录,按位记录首充第X天是否已领取,第1天为第0索引位 - ("FirstGoldTry", c_ubyte), #首充试用状态0-不可试用 1-可试用 2-已试用 - ("FirstGoldServerDay", c_ushort), #首充时是开服第几天,从1开始,0代表未记录充值 + ("ChargeTime", c_int), #充值该首充的时间戳 + ("AwardRecord", c_ushort), #首充奖励领奖记录,按二进制位记录首充第X天是否已领取 ] def __init__(self): self.Clear() - self.Cmd = 0xAA - self.SubCmd = 0x02 return def ReadData(self, stringData, _pos=0, _len=0): @@ -31525,91 +30595,92 @@ return _pos + self.GetLength() def Clear(self): - self.Cmd = 0xAA - self.SubCmd = 0x02 - self.FirstGoldRewardState = 0 - self.FirstGoldTry = 0 - self.FirstGoldServerDay = 0 + self.ChargeTime = 0 + self.AwardRecord = 0 return def GetLength(self): - return sizeof(tagMCFirstGoldInfo) + return sizeof(tagSCFirstCharge) def GetBuffer(self): return string_at(addressof(self), self.GetLength()) def OutputString(self): - DumpString = '''// AA 02 首充信息 //tagMCFirstGoldInfo: - Cmd:%s, - SubCmd:%s, - FirstGoldRewardState:%d, - FirstGoldTry:%d, - FirstGoldServerDay:%d + DumpString = '''// AA 02 首充信息 //tagSCFirstChargeInfo: + ChargeTime:%d, + AwardRecord:%d '''\ %( - self.Cmd, - self.SubCmd, - self.FirstGoldRewardState, - self.FirstGoldTry, - self.FirstGoldServerDay + self.ChargeTime, + self.AwardRecord ) return DumpString -m_NAtagMCFirstGoldInfo=tagMCFirstGoldInfo() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCFirstGoldInfo.Cmd,m_NAtagMCFirstGoldInfo.SubCmd))] = m_NAtagMCFirstGoldInfo - - -#------------------------------------------------------ -# AA 08 首充提示剩余时间 #tagMCFirstGoldTime - -class tagMCFirstGoldTime(Structure): - _pack_ = 1 - _fields_ = [ - ("Cmd", c_ubyte), - ("SubCmd", c_ubyte), - ("FirstGoldRemainTime", c_int), #首充提示剩余时间 - ] +class tagSCFirstChargeInfo(Structure): + Head = tagHead() + Count = 0 #(BYTE Count) + FirstChargeList = list() #(vector<tagSCFirstCharge> FirstChargeList) + data = None def __init__(self): self.Clear() - self.Cmd = 0xAA - self.SubCmd = 0x08 + self.Head.Cmd = 0xAA + self.Head.SubCmd = 0x02 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.Count,_pos = CommFunc.ReadBYTE(_lpData, _pos) + for i in range(self.Count): + temFirstChargeList = tagSCFirstCharge() + _pos = temFirstChargeList.ReadData(_lpData, _pos) + self.FirstChargeList.append(temFirstChargeList) + return _pos def Clear(self): - self.Cmd = 0xAA - self.SubCmd = 0x08 - self.FirstGoldRemainTime = 0 + self.Head = tagHead() + self.Head.Clear() + self.Head.Cmd = 0xAA + self.Head.SubCmd = 0x02 + self.Count = 0 + self.FirstChargeList = list() return def GetLength(self): - return sizeof(tagMCFirstGoldTime) + length = 0 + length += self.Head.GetLength() + length += 1 + for i in range(self.Count): + length += self.FirstChargeList[i].GetLength() + + 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.WriteBYTE(data, self.Count) + for i in range(self.Count): + data = CommFunc.WriteString(data, self.FirstChargeList[i].GetLength(), self.FirstChargeList[i].GetBuffer()) + return data def OutputString(self): - DumpString = '''// AA 08 首充提示剩余时间 //tagMCFirstGoldTime: - Cmd:%s, - SubCmd:%s, - FirstGoldRemainTime:%d + DumpString = ''' + Head:%s, + Count:%d, + FirstChargeList:%s '''\ %( - self.Cmd, - self.SubCmd, - self.FirstGoldRemainTime + self.Head.OutputString(), + self.Count, + "..." ) return DumpString -m_NAtagMCFirstGoldTime=tagMCFirstGoldTime() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCFirstGoldTime.Cmd,m_NAtagMCFirstGoldTime.SubCmd))] = m_NAtagMCFirstGoldTime +m_NAtagSCFirstChargeInfo=tagSCFirstChargeInfo() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagSCFirstChargeInfo.Head.Cmd,m_NAtagSCFirstChargeInfo.Head.SubCmd))] = m_NAtagSCFirstChargeInfo #------------------------------------------------------ @@ -38000,6 +37071,8 @@ ("BookInitState", c_ubyte), # 图鉴激活状态:0-未激活;1-可激活;2-已激活 ("BookStarLV", c_ushort), # 图鉴星级等级 ("BookBreakLV", c_ushort), # 图鉴突破等级 + ("BookStarLVH", c_ushort), # 图鉴星级历史最高等级 + ("BookBreakLVH", c_ushort), # 图鉴突破历史最高等级 ] def __init__(self): @@ -38017,6 +37090,8 @@ self.BookInitState = 0 self.BookStarLV = 0 self.BookBreakLV = 0 + self.BookStarLVH = 0 + self.BookBreakLVH = 0 return def GetLength(self): @@ -38031,14 +37106,18 @@ SkinState:%d, BookInitState:%d, BookStarLV:%d, - BookBreakLV:%d + BookBreakLV:%d, + BookStarLVH:%d, + BookBreakLVH:%d '''\ %( self.HeroID, self.SkinState, self.BookInitState, self.BookStarLV, - self.BookBreakLV + self.BookBreakLV, + self.BookStarLVH, + self.BookBreakLVH ) return DumpString @@ -39684,230 +38763,6 @@ #------------------------------------------------------ -# B2 15 副本买buff信息通知 #tagMCFBBuyBuffInfo - -class tagMCFBBuyBuffTime(Structure): - _pack_ = 1 - _fields_ = [ - ("MapID", c_int), - ("MoneyCnt", c_ushort), - ("BuyTime", c_int), - ] - - def __init__(self): - self.Clear() - 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.MapID = 0 - self.MoneyCnt = 0 - self.BuyTime = 0 - return - - def GetLength(self): - return sizeof(tagMCFBBuyBuffTime) - - def GetBuffer(self): - return string_at(addressof(self), self.GetLength()) - - def OutputString(self): - DumpString = '''// B2 15 副本买buff信息通知 //tagMCFBBuyBuffInfo: - MapID:%d, - MoneyCnt:%d, - BuyTime:%d - '''\ - %( - self.MapID, - self.MoneyCnt, - self.BuyTime - ) - return DumpString - - -class tagMCFBBuyBuffInfo(Structure): - Head = tagHead() - Cnt = 0 #(BYTE Cnt) - InfoList = list() #(vector<tagMCFBBuyBuffTime> InfoList) - data = None - - def __init__(self): - self.Clear() - self.Head.Cmd = 0xB2 - self.Head.SubCmd = 0x15 - return - - def ReadData(self, _lpData, _pos=0, _Len=0): - self.Clear() - _pos = self.Head.ReadData(_lpData, _pos) - self.Cnt,_pos = CommFunc.ReadBYTE(_lpData, _pos) - for i in range(self.Cnt): - temInfoList = tagMCFBBuyBuffTime() - _pos = temInfoList.ReadData(_lpData, _pos) - self.InfoList.append(temInfoList) - return _pos - - def Clear(self): - self.Head = tagHead() - self.Head.Clear() - self.Head.Cmd = 0xB2 - self.Head.SubCmd = 0x15 - self.Cnt = 0 - self.InfoList = list() - return - - def GetLength(self): - length = 0 - length += self.Head.GetLength() - length += 1 - for i in range(self.Cnt): - length += self.InfoList[i].GetLength() - - return length - - def GetBuffer(self): - data = '' - data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) - data = CommFunc.WriteBYTE(data, self.Cnt) - for i in range(self.Cnt): - data = CommFunc.WriteString(data, self.InfoList[i].GetLength(), self.InfoList[i].GetBuffer()) - return data - - def OutputString(self): - DumpString = ''' - Head:%s, - Cnt:%d, - InfoList:%s - '''\ - %( - self.Head.OutputString(), - self.Cnt, - "..." - ) - return DumpString - - -m_NAtagMCFBBuyBuffInfo=tagMCFBBuyBuffInfo() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCFBBuyBuffInfo.Head.Cmd,m_NAtagMCFBBuyBuffInfo.Head.SubCmd))] = m_NAtagMCFBBuyBuffInfo - - -#------------------------------------------------------ -# B2 09 副本次数恢复剩余时间 #tagMCFBCntRegainRemainTime - -class tagMCFBCntRegain(Structure): - _pack_ = 1 - _fields_ = [ - ("DataMapID", c_int), # 地图ID - ("RemainTime", c_int), # 剩余时间秒 - ("RegainCnt", c_ubyte), # 今日已恢复次数 - ] - - def __init__(self): - self.Clear() - 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.DataMapID = 0 - self.RemainTime = 0 - self.RegainCnt = 0 - return - - def GetLength(self): - return sizeof(tagMCFBCntRegain) - - def GetBuffer(self): - return string_at(addressof(self), self.GetLength()) - - def OutputString(self): - DumpString = '''// B2 09 副本次数恢复剩余时间 //tagMCFBCntRegainRemainTime: - DataMapID:%d, - RemainTime:%d, - RegainCnt:%d - '''\ - %( - self.DataMapID, - self.RemainTime, - self.RegainCnt - ) - return DumpString - - -class tagMCFBCntRegainRemainTime(Structure): - Head = tagHead() - Cnt = 0 #(BYTE Cnt)// 信息数 - InfoList = list() #(vector<tagMCFBCntRegain> InfoList)// 信息列表 - data = None - - def __init__(self): - self.Clear() - self.Head.Cmd = 0xB2 - self.Head.SubCmd = 0x09 - return - - def ReadData(self, _lpData, _pos=0, _Len=0): - self.Clear() - _pos = self.Head.ReadData(_lpData, _pos) - self.Cnt,_pos = CommFunc.ReadBYTE(_lpData, _pos) - for i in range(self.Cnt): - temInfoList = tagMCFBCntRegain() - _pos = temInfoList.ReadData(_lpData, _pos) - self.InfoList.append(temInfoList) - return _pos - - def Clear(self): - self.Head = tagHead() - self.Head.Clear() - self.Head.Cmd = 0xB2 - self.Head.SubCmd = 0x09 - self.Cnt = 0 - self.InfoList = list() - return - - def GetLength(self): - length = 0 - length += self.Head.GetLength() - length += 1 - for i in range(self.Cnt): - length += self.InfoList[i].GetLength() - - return length - - def GetBuffer(self): - data = '' - data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) - data = CommFunc.WriteBYTE(data, self.Cnt) - for i in range(self.Cnt): - data = CommFunc.WriteString(data, self.InfoList[i].GetLength(), self.InfoList[i].GetBuffer()) - return data - - def OutputString(self): - DumpString = ''' - Head:%s, - Cnt:%d, - InfoList:%s - '''\ - %( - self.Head.OutputString(), - self.Cnt, - "..." - ) - return DumpString - - -m_NAtagMCFBCntRegainRemainTime=tagMCFBCntRegainRemainTime() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCFBCntRegainRemainTime.Head.Cmd,m_NAtagMCFBCntRegainRemainTime.Head.SubCmd))] = m_NAtagMCFBCntRegainRemainTime - - -#------------------------------------------------------ # B2 01 通知封魔坛双倍击杀状态 #tagMCFMTDoubleState class tagMCFMTDoubleState(Structure): @@ -39961,196 +38816,6 @@ m_NAtagMCFMTDoubleState=tagMCFMTDoubleState() ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCFMTDoubleState.Cmd,m_NAtagMCFMTDoubleState.SubCmd))] = m_NAtagMCFMTDoubleState - - -#------------------------------------------------------ -# B2 03 公共副本扫荡信息 #tagMCPubFBSweepData - -class tagMCPubFBSweep(Structure): - _pack_ = 1 - _fields_ = [ - ("Cmd", c_ubyte), - ("SubCmd", c_ubyte), - ("PubNum", c_ubyte), # 公共组编号 - ("FBMapID", c_int), # 当前扫荡的副本地图ID - ("LineID", c_ushort), # lineID - ("SweepTime", c_int), # 开始扫荡的时间 - ("SweepCnt", c_ubyte), # 扫荡次数 - ] - - def __init__(self): - self.Clear() - self.Cmd = 0xB2 - self.SubCmd = 0x03 - 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 = 0xB2 - self.SubCmd = 0x03 - self.PubNum = 0 - self.FBMapID = 0 - self.LineID = 0 - self.SweepTime = 0 - self.SweepCnt = 0 - return - - def GetLength(self): - return sizeof(tagMCPubFBSweep) - - def GetBuffer(self): - return string_at(addressof(self), self.GetLength()) - - def OutputString(self): - DumpString = '''// B2 03 公共副本扫荡信息 //tagMCPubFBSweepData: - Cmd:%s, - SubCmd:%s, - PubNum:%d, - FBMapID:%d, - LineID:%d, - SweepTime:%d, - SweepCnt:%d - '''\ - %( - self.Cmd, - self.SubCmd, - self.PubNum, - self.FBMapID, - self.LineID, - self.SweepTime, - self.SweepCnt - ) - return DumpString - - -class tagMCPubFBSweepData(Structure): - Head = tagHead() - Cnt = 0 #(BYTE Cnt)// 信息数 - SweepDatList = list() #(vector<tagMCPubFBSweep> SweepDatList)// 信息列表 - data = None - - def __init__(self): - self.Clear() - self.Head.Cmd = 0xB2 - self.Head.SubCmd = 0x03 - return - - def ReadData(self, _lpData, _pos=0, _Len=0): - self.Clear() - _pos = self.Head.ReadData(_lpData, _pos) - self.Cnt,_pos = CommFunc.ReadBYTE(_lpData, _pos) - for i in range(self.Cnt): - temSweepDatList = tagMCPubFBSweep() - _pos = temSweepDatList.ReadData(_lpData, _pos) - self.SweepDatList.append(temSweepDatList) - return _pos - - def Clear(self): - self.Head = tagHead() - self.Head.Clear() - self.Head.Cmd = 0xB2 - self.Head.SubCmd = 0x03 - self.Cnt = 0 - self.SweepDatList = list() - return - - def GetLength(self): - length = 0 - length += self.Head.GetLength() - length += 1 - for i in range(self.Cnt): - length += self.SweepDatList[i].GetLength() - - return length - - def GetBuffer(self): - data = '' - data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) - data = CommFunc.WriteBYTE(data, self.Cnt) - for i in range(self.Cnt): - data = CommFunc.WriteString(data, self.SweepDatList[i].GetLength(), self.SweepDatList[i].GetBuffer()) - return data - - def OutputString(self): - DumpString = ''' - Head:%s, - Cnt:%d, - SweepDatList:%s - '''\ - %( - self.Head.OutputString(), - self.Cnt, - "..." - ) - return DumpString - - -m_NAtagMCPubFBSweepData=tagMCPubFBSweepData() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCPubFBSweepData.Head.Cmd,m_NAtagMCPubFBSweepData.Head.SubCmd))] = m_NAtagMCPubFBSweepData - - -#------------------------------------------------------ -# B2 16 开始自定义场景结果 #tagMCStartCustomSceneResult - -class tagMCStartCustomSceneResult(Structure): - _pack_ = 1 - _fields_ = [ - ("Cmd", c_ubyte), - ("SubCmd", c_ubyte), - ("MapID", c_int), - ("FuncLineID", c_ushort), - ("Result", c_ubyte), #是否允许 - ] - - def __init__(self): - self.Clear() - self.Cmd = 0xB2 - self.SubCmd = 0x16 - 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 = 0xB2 - self.SubCmd = 0x16 - self.MapID = 0 - self.FuncLineID = 0 - self.Result = 0 - return - - def GetLength(self): - return sizeof(tagMCStartCustomSceneResult) - - def GetBuffer(self): - return string_at(addressof(self), self.GetLength()) - - def OutputString(self): - DumpString = '''// B2 16 开始自定义场景结果 //tagMCStartCustomSceneResult: - Cmd:%s, - SubCmd:%s, - MapID:%d, - FuncLineID:%d, - Result:%d - '''\ - %( - self.Cmd, - self.SubCmd, - self.MapID, - self.FuncLineID, - self.Result - ) - return DumpString - - -m_NAtagMCStartCustomSceneResult=tagMCStartCustomSceneResult() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCStartCustomSceneResult.Cmd,m_NAtagMCStartCustomSceneResult.SubCmd))] = m_NAtagMCStartCustomSceneResult #------------------------------------------------------ -- Gitblit v1.8.0