From 1ea73e1885835466265ce788d93556b7030ee0e8 Mon Sep 17 00:00:00 2001 From: hxp <ale99527@vip.qq.com> Date: 星期日, 30 十二月 2018 18:42:00 +0800 Subject: [PATCH] 5424 【后端】【1.4】跨服竞技场开发(GM工具增加子服服务器维护,文字翻译版) --- ServerPython/CoreServerGroup/GameServer/Script/ChPyNetSendPack.py | 1610 +++++++++++++---------------------------------------------- 1 files changed, 357 insertions(+), 1,253 deletions(-) diff --git a/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetSendPack.py b/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetSendPack.py index 3d2aed2..864cc01 100644 --- a/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetSendPack.py +++ b/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetSendPack.py @@ -8226,6 +8226,7 @@ Job = 0 #(BYTE Job) LV = 0 #(WORD LV) MaxHP = 0 #(DWORD MaxHP)// 默认满血 + MaxProDef = 0 #(DWORD MaxProDef)// 最大护盾 data = None def __init__(self): @@ -8240,6 +8241,7 @@ self.Job,_pos = CommFunc.ReadBYTE(_lpData, _pos) self.LV,_pos = CommFunc.ReadWORD(_lpData, _pos) self.MaxHP,_pos = CommFunc.ReadDWORD(_lpData, _pos) + self.MaxProDef,_pos = CommFunc.ReadDWORD(_lpData, _pos) return _pos def Clear(self): @@ -8249,6 +8251,7 @@ self.Job = 0 self.LV = 0 self.MaxHP = 0 + self.MaxProDef = 0 return def GetLength(self): @@ -8258,6 +8261,7 @@ length += len(self.PlayerName) length += 1 length += 2 + length += 4 length += 4 return length @@ -8270,6 +8274,7 @@ data = CommFunc.WriteBYTE(data, self.Job) data = CommFunc.WriteWORD(data, self.LV) data = CommFunc.WriteDWORD(data, self.MaxHP) + data = CommFunc.WriteDWORD(data, self.MaxProDef) return data def OutputString(self): @@ -8279,7 +8284,8 @@ PlayerName:%s, Job:%d, LV:%d, - MaxHP:%d + MaxHP:%d, + MaxProDef:%d '''\ %( self.PlayerID, @@ -8287,7 +8293,8 @@ self.PlayerName, self.Job, self.LV, - self.MaxHP + self.MaxHP, + self.MaxProDef ) return DumpString @@ -8297,6 +8304,7 @@ RoomID = 0 #(WORD RoomID)// 房间ID NameLen = 0 #(BYTE NameLen) PlayerName = "" #(String PlayerName)// 跨服名字 + Number = 0 #(BYTE Number)// 位置编号;1-左,2-右 MatchPlayerCount = 0 #(BYTE MatchPlayerCount) MatchPlayer = list() #(vector<tagGCCrossRealmPKMatchPlayer> MatchPlayer)// 匹配到的玩家 data = None @@ -8313,6 +8321,7 @@ self.RoomID,_pos = CommFunc.ReadWORD(_lpData, _pos) self.NameLen,_pos = CommFunc.ReadBYTE(_lpData, _pos) self.PlayerName,_pos = CommFunc.ReadString(_lpData, _pos,self.NameLen) + self.Number,_pos = CommFunc.ReadBYTE(_lpData, _pos) self.MatchPlayerCount,_pos = CommFunc.ReadBYTE(_lpData, _pos) for i in range(self.MatchPlayerCount): temMatchPlayer = tagGCCrossRealmPKMatchPlayer() @@ -8328,6 +8337,7 @@ self.RoomID = 0 self.NameLen = 0 self.PlayerName = "" + self.Number = 0 self.MatchPlayerCount = 0 self.MatchPlayer = list() return @@ -8338,6 +8348,7 @@ length += 2 length += 1 length += len(self.PlayerName) + length += 1 length += 1 for i in range(self.MatchPlayerCount): length += self.MatchPlayer[i].GetLength() @@ -8350,6 +8361,7 @@ data = CommFunc.WriteWORD(data, self.RoomID) data = CommFunc.WriteBYTE(data, self.NameLen) data = CommFunc.WriteString(data, self.NameLen, self.PlayerName) + data = CommFunc.WriteBYTE(data, self.Number) data = CommFunc.WriteBYTE(data, self.MatchPlayerCount) for i in range(self.MatchPlayerCount): data = CommFunc.WriteString(data, self.MatchPlayer[i].GetLength(), self.MatchPlayer[i].GetBuffer()) @@ -8361,6 +8373,7 @@ RoomID:%d, NameLen:%d, PlayerName:%s, + Number:%d, MatchPlayerCount:%d, MatchPlayer:%s '''\ @@ -8369,6 +8382,7 @@ self.RoomID, self.NameLen, self.PlayerName, + self.Number, self.MatchPlayerCount, "..." ) @@ -8510,19 +8524,142 @@ #------------------------------------------------------ -# C0 04 跨服PK赛季信息 #tagGCCrossRealmPKSeason +# C0 04 跨服PK赛区赛季信息 #tagGCCrossRealmPKSeasonInfo class tagGCCrossRealmPKSeason(Structure): - Head = tagHead() - ZoneCount = 0 #(BYTE ZoneCount)// 所有赛区个数 - ZoneIDList = list() #(vector<BYTE> ZoneIDList)// 所有赛区列表 - ZoneID = 0 #(BYTE ZoneID)// 所属赛区ID SeasonID = 0 #(WORD SeasonID)// 当前赛季ID StartDate = "" #(char StartDate[10])// 开始日期 yyyy-MM-dd EndDate = "" #(char EndDate[10])// 结束日期 yyyy-MM-dd EndTime = "" #(char EndTime[5])// 赛季结算时间,赛季奖励该时间后才可领取 hh:mm - NextStartDate = "" #(char NextStartDate[10])// 下赛季开始日期 yyyy-MM-dd - NextEndDate = "" #(char NextEndDate[10])// 下赛季结束日期 yyyy-MM-dd + data = None + + def __init__(self): + self.Clear() + return + + def ReadData(self, _lpData, _pos=0, _Len=0): + self.Clear() + self.SeasonID,_pos = CommFunc.ReadWORD(_lpData, _pos) + self.StartDate,_pos = CommFunc.ReadString(_lpData, _pos,10) + self.EndDate,_pos = CommFunc.ReadString(_lpData, _pos,10) + self.EndTime,_pos = CommFunc.ReadString(_lpData, _pos,5) + return _pos + + def Clear(self): + self.SeasonID = 0 + self.StartDate = "" + self.EndDate = "" + self.EndTime = "" + return + + def GetLength(self): + length = 0 + length += 2 + length += 10 + length += 10 + length += 5 + + return length + + def GetBuffer(self): + data = '' + data = CommFunc.WriteWORD(data, self.SeasonID) + data = CommFunc.WriteString(data, 10, self.StartDate) + data = CommFunc.WriteString(data, 10, self.EndDate) + data = CommFunc.WriteString(data, 5, self.EndTime) + return data + + def OutputString(self): + DumpString = ''' + SeasonID:%d, + StartDate:%s, + EndDate:%s, + EndTime:%s + '''\ + %( + self.SeasonID, + self.StartDate, + self.EndDate, + self.EndTime + ) + return DumpString + + +class tagGCCrossRealmPKZone(Structure): + ZoneID = 0 #(BYTE ZoneID)// 赛区ID + ZoneNameLen = 0 #(BYTE ZoneNameLen) + ZoneName = "" #(String ZoneName)// 赛区名 + SeasonCount = 0 #(WORD SeasonCount) + SeasonList = list() #(vector<tagGCCrossRealmPKSeason> SeasonList)// 赛季列表 + data = None + + def __init__(self): + self.Clear() + return + + def ReadData(self, _lpData, _pos=0, _Len=0): + self.Clear() + self.ZoneID,_pos = CommFunc.ReadBYTE(_lpData, _pos) + self.ZoneNameLen,_pos = CommFunc.ReadBYTE(_lpData, _pos) + self.ZoneName,_pos = CommFunc.ReadString(_lpData, _pos,self.ZoneNameLen) + self.SeasonCount,_pos = CommFunc.ReadWORD(_lpData, _pos) + for i in range(self.SeasonCount): + temSeasonList = tagGCCrossRealmPKSeason() + _pos = temSeasonList.ReadData(_lpData, _pos) + self.SeasonList.append(temSeasonList) + return _pos + + def Clear(self): + self.ZoneID = 0 + self.ZoneNameLen = 0 + self.ZoneName = "" + self.SeasonCount = 0 + self.SeasonList = list() + return + + def GetLength(self): + length = 0 + length += 1 + length += 1 + length += len(self.ZoneName) + length += 2 + for i in range(self.SeasonCount): + length += self.SeasonList[i].GetLength() + + return length + + def GetBuffer(self): + data = '' + data = CommFunc.WriteBYTE(data, self.ZoneID) + data = CommFunc.WriteBYTE(data, self.ZoneNameLen) + data = CommFunc.WriteString(data, self.ZoneNameLen, self.ZoneName) + data = CommFunc.WriteWORD(data, self.SeasonCount) + for i in range(self.SeasonCount): + data = CommFunc.WriteString(data, self.SeasonList[i].GetLength(), self.SeasonList[i].GetBuffer()) + return data + + def OutputString(self): + DumpString = ''' + ZoneID:%d, + ZoneNameLen:%d, + ZoneName:%s, + SeasonCount:%d, + SeasonList:%s + '''\ + %( + self.ZoneID, + self.ZoneNameLen, + self.ZoneName, + self.SeasonCount, + "..." + ) + return DumpString + + +class tagGCCrossRealmPKSeasonInfo(Structure): + Head = tagHead() + ZoneCount = 0 #(BYTE ZoneCount)// 赛区个数 + ZoneList = list() #(vector<tagGCCrossRealmPKZone> ZoneList)// 赛区列表 data = None def __init__(self): @@ -8536,15 +8673,9 @@ _pos = self.Head.ReadData(_lpData, _pos) self.ZoneCount,_pos = CommFunc.ReadBYTE(_lpData, _pos) for i in range(self.ZoneCount): - value,_pos=CommFunc.ReadBYTE(_lpData,_pos) - self.ZoneIDList.append(value) - self.ZoneID,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.SeasonID,_pos = CommFunc.ReadWORD(_lpData, _pos) - self.StartDate,_pos = CommFunc.ReadString(_lpData, _pos,10) - self.EndDate,_pos = CommFunc.ReadString(_lpData, _pos,10) - self.EndTime,_pos = CommFunc.ReadString(_lpData, _pos,5) - self.NextStartDate,_pos = CommFunc.ReadString(_lpData, _pos,10) - self.NextEndDate,_pos = CommFunc.ReadString(_lpData, _pos,10) + temZoneList = tagGCCrossRealmPKZone() + _pos = temZoneList.ReadData(_lpData, _pos) + self.ZoneList.append(temZoneList) return _pos def Clear(self): @@ -8553,28 +8684,15 @@ self.Head.Cmd = 0xC0 self.Head.SubCmd = 0x04 self.ZoneCount = 0 - self.ZoneIDList = list() - self.ZoneID = 0 - self.SeasonID = 0 - self.StartDate = "" - self.EndDate = "" - self.EndTime = "" - self.NextStartDate = "" - self.NextEndDate = "" + self.ZoneList = list() return def GetLength(self): length = 0 length += self.Head.GetLength() length += 1 - length += 1 * self.ZoneCount - length += 1 - length += 2 - length += 10 - length += 10 - length += 5 - length += 10 - length += 10 + for i in range(self.ZoneCount): + length += self.ZoneList[i].GetLength() return length @@ -8583,46 +8701,89 @@ data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) data = CommFunc.WriteBYTE(data, self.ZoneCount) for i in range(self.ZoneCount): - data = CommFunc.WriteBYTE(data, self.ZoneIDList[i]) - data = CommFunc.WriteBYTE(data, self.ZoneID) - data = CommFunc.WriteWORD(data, self.SeasonID) - data = CommFunc.WriteString(data, 10, self.StartDate) - data = CommFunc.WriteString(data, 10, self.EndDate) - data = CommFunc.WriteString(data, 5, self.EndTime) - data = CommFunc.WriteString(data, 10, self.NextStartDate) - data = CommFunc.WriteString(data, 10, self.NextEndDate) + data = CommFunc.WriteString(data, self.ZoneList[i].GetLength(), self.ZoneList[i].GetBuffer()) return data def OutputString(self): DumpString = ''' Head:%s, ZoneCount:%d, - ZoneIDList:%s, - ZoneID:%d, - SeasonID:%d, - StartDate:%s, - EndDate:%s, - EndTime:%s, - NextStartDate:%s, - NextEndDate:%s + ZoneList:%s '''\ %( self.Head.OutputString(), self.ZoneCount, - "...", - self.ZoneID, - self.SeasonID, - self.StartDate, - self.EndDate, - self.EndTime, - self.NextStartDate, - self.NextEndDate + "..." ) return DumpString -m_NAtagGCCrossRealmPKSeason=tagGCCrossRealmPKSeason() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagGCCrossRealmPKSeason.Head.Cmd,m_NAtagGCCrossRealmPKSeason.Head.SubCmd))] = m_NAtagGCCrossRealmPKSeason +m_NAtagGCCrossRealmPKSeasonInfo=tagGCCrossRealmPKSeasonInfo() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagGCCrossRealmPKSeasonInfo.Head.Cmd,m_NAtagGCCrossRealmPKSeasonInfo.Head.SubCmd))] = m_NAtagGCCrossRealmPKSeasonInfo + + +#------------------------------------------------------ +# C0 06 跨服PK本服赛季状态 #tagGCCrossRealmPKSeasonState + +class tagGCCrossRealmPKSeasonState(Structure): + _pack_ = 1 + _fields_ = [ + ("Cmd", c_ubyte), + ("SubCmd", c_ubyte), + ("ZoneID", c_ubyte), # 所属赛区ID + ("SeasonID", c_ushort), # 当前赛季ID + ("SeasonState", c_ubyte), # 赛季状态;0-未开启,1-开启中,2-已结束 + ("MatchState", c_ubyte), # 匹配状态;0-未开启;1-开启中 + ] + + def __init__(self): + self.Clear() + self.Cmd = 0xC0 + 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 = 0xC0 + self.SubCmd = 0x06 + self.ZoneID = 0 + self.SeasonID = 0 + self.SeasonState = 0 + self.MatchState = 0 + return + + def GetLength(self): + return sizeof(tagGCCrossRealmPKSeasonState) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// C0 06 跨服PK本服赛季状态 //tagGCCrossRealmPKSeasonState: + Cmd:%s, + SubCmd:%s, + ZoneID:%d, + SeasonID:%d, + SeasonState:%d, + MatchState:%d + '''\ + %( + self.Cmd, + self.SubCmd, + self.ZoneID, + self.SeasonID, + self.SeasonState, + self.MatchState + ) + return DumpString + + +m_NAtagGCCrossRealmPKSeasonState=tagGCCrossRealmPKSeasonState() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagGCCrossRealmPKSeasonState.Cmd,m_NAtagGCCrossRealmPKSeasonState.SubCmd))] = m_NAtagGCCrossRealmPKSeasonState #------------------------------------------------------ @@ -8671,910 +8832,6 @@ m_NAtagGCCrossRealmPKStartMatch=tagGCCrossRealmPKStartMatch() ChNetPackDict[eval("0x%02x%02x"%(m_NAtagGCCrossRealmPKStartMatch.Cmd,m_NAtagGCCrossRealmPKStartMatch.SubCmd))] = m_NAtagGCCrossRealmPKStartMatch - - -#------------------------------------------------------ -# D1 25 通知可进入跨服王者争霸 #tagCanEnterMergeKing - -class tagCanEnterMergeKing(Structure): - _pack_ = 1 - _fields_ = [ - ("Cmd", c_ubyte), - ("SubCmd", c_ubyte), - ("GroupType", c_ubyte), # 战斗赛事组类型,如16强等 - ] - - def __init__(self): - self.Clear() - self.Cmd = 0xD1 - self.SubCmd = 0x25 - 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 = 0xD1 - self.SubCmd = 0x25 - self.GroupType = 0 - return - - def GetLength(self): - return sizeof(tagCanEnterMergeKing) - - def GetBuffer(self): - return string_at(addressof(self), self.GetLength()) - - def OutputString(self): - DumpString = '''// D1 25 通知可进入跨服王者争霸 //tagCanEnterMergeKing: - Cmd:%s, - SubCmd:%s, - GroupType:%d - '''\ - %( - self.Cmd, - self.SubCmd, - self.GroupType - ) - return DumpString - - -m_NAtagCanEnterMergeKing=tagCanEnterMergeKing() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCanEnterMergeKing.Cmd,m_NAtagCanEnterMergeKing.SubCmd))] = m_NAtagCanEnterMergeKing - - -#------------------------------------------------------ -# D1 24 通知可进入跨服PK匹配 #tagCanEnterMergePK - -class tagCanEnterMergePKMember(Structure): - Head = tagHead() - AccIDLen = 0 #(BYTE AccIDLen) - AccID = "" #(String AccID) - NameLen = 0 #(BYTE NameLen) - PlayerName = "" #(String PlayerName) - Job = 0 #(BYTE Job) - PKCnt = 0 #(DWORD PKCnt)// 已PK次数 - PKCWinCnt = 0 #(DWORD PKCWinCnt)// 当前连胜次数 - Score = 0 #(DWORD Score)// 赛季积分 - DayScore = 0 #(DWORD DayScore)// 当日积分 - PKWinCnt = 0 #(DWORD PKWinCnt)// 累计胜利次数 - MaxCWinCnt = 0 #(DWORD MaxCWinCnt)// 最大连胜次数 - Grade = 0 #(BYTE Grade)// 当前段位 - FightPower = 0 #(DWORD FightPower)// 战斗力 - PlayerLV = 0 #(WORD PlayerLV)// 等级 - MaxHP = 0 #(DWORD MaxHP)// 最大生命值 - data = None - - def __init__(self): - self.Clear() - self.Head.Cmd = 0xD1 - self.Head.SubCmd = 0x24 - return - - def ReadData(self, _lpData, _pos=0, _Len=0): - self.Clear() - _pos = self.Head.ReadData(_lpData, _pos) - self.AccIDLen,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.AccID,_pos = CommFunc.ReadString(_lpData, _pos,self.AccIDLen) - self.NameLen,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.PlayerName,_pos = CommFunc.ReadString(_lpData, _pos,self.NameLen) - self.Job,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.PKCnt,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.PKCWinCnt,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.Score,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.DayScore,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.PKWinCnt,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.MaxCWinCnt,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.Grade,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.FightPower,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.PlayerLV,_pos = CommFunc.ReadWORD(_lpData, _pos) - self.MaxHP,_pos = CommFunc.ReadDWORD(_lpData, _pos) - return _pos - - def Clear(self): - self.Head = tagHead() - self.Head.Clear() - self.Head.Cmd = 0xD1 - self.Head.SubCmd = 0x24 - self.AccIDLen = 0 - self.AccID = "" - self.NameLen = 0 - self.PlayerName = "" - self.Job = 0 - self.PKCnt = 0 - self.PKCWinCnt = 0 - self.Score = 0 - self.DayScore = 0 - self.PKWinCnt = 0 - self.MaxCWinCnt = 0 - self.Grade = 0 - self.FightPower = 0 - self.PlayerLV = 0 - self.MaxHP = 0 - return - - def GetLength(self): - length = 0 - length += self.Head.GetLength() - length += 1 - length += len(self.AccID) - length += 1 - length += len(self.PlayerName) - length += 1 - length += 4 - length += 4 - length += 4 - length += 4 - length += 4 - length += 4 - length += 1 - length += 4 - length += 2 - length += 4 - - return length - - def GetBuffer(self): - data = '' - data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) - data = CommFunc.WriteBYTE(data, self.AccIDLen) - data = CommFunc.WriteString(data, self.AccIDLen, self.AccID) - data = CommFunc.WriteBYTE(data, self.NameLen) - data = CommFunc.WriteString(data, self.NameLen, self.PlayerName) - data = CommFunc.WriteBYTE(data, self.Job) - data = CommFunc.WriteDWORD(data, self.PKCnt) - data = CommFunc.WriteDWORD(data, self.PKCWinCnt) - data = CommFunc.WriteDWORD(data, self.Score) - data = CommFunc.WriteDWORD(data, self.DayScore) - data = CommFunc.WriteDWORD(data, self.PKWinCnt) - data = CommFunc.WriteDWORD(data, self.MaxCWinCnt) - data = CommFunc.WriteBYTE(data, self.Grade) - data = CommFunc.WriteDWORD(data, self.FightPower) - data = CommFunc.WriteWORD(data, self.PlayerLV) - data = CommFunc.WriteDWORD(data, self.MaxHP) - return data - - def OutputString(self): - DumpString = ''' - Head:%s, - AccIDLen:%d, - AccID:%s, - NameLen:%d, - PlayerName:%s, - Job:%d, - PKCnt:%d, - PKCWinCnt:%d, - Score:%d, - DayScore:%d, - PKWinCnt:%d, - MaxCWinCnt:%d, - Grade:%d, - FightPower:%d, - PlayerLV:%d, - MaxHP:%d - '''\ - %( - self.Head.OutputString(), - self.AccIDLen, - self.AccID, - self.NameLen, - self.PlayerName, - self.Job, - self.PKCnt, - self.PKCWinCnt, - self.Score, - self.DayScore, - self.PKWinCnt, - self.MaxCWinCnt, - self.Grade, - self.FightPower, - self.PlayerLV, - self.MaxHP - ) - return DumpString - - -class tagCanEnterMergePK(Structure): - Head = tagHead() - MapID = 0 #(DWORD MapID)// 要进入的地图ID - RoomID = 0 #(DWORD RoomID)// 要进入的房间ID - MemberCnt = 0 #(BYTE MemberCnt)// 对战玩家个数 - MemberList = list() #(vector<tagCanEnterMergePKMember> MemberList)// 对战玩家详细信息 - data = None - - def __init__(self): - self.Clear() - self.Head.Cmd = 0xD1 - self.Head.SubCmd = 0x24 - 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.RoomID,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.MemberCnt,_pos = CommFunc.ReadBYTE(_lpData, _pos) - for i in range(self.MemberCnt): - temMemberList = tagCanEnterMergePKMember() - _pos = temMemberList.ReadData(_lpData, _pos) - self.MemberList.append(temMemberList) - return _pos - - def Clear(self): - self.Head = tagHead() - self.Head.Clear() - self.Head.Cmd = 0xD1 - self.Head.SubCmd = 0x24 - self.MapID = 0 - self.RoomID = 0 - self.MemberCnt = 0 - self.MemberList = list() - return - - def GetLength(self): - length = 0 - length += self.Head.GetLength() - length += 4 - length += 4 - length += 1 - for i in range(self.MemberCnt): - length += self.MemberList[i].GetLength() - - return length - - def GetBuffer(self): - data = '' - data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) - data = CommFunc.WriteDWORD(data, self.MapID) - data = CommFunc.WriteDWORD(data, self.RoomID) - data = CommFunc.WriteBYTE(data, self.MemberCnt) - for i in range(self.MemberCnt): - data = CommFunc.WriteString(data, self.MemberList[i].GetLength(), self.MemberList[i].GetBuffer()) - return data - - def OutputString(self): - DumpString = ''' - Head:%s, - MapID:%d, - RoomID:%d, - MemberCnt:%d, - MemberList:%s - '''\ - %( - self.Head.OutputString(), - self.MapID, - self.RoomID, - self.MemberCnt, - "..." - ) - return DumpString - - -m_NAtagCanEnterMergePK=tagCanEnterMergePK() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCanEnterMergePK.Head.Cmd,m_NAtagCanEnterMergePK.Head.SubCmd))] = m_NAtagCanEnterMergePK - - -#------------------------------------------------------ -# D1 23 通知可进入跨服活动 #tagCanEnterMergeServer - -class tagCanEnterMergeServer(Structure): - Head = tagHead() - ActionType = 0 #(BYTE ActionType)//活动类型 - MapID = 0 #(DWORD MapID)// 登录后在中转地图时要跳转进入的地图ID - LineID = 0 #(DWORD LineID)// 要进入的线路或地图扩展数据 - NewAccIDLen = 0 #(BYTE NewAccIDLen) - NewAccID = "" #(String NewAccID) - NewPswLen = 0 #(BYTE NewPswLen) - NewPsw = "" #(String NewPsw) - data = None - - def __init__(self): - self.Clear() - self.Head.Cmd = 0xD1 - self.Head.SubCmd = 0x23 - return - - def ReadData(self, _lpData, _pos=0, _Len=0): - self.Clear() - _pos = self.Head.ReadData(_lpData, _pos) - self.ActionType,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.MapID,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.LineID,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.NewAccIDLen,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.NewAccID,_pos = CommFunc.ReadString(_lpData, _pos,self.NewAccIDLen) - self.NewPswLen,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.NewPsw,_pos = CommFunc.ReadString(_lpData, _pos,self.NewPswLen) - return _pos - - def Clear(self): - self.Head = tagHead() - self.Head.Clear() - self.Head.Cmd = 0xD1 - self.Head.SubCmd = 0x23 - self.ActionType = 0 - self.MapID = 0 - self.LineID = 0 - self.NewAccIDLen = 0 - self.NewAccID = "" - self.NewPswLen = 0 - self.NewPsw = "" - return - - def GetLength(self): - length = 0 - length += self.Head.GetLength() - length += 1 - length += 4 - length += 4 - length += 1 - length += len(self.NewAccID) - length += 1 - length += len(self.NewPsw) - - return length - - def GetBuffer(self): - data = '' - data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) - data = CommFunc.WriteBYTE(data, self.ActionType) - data = CommFunc.WriteDWORD(data, self.MapID) - data = CommFunc.WriteDWORD(data, self.LineID) - data = CommFunc.WriteBYTE(data, self.NewAccIDLen) - data = CommFunc.WriteString(data, self.NewAccIDLen, self.NewAccID) - data = CommFunc.WriteBYTE(data, self.NewPswLen) - data = CommFunc.WriteString(data, self.NewPswLen, self.NewPsw) - return data - - def OutputString(self): - DumpString = ''' - Head:%s, - ActionType:%d, - MapID:%d, - LineID:%d, - NewAccIDLen:%d, - NewAccID:%s, - NewPswLen:%d, - NewPsw:%s - '''\ - %( - self.Head.OutputString(), - self.ActionType, - self.MapID, - self.LineID, - self.NewAccIDLen, - self.NewAccID, - self.NewPswLen, - self.NewPsw - ) - return DumpString - - -m_NAtagCanEnterMergeServer=tagCanEnterMergeServer() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCanEnterMergeServer.Head.Cmd,m_NAtagCanEnterMergeServer.Head.SubCmd))] = m_NAtagCanEnterMergeServer - - -#------------------------------------------------------ -#D1 08 上传数据查询结果 #tagMergeRegisterQueryResult - -class tagMergeRegisterQueryResult(Structure): - Head = tagHead() - NewAccIDLen = 0 #(BYTE NewAccIDLen) - NewAccID = "" #(String NewAccID) - NewPswLen = 0 #(BYTE NewPswLen) - NewPsw = "" #(String NewPsw) - data = None - - def __init__(self): - self.Clear() - self.Head.Cmd = 0xD1 - self.Head.SubCmd = 0x08 - return - - def ReadData(self, _lpData, _pos=0, _Len=0): - self.Clear() - _pos = self.Head.ReadData(_lpData, _pos) - self.NewAccIDLen,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.NewAccID,_pos = CommFunc.ReadString(_lpData, _pos,self.NewAccIDLen) - self.NewPswLen,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.NewPsw,_pos = CommFunc.ReadString(_lpData, _pos,self.NewPswLen) - return _pos - - def Clear(self): - self.Head = tagHead() - self.Head.Clear() - self.Head.Cmd = 0xD1 - self.Head.SubCmd = 0x08 - self.NewAccIDLen = 0 - self.NewAccID = "" - self.NewPswLen = 0 - self.NewPsw = "" - return - - def GetLength(self): - length = 0 - length += self.Head.GetLength() - length += 1 - length += len(self.NewAccID) - length += 1 - length += len(self.NewPsw) - - return length - - def GetBuffer(self): - data = '' - data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) - data = CommFunc.WriteBYTE(data, self.NewAccIDLen) - data = CommFunc.WriteString(data, self.NewAccIDLen, self.NewAccID) - data = CommFunc.WriteBYTE(data, self.NewPswLen) - data = CommFunc.WriteString(data, self.NewPswLen, self.NewPsw) - return data - - def OutputString(self): - DumpString = ''' - Head:%s, - NewAccIDLen:%d, - NewAccID:%s, - NewPswLen:%d, - NewPsw:%s - '''\ - %( - self.Head.OutputString(), - self.NewAccIDLen, - self.NewAccID, - self.NewPswLen, - self.NewPsw - ) - return DumpString - - -m_NAtagMergeRegisterQueryResult=tagMergeRegisterQueryResult() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMergeRegisterQueryResult.Head.Cmd,m_NAtagMergeRegisterQueryResult.Head.SubCmd))] = m_NAtagMergeRegisterQueryResult - - -#------------------------------------------------------ -#D1 16 跨服赛服务器信息 #tagMergeServerInfo - -class tagMergeServerInfo(Structure): - Head = tagHead() - ServerIPLen = 0 #(BYTE ServerIPLen) - ServerIP = "" #(String ServerIP) - Port = 0 #(DWORD Port) - IsMergeServer = 0 #(BYTE IsMergeServer) - data = None - - def __init__(self): - self.Clear() - self.Head.Cmd = 0xD1 - self.Head.SubCmd = 0x16 - return - - def ReadData(self, _lpData, _pos=0, _Len=0): - self.Clear() - _pos = self.Head.ReadData(_lpData, _pos) - self.ServerIPLen,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.ServerIP,_pos = CommFunc.ReadString(_lpData, _pos,self.ServerIPLen) - self.Port,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.IsMergeServer,_pos = CommFunc.ReadBYTE(_lpData, _pos) - return _pos - - def Clear(self): - self.Head = tagHead() - self.Head.Clear() - self.Head.Cmd = 0xD1 - self.Head.SubCmd = 0x16 - self.ServerIPLen = 0 - self.ServerIP = "" - self.Port = 0 - self.IsMergeServer = 0 - return - - def GetLength(self): - length = 0 - length += self.Head.GetLength() - length += 1 - length += len(self.ServerIP) - length += 4 - length += 1 - - return length - - def GetBuffer(self): - data = '' - data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) - data = CommFunc.WriteBYTE(data, self.ServerIPLen) - data = CommFunc.WriteString(data, self.ServerIPLen, self.ServerIP) - data = CommFunc.WriteDWORD(data, self.Port) - data = CommFunc.WriteBYTE(data, self.IsMergeServer) - return data - - def OutputString(self): - DumpString = ''' - Head:%s, - ServerIPLen:%d, - ServerIP:%s, - Port:%d, - IsMergeServer:%d - '''\ - %( - self.Head.OutputString(), - self.ServerIPLen, - self.ServerIP, - self.Port, - self.IsMergeServer - ) - return DumpString - - -m_NAtagMergeServerInfo=tagMergeServerInfo() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMergeServerInfo.Head.Cmd,m_NAtagMergeServerInfo.Head.SubCmd))] = m_NAtagMergeServerInfo - - -#------------------------------------------------------ -# D1 27 通知跨服PK战斗结果 #tagMergePKOverInfo - -class tagMergePKOver(Structure): - TimeLen = 0 #(BYTE TimeLen) - TimeStr = "" #(String TimeStr)// yyyy-MM-dd HH:mm:ss - RoomID = 0 #(DWORD RoomID) - OverType = 0 #(BYTE OverType) - RemainTime = 0 #(DWORD RemainTime) - WinnerAccIDLen = 0 #(BYTE WinnerAccIDLen) - WinnerAccID = "" #(String WinnerAccID) - LoserAccIDLen = 0 #(BYTE LoserAccIDLen) - LoserAccID = "" #(String LoserAccID) - WinnerID = 0 #(DWORD WinnerID) - LoserID = 0 #(DWORD LoserID) - WinnerNameLen = 0 #(BYTE WinnerNameLen) - WinnerName = "" #(String WinnerName) - LoserNameLen = 0 #(BYTE LoserNameLen) - LoserName = "" #(String LoserName) - WinnerAddScore = 0 #(WORD WinnerAddScore) - LoserAddScoreLen = 0 #(BYTE LoserAddScoreLen) - LoserAddScore = "" #(String LoserAddScore)// 失败附加分,支持负值 - WinnerWinCnt = 0 #(BYTE WinnerWinCnt)// 比分获胜方获胜次数 - LoserWinCnt = 0 #(BYTE LoserWinCnt)// 比分失败方获胜次数 - WinnerCWinCnt = 0 #(WORD WinnerCWinCnt)// 获胜者连胜数 - LuckyItemID = 0 #(DWORD LuckyItemID) - data = None - - def __init__(self): - self.Clear() - return - - def ReadData(self, _lpData, _pos=0, _Len=0): - self.Clear() - self.TimeLen,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.TimeStr,_pos = CommFunc.ReadString(_lpData, _pos,self.TimeLen) - self.RoomID,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.OverType,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.RemainTime,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.WinnerAccIDLen,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.WinnerAccID,_pos = CommFunc.ReadString(_lpData, _pos,self.WinnerAccIDLen) - self.LoserAccIDLen,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.LoserAccID,_pos = CommFunc.ReadString(_lpData, _pos,self.LoserAccIDLen) - self.WinnerID,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.LoserID,_pos = CommFunc.ReadDWORD(_lpData, _pos) - self.WinnerNameLen,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.WinnerName,_pos = CommFunc.ReadString(_lpData, _pos,self.WinnerNameLen) - self.LoserNameLen,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.LoserName,_pos = CommFunc.ReadString(_lpData, _pos,self.LoserNameLen) - self.WinnerAddScore,_pos = CommFunc.ReadWORD(_lpData, _pos) - self.LoserAddScoreLen,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.LoserAddScore,_pos = CommFunc.ReadString(_lpData, _pos,self.LoserAddScoreLen) - self.WinnerWinCnt,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.LoserWinCnt,_pos = CommFunc.ReadBYTE(_lpData, _pos) - self.WinnerCWinCnt,_pos = CommFunc.ReadWORD(_lpData, _pos) - self.LuckyItemID,_pos = CommFunc.ReadDWORD(_lpData, _pos) - return _pos - - def Clear(self): - self.TimeLen = 0 - self.TimeStr = "" - self.RoomID = 0 - self.OverType = 0 - self.RemainTime = 0 - self.WinnerAccIDLen = 0 - self.WinnerAccID = "" - self.LoserAccIDLen = 0 - self.LoserAccID = "" - self.WinnerID = 0 - self.LoserID = 0 - self.WinnerNameLen = 0 - self.WinnerName = "" - self.LoserNameLen = 0 - self.LoserName = "" - self.WinnerAddScore = 0 - self.LoserAddScoreLen = 0 - self.LoserAddScore = "" - self.WinnerWinCnt = 0 - self.LoserWinCnt = 0 - self.WinnerCWinCnt = 0 - self.LuckyItemID = 0 - return - - def GetLength(self): - length = 0 - length += 1 - length += len(self.TimeStr) - length += 4 - length += 1 - length += 4 - length += 1 - length += len(self.WinnerAccID) - length += 1 - length += len(self.LoserAccID) - length += 4 - length += 4 - length += 1 - length += len(self.WinnerName) - length += 1 - length += len(self.LoserName) - length += 2 - length += 1 - length += len(self.LoserAddScore) - length += 1 - length += 1 - length += 2 - length += 4 - - return length - - def GetBuffer(self): - data = '' - data = CommFunc.WriteBYTE(data, self.TimeLen) - data = CommFunc.WriteString(data, self.TimeLen, self.TimeStr) - data = CommFunc.WriteDWORD(data, self.RoomID) - data = CommFunc.WriteBYTE(data, self.OverType) - data = CommFunc.WriteDWORD(data, self.RemainTime) - data = CommFunc.WriteBYTE(data, self.WinnerAccIDLen) - data = CommFunc.WriteString(data, self.WinnerAccIDLen, self.WinnerAccID) - data = CommFunc.WriteBYTE(data, self.LoserAccIDLen) - data = CommFunc.WriteString(data, self.LoserAccIDLen, self.LoserAccID) - data = CommFunc.WriteDWORD(data, self.WinnerID) - data = CommFunc.WriteDWORD(data, self.LoserID) - data = CommFunc.WriteBYTE(data, self.WinnerNameLen) - data = CommFunc.WriteString(data, self.WinnerNameLen, self.WinnerName) - data = CommFunc.WriteBYTE(data, self.LoserNameLen) - data = CommFunc.WriteString(data, self.LoserNameLen, self.LoserName) - data = CommFunc.WriteWORD(data, self.WinnerAddScore) - data = CommFunc.WriteBYTE(data, self.LoserAddScoreLen) - data = CommFunc.WriteString(data, self.LoserAddScoreLen, self.LoserAddScore) - data = CommFunc.WriteBYTE(data, self.WinnerWinCnt) - data = CommFunc.WriteBYTE(data, self.LoserWinCnt) - data = CommFunc.WriteWORD(data, self.WinnerCWinCnt) - data = CommFunc.WriteDWORD(data, self.LuckyItemID) - return data - - def OutputString(self): - DumpString = ''' - TimeLen:%d, - TimeStr:%s, - RoomID:%d, - OverType:%d, - RemainTime:%d, - WinnerAccIDLen:%d, - WinnerAccID:%s, - LoserAccIDLen:%d, - LoserAccID:%s, - WinnerID:%d, - LoserID:%d, - WinnerNameLen:%d, - WinnerName:%s, - LoserNameLen:%d, - LoserName:%s, - WinnerAddScore:%d, - LoserAddScoreLen:%d, - LoserAddScore:%s, - WinnerWinCnt:%d, - LoserWinCnt:%d, - WinnerCWinCnt:%d, - LuckyItemID:%d - '''\ - %( - self.TimeLen, - self.TimeStr, - self.RoomID, - self.OverType, - self.RemainTime, - self.WinnerAccIDLen, - self.WinnerAccID, - self.LoserAccIDLen, - self.LoserAccID, - self.WinnerID, - self.LoserID, - self.WinnerNameLen, - self.WinnerName, - self.LoserNameLen, - self.LoserName, - self.WinnerAddScore, - self.LoserAddScoreLen, - self.LoserAddScore, - self.WinnerWinCnt, - self.LoserWinCnt, - self.WinnerCWinCnt, - self.LuckyItemID - ) - return DumpString - - -class tagMergePKOverInfo(Structure): - Head = tagHead() - Count = 0 #(BYTE Count) - PKOverList = list() #(vector<tagMergePKOver> PKOverList) - data = None - - def __init__(self): - self.Clear() - self.Head.Cmd = 0xD1 - self.Head.SubCmd = 0x27 - 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): - temPKOverList = tagMergePKOver() - _pos = temPKOverList.ReadData(_lpData, _pos) - self.PKOverList.append(temPKOverList) - return _pos - - def Clear(self): - self.Head = tagHead() - self.Head.Clear() - self.Head.Cmd = 0xD1 - self.Head.SubCmd = 0x27 - self.Count = 0 - self.PKOverList = list() - return - - def GetLength(self): - length = 0 - length += self.Head.GetLength() - length += 1 - for i in range(self.Count): - length += self.PKOverList[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.PKOverList[i].GetLength(), self.PKOverList[i].GetBuffer()) - return data - - def OutputString(self): - DumpString = ''' - Head:%s, - Count:%d, - PKOverList:%s - '''\ - %( - self.Head.OutputString(), - self.Count, - "..." - ) - return DumpString - - -m_NAtagMergePKOverInfo=tagMergePKOverInfo() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMergePKOverInfo.Head.Cmd,m_NAtagMergePKOverInfo.Head.SubCmd))] = m_NAtagMergePKOverInfo - - -#------------------------------------------------------ -# D1 28 跨服PK赛季信息 #tagGCMergePKSeasonInfo - -class tagGCMergePKSeasonInfo(Structure): - _pack_ = 1 - _fields_ = [ - ("Cmd", c_ubyte), - ("SubCmd", c_ubyte), - ("SeasonID", c_int), # 赛季ID - ("SeasonStartTime", c_int), # 赛季开始时间 - ("SeasonCycle", c_ubyte), # 赛季周期天数 - ("IsSeasonEnd", c_ubyte), # 赛季是否结束 - ] - - def __init__(self): - self.Clear() - self.Cmd = 0xD1 - 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 = 0xD1 - self.SubCmd = 0x28 - self.SeasonID = 0 - self.SeasonStartTime = 0 - self.SeasonCycle = 0 - self.IsSeasonEnd = 0 - return - - def GetLength(self): - return sizeof(tagGCMergePKSeasonInfo) - - def GetBuffer(self): - return string_at(addressof(self), self.GetLength()) - - def OutputString(self): - DumpString = '''// D1 28 跨服PK赛季信息 //tagGCMergePKSeasonInfo: - Cmd:%s, - SubCmd:%s, - SeasonID:%d, - SeasonStartTime:%d, - SeasonCycle:%d, - IsSeasonEnd:%d - '''\ - %( - self.Cmd, - self.SubCmd, - self.SeasonID, - self.SeasonStartTime, - self.SeasonCycle, - self.IsSeasonEnd - ) - return DumpString - - -m_NAtagGCMergePKSeasonInfo=tagGCMergePKSeasonInfo() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagGCMergePKSeasonInfo.Cmd,m_NAtagGCMergePKSeasonInfo.SubCmd))] = m_NAtagGCMergePKSeasonInfo - - -#------------------------------------------------------ -# D1 26 通知跨服PK续胜结果 #tagRecoverMergePKWinOK - -class tagRecoverMergePKWinOK(Structure): - _pack_ = 1 - _fields_ = [ - ("Cmd", c_ubyte), - ("SubCmd", c_ubyte), - ] - - def __init__(self): - self.Clear() - self.Cmd = 0xD1 - self.SubCmd = 0x26 - 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 = 0xD1 - self.SubCmd = 0x26 - return - - def GetLength(self): - return sizeof(tagRecoverMergePKWinOK) - - def GetBuffer(self): - return string_at(addressof(self), self.GetLength()) - - def OutputString(self): - DumpString = '''// D1 26 通知跨服PK续胜结果 //tagRecoverMergePKWinOK: - Cmd:%s, - SubCmd:%s - '''\ - %( - self.Cmd, - self.SubCmd - ) - return DumpString - - -m_NAtagRecoverMergePKWinOK=tagRecoverMergePKWinOK() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagRecoverMergePKWinOK.Cmd,m_NAtagRecoverMergePKWinOK.SubCmd))] = m_NAtagRecoverMergePKWinOK #------------------------------------------------------ @@ -13411,6 +12668,7 @@ ("Exp", c_int), ("State", c_ubyte), #是否点击法宝认主 ("FBPassLV", c_ubyte), #副本关卡 + ("IsWear", c_ubyte), #是否佩戴(仅适用王者法宝) ] def __init__(self): @@ -13428,6 +12686,7 @@ self.Exp = 0 self.State = 0 self.FBPassLV = 0 + self.IsWear = 0 return def GetLength(self): @@ -13442,14 +12701,16 @@ LV:%d, Exp:%d, State:%d, - FBPassLV:%d + FBPassLV:%d, + IsWear:%d '''\ %( self.MWID, self.LV, self.Exp, self.State, - self.FBPassLV + self.FBPassLV, + self.IsWear ) return DumpString @@ -18808,6 +18069,7 @@ ItemData = "" #(String ItemData)//物品记录 PlusDataSize = 0 #(DWORD PlusDataSize) PlusData = "" #(String PlusData)//扩展记录 + CrossPlayer = 0 #(BYTE CrossPlayer)//是否跨服玩家 data = None def __init__(self): @@ -18826,6 +18088,7 @@ self.ItemData,_pos = CommFunc.ReadString(_lpData, _pos,self.ItemDataSize) self.PlusDataSize,_pos = CommFunc.ReadDWORD(_lpData, _pos) self.PlusData,_pos = CommFunc.ReadString(_lpData, _pos,self.PlusDataSize) + self.CrossPlayer,_pos = CommFunc.ReadBYTE(_lpData, _pos) return _pos def Clear(self): @@ -18840,6 +18103,7 @@ self.ItemData = "" self.PlusDataSize = 0 self.PlusData = "" + self.CrossPlayer = 0 return def GetLength(self): @@ -18852,6 +18116,7 @@ length += len(self.ItemData) length += 4 length += len(self.PlusData) + length += 1 return length @@ -18865,6 +18130,7 @@ data = CommFunc.WriteString(data, self.ItemDataSize, self.ItemData) data = CommFunc.WriteDWORD(data, self.PlusDataSize) data = CommFunc.WriteString(data, self.PlusDataSize, self.PlusData) + data = CommFunc.WriteBYTE(data, self.CrossPlayer) return data def OutputString(self): @@ -18876,7 +18142,8 @@ ItemDataSize:%d, ItemData:%s, PlusDataSize:%d, - PlusData:%s + PlusData:%s, + CrossPlayer:%d '''\ %( self.Head.OutputString(), @@ -18886,7 +18153,8 @@ self.ItemDataSize, self.ItemData, self.PlusDataSize, - self.PlusData + self.PlusData, + self.CrossPlayer ) return DumpString @@ -27579,6 +26847,126 @@ #------------------------------------------------------ +# C1 03 跨服PK玩家历史赛季信息 #tagMCCrossRealmPKPlayerHisSeasonInfo + +class tagMCCrossRealmPKPlayerHisSeason(Structure): + _pack_ = 1 + _fields_ = [ + ("SeasonID", c_ushort), # 赛季ID + ("Order", c_ushort), # 名次 + ("DanLV", c_ubyte), # 段位 + ("Score", c_int), # 积分 + ("AwardLV", 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.SeasonID = 0 + self.Order = 0 + self.DanLV = 0 + self.Score = 0 + self.AwardLV = 0 + return + + def GetLength(self): + return sizeof(tagMCCrossRealmPKPlayerHisSeason) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// C1 03 跨服PK玩家历史赛季信息 //tagMCCrossRealmPKPlayerHisSeasonInfo: + SeasonID:%d, + Order:%d, + DanLV:%d, + Score:%d, + AwardLV:%d + '''\ + %( + self.SeasonID, + self.Order, + self.DanLV, + self.Score, + self.AwardLV + ) + return DumpString + + +class tagMCCrossRealmPKPlayerHisSeasonInfo(Structure): + Head = tagHead() + Count = 0 #(WORD Count)// 赛季个数 + SeasonList = list() #(vector<tagMCCrossRealmPKPlayerHisSeason> SeasonList)// 赛季信息列表 + data = None + + def __init__(self): + self.Clear() + self.Head.Cmd = 0xC1 + self.Head.SubCmd = 0x03 + return + + def ReadData(self, _lpData, _pos=0, _Len=0): + self.Clear() + _pos = self.Head.ReadData(_lpData, _pos) + self.Count,_pos = CommFunc.ReadWORD(_lpData, _pos) + for i in range(self.Count): + temSeasonList = tagMCCrossRealmPKPlayerHisSeason() + _pos = temSeasonList.ReadData(_lpData, _pos) + self.SeasonList.append(temSeasonList) + return _pos + + def Clear(self): + self.Head = tagHead() + self.Head.Clear() + self.Head.Cmd = 0xC1 + self.Head.SubCmd = 0x03 + self.Count = 0 + self.SeasonList = list() + return + + def GetLength(self): + length = 0 + length += self.Head.GetLength() + length += 2 + for i in range(self.Count): + length += self.SeasonList[i].GetLength() + + return length + + def GetBuffer(self): + data = '' + data = CommFunc.WriteString(data, self.Head.GetLength(), self.Head.GetBuffer()) + data = CommFunc.WriteWORD(data, self.Count) + for i in range(self.Count): + data = CommFunc.WriteString(data, self.SeasonList[i].GetLength(), self.SeasonList[i].GetBuffer()) + return data + + def OutputString(self): + DumpString = ''' + Head:%s, + Count:%d, + SeasonList:%s + '''\ + %( + self.Head.OutputString(), + self.Count, + "..." + ) + return DumpString + + +m_NAtagMCCrossRealmPKPlayerHisSeasonInfo=tagMCCrossRealmPKPlayerHisSeasonInfo() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCCrossRealmPKPlayerHisSeasonInfo.Head.Cmd,m_NAtagMCCrossRealmPKPlayerHisSeasonInfo.Head.SubCmd))] = m_NAtagMCCrossRealmPKPlayerHisSeasonInfo + + +#------------------------------------------------------ # C1 01 跨服PK玩家信息 #tagMCCrossRealmPKPlayerInfo class tagMCCrossRealmPKPlayerInfo(Structure): @@ -27655,288 +27043,4 @@ m_NAtagMCCrossRealmPKPlayerInfo=tagMCCrossRealmPKPlayerInfo() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCCrossRealmPKPlayerInfo.Cmd,m_NAtagMCCrossRealmPKPlayerInfo.SubCmd))] = m_NAtagMCCrossRealmPKPlayerInfo - - -#------------------------------------------------------ -#D2 01 跨服赛报名(上传数据)状态 #tagMergeWarRegisterState - -class tagMergeWarRegisterState(Structure): - _pack_ = 1 - _fields_ = [ - ("Cmd", c_ubyte), - ("SubCmd", c_ubyte), - ("RegisterState", c_ubyte), - ] - - def __init__(self): - self.Clear() - self.Cmd = 0xD2 - self.SubCmd = 0x01 - 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 = 0xD2 - self.SubCmd = 0x01 - self.RegisterState = 0 - return - - def GetLength(self): - return sizeof(tagMergeWarRegisterState) - - def GetBuffer(self): - return string_at(addressof(self), self.GetLength()) - - def OutputString(self): - DumpString = '''//D2 01 跨服赛报名(上传数据)状态 //tagMergeWarRegisterState: - Cmd:%s, - SubCmd:%s, - RegisterState:%d - '''\ - %( - self.Cmd, - self.SubCmd, - self.RegisterState - ) - return DumpString - - -m_NAtagMergeWarRegisterState=tagMergeWarRegisterState() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMergeWarRegisterState.Cmd,m_NAtagMergeWarRegisterState.SubCmd))] = m_NAtagMergeWarRegisterState - - -#------------------------------------------------------ -# D2 09 跨服boss奖励领奖状态 #tagMCMergeBossAwardRecord - -class tagMCMergeBossAwardRecord(Structure): - _pack_ = 1 - _fields_ = [ - ("Cmd", c_ubyte), - ("SubCmd", c_ubyte), - ("FirstJoinAwardState", c_ubyte), # 首次参与奖励状态;0-不可领,1-可领,2-已领 - ] - - def __init__(self): - self.Clear() - self.Cmd = 0xD2 - self.SubCmd = 0x09 - 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 = 0xD2 - self.SubCmd = 0x09 - self.FirstJoinAwardState = 0 - return - - def GetLength(self): - return sizeof(tagMCMergeBossAwardRecord) - - def GetBuffer(self): - return string_at(addressof(self), self.GetLength()) - - def OutputString(self): - DumpString = '''// D2 09 跨服boss奖励领奖状态 //tagMCMergeBossAwardRecord: - Cmd:%s, - SubCmd:%s, - FirstJoinAwardState:%d - '''\ - %( - self.Cmd, - self.SubCmd, - self.FirstJoinAwardState - ) - return DumpString - - -m_NAtagMCMergeBossAwardRecord=tagMCMergeBossAwardRecord() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCMergeBossAwardRecord.Cmd,m_NAtagMCMergeBossAwardRecord.SubCmd))] = m_NAtagMCMergeBossAwardRecord - - -#------------------------------------------------------ -# D2 07 跨服王者争霸奖励相关 #tagMCMergeKingAwardInfo - -class tagMCMergeKingAwardInfo(Structure): - _pack_ = 1 - _fields_ = [ - ("Cmd", c_ubyte), - ("SubCmd", c_ubyte), - ("ServerHonour", c_ubyte), # 全服荣耀值, 1 2 4 8等 - ("ServerHonourAward", c_ubyte), # 全服荣耀奖励是否已领取, 0否1是 - ("RankAward", c_ubyte), # 晋级排名奖励是否已领取, 0否1是 - ("SupportAward", c_int), # 竞猜积分奖励领取记录,按位表示 - ("WorshipState", c_ubyte), # 今日是否已膜拜, 0否1是 - ] - - def __init__(self): - self.Clear() - self.Cmd = 0xD2 - 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 = 0xD2 - self.SubCmd = 0x07 - self.ServerHonour = 0 - self.ServerHonourAward = 0 - self.RankAward = 0 - self.SupportAward = 0 - self.WorshipState = 0 - return - - def GetLength(self): - return sizeof(tagMCMergeKingAwardInfo) - - def GetBuffer(self): - return string_at(addressof(self), self.GetLength()) - - def OutputString(self): - DumpString = '''// D2 07 跨服王者争霸奖励相关 //tagMCMergeKingAwardInfo: - Cmd:%s, - SubCmd:%s, - ServerHonour:%d, - ServerHonourAward:%d, - RankAward:%d, - SupportAward:%d, - WorshipState:%d - '''\ - %( - self.Cmd, - self.SubCmd, - self.ServerHonour, - self.ServerHonourAward, - self.RankAward, - self.SupportAward, - self.WorshipState - ) - return DumpString - - -m_NAtagMCMergeKingAwardInfo=tagMCMergeKingAwardInfo() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCMergeKingAwardInfo.Cmd,m_NAtagMCMergeKingAwardInfo.SubCmd))] = m_NAtagMCMergeKingAwardInfo - - -#------------------------------------------------------ -# D2 08 跨服PK奖励领奖记录 #tagMCMergePKAwardRecord - -class tagMCMergePKAwardRecord(Structure): - _pack_ = 1 - _fields_ = [ - ("Cmd", c_ubyte), - ("SubCmd", c_ubyte), - ("FirstWinAwardRecord", c_int), # 首次胜利奖励记录, 按位存储是否已领 - ] - - def __init__(self): - self.Clear() - self.Cmd = 0xD2 - self.SubCmd = 0x08 - 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 = 0xD2 - self.SubCmd = 0x08 - self.FirstWinAwardRecord = 0 - return - - def GetLength(self): - return sizeof(tagMCMergePKAwardRecord) - - def GetBuffer(self): - return string_at(addressof(self), self.GetLength()) - - def OutputString(self): - DumpString = '''// D2 08 跨服PK奖励领奖记录 //tagMCMergePKAwardRecord: - Cmd:%s, - SubCmd:%s, - FirstWinAwardRecord:%d - '''\ - %( - self.Cmd, - self.SubCmd, - self.FirstWinAwardRecord - ) - return DumpString - - -m_NAtagMCMergePKAwardRecord=tagMCMergePKAwardRecord() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCMergePKAwardRecord.Cmd,m_NAtagMCMergePKAwardRecord.SubCmd))] = m_NAtagMCMergePKAwardRecord - - -#------------------------------------------------------ -# D2 06 跨服PK次数通知 #tagMCMergePKCnt - -class tagMCMergePKCnt(Structure): - _pack_ = 1 - _fields_ = [ - ("Cmd", c_ubyte), - ("SubCmd", c_ubyte), - ("DayPKCnt", c_ushort), # 当日已PK次数 - ("DayBuyCnt", c_ushort), # 当日已购买次数 - ("UnUsedBuyCnt", c_ushort), # 未使用的购买次数 - ] - - def __init__(self): - self.Clear() - self.Cmd = 0xD2 - 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 = 0xD2 - self.SubCmd = 0x06 - self.DayPKCnt = 0 - self.DayBuyCnt = 0 - self.UnUsedBuyCnt = 0 - return - - def GetLength(self): - return sizeof(tagMCMergePKCnt) - - def GetBuffer(self): - return string_at(addressof(self), self.GetLength()) - - def OutputString(self): - DumpString = '''// D2 06 跨服PK次数通知 //tagMCMergePKCnt: - Cmd:%s, - SubCmd:%s, - DayPKCnt:%d, - DayBuyCnt:%d, - UnUsedBuyCnt:%d - '''\ - %( - self.Cmd, - self.SubCmd, - self.DayPKCnt, - self.DayBuyCnt, - self.UnUsedBuyCnt - ) - return DumpString - - -m_NAtagMCMergePKCnt=tagMCMergePKCnt() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCMergePKCnt.Cmd,m_NAtagMCMergePKCnt.SubCmd))] = m_NAtagMCMergePKCnt \ No newline at end of file +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCCrossRealmPKPlayerInfo.Cmd,m_NAtagMCCrossRealmPKPlayerInfo.SubCmd))] = m_NAtagMCCrossRealmPKPlayerInfo \ No newline at end of file -- Gitblit v1.8.0