From 11fe4059a5f65e1f27d78aa9a8d2a110e8122476 Mon Sep 17 00:00:00 2001 From: xdh <xiefantasy@qq.com> Date: 星期四, 11 四月 2019 19:16:13 +0800 Subject: [PATCH] 6457 【后端】【2.0】缥缈仙域开发单(新增表) --- ServerPython/CoreServerGroup/GameServer/Script/ChPyNetSendPack.py | 298 ++++++++++++++++++++++++++++++++++++++++++++++++----------- 1 files changed, 242 insertions(+), 56 deletions(-) diff --git a/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetSendPack.py b/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetSendPack.py index 59df580..8b7eeae 100644 --- a/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetSendPack.py +++ b/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetSendPack.py @@ -13019,6 +13019,8 @@ _fields_ = [ ("ActionID", c_int), # ID ("DayFinishCnt", c_ushort), # 今日已完成次数 + ("DayBuyTimes", c_ubyte), # 今日购买次数 + ("DayItemTimes", c_ubyte), # 今日物品增加次数 ("WeekFinishCnt", c_int), # 本周已完成次数 ] @@ -13034,6 +13036,8 @@ def Clear(self): self.ActionID = 0 self.DayFinishCnt = 0 + self.DayBuyTimes = 0 + self.DayItemTimes = 0 self.WeekFinishCnt = 0 return @@ -13047,11 +13051,15 @@ DumpString = '''// A3 15 日常活动次数通知 //tagMCDailyActionCnt: ActionID:%d, DayFinishCnt:%d, + DayBuyTimes:%d, + DayItemTimes:%d, WeekFinishCnt:%d '''\ %( self.ActionID, self.DayFinishCnt, + self.DayBuyTimes, + self.DayItemTimes, self.WeekFinishCnt ) return DumpString @@ -13737,6 +13745,240 @@ m_NAtagMCEquipPartXLAttrInfo=tagMCEquipPartXLAttrInfo() ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCEquipPartXLAttrInfo.Head.Cmd,m_NAtagMCEquipPartXLAttrInfo.Head.SubCmd))] = m_NAtagMCEquipPartXLAttrInfo + + +#------------------------------------------------------ +# A3 07 缥缈奇遇信息 #tagMCFairyAdventuresInfo + +class tagMCFairyAdventuresData(Structure): + _pack_ = 1 + _fields_ = [ + ("EventID", c_ubyte), + ("Gear", c_ubyte), #第几档 + ("Condition", 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.EventID = 0 + self.Gear = 0 + self.Condition = 0 + return + + def GetLength(self): + return sizeof(tagMCFairyAdventuresData) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// A3 07 缥缈奇遇信息 //tagMCFairyAdventuresInfo: + EventID:%d, + Gear:%d, + Condition:%d + '''\ + %( + self.EventID, + self.Gear, + self.Condition + ) + return DumpString + + +class tagMCFairyAdventuresInfo(Structure): + Head = tagHead() + Cnt = 0 #(BYTE Cnt) + InfoList = list() #(vector<tagMCFairyAdventuresData> InfoList)// 信息 + data = None + + def __init__(self): + self.Clear() + self.Head.Cmd = 0xA3 + self.Head.SubCmd = 0x07 + 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 = tagMCFairyAdventuresData() + _pos = temInfoList.ReadData(_lpData, _pos) + self.InfoList.append(temInfoList) + return _pos + + def Clear(self): + self.Head = tagHead() + self.Head.Clear() + self.Head.Cmd = 0xA3 + self.Head.SubCmd = 0x07 + 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_NAtagMCFairyAdventuresInfo=tagMCFairyAdventuresInfo() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCFairyAdventuresInfo.Head.Cmd,m_NAtagMCFairyAdventuresInfo.Head.SubCmd))] = m_NAtagMCFairyAdventuresInfo + + +#------------------------------------------------------ +# A3 06 缥缈仙域信息 #tagMCFairyDomainInfo + +class tagMCFairyDomainEvent(Structure): + _pack_ = 1 + _fields_ = [ + ("EventID", c_ushort), #事件ID + ("EventState", c_ubyte), #事件状态 1-可拜访 2-拜访中 3-已拜访 + ] + + 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.EventID = 0 + self.EventState = 0 + return + + def GetLength(self): + return sizeof(tagMCFairyDomainEvent) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// A3 06 缥缈仙域信息 //tagMCFairyDomainInfo: + EventID:%d, + EventState:%d + '''\ + %( + self.EventID, + self.EventState + ) + return DumpString + + +class tagMCFairyDomainInfo(Structure): + Head = tagHead() + State = 0 #(BYTE State)//是否寻访中 + Energy = 0 #(WORD Energy)//体力 + Count = 0 #(BYTE Count)// 信息个数 + InfoList = list() #(vector<tagMCFairyDomainEvent> InfoList)// 信息列表 + data = None + + def __init__(self): + self.Clear() + self.Head.Cmd = 0xA3 + self.Head.SubCmd = 0x06 + return + + def ReadData(self, _lpData, _pos=0, _Len=0): + self.Clear() + _pos = self.Head.ReadData(_lpData, _pos) + self.State,_pos = CommFunc.ReadBYTE(_lpData, _pos) + self.Energy,_pos = CommFunc.ReadWORD(_lpData, _pos) + self.Count,_pos = CommFunc.ReadBYTE(_lpData, _pos) + for i in range(self.Count): + temInfoList = tagMCFairyDomainEvent() + _pos = temInfoList.ReadData(_lpData, _pos) + self.InfoList.append(temInfoList) + return _pos + + def Clear(self): + self.Head = tagHead() + self.Head.Clear() + self.Head.Cmd = 0xA3 + self.Head.SubCmd = 0x06 + self.State = 0 + self.Energy = 0 + self.Count = 0 + self.InfoList = list() + return + + def GetLength(self): + length = 0 + length += self.Head.GetLength() + length += 1 + length += 2 + length += 1 + for i in range(self.Count): + 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.State) + data = CommFunc.WriteWORD(data, self.Energy) + data = CommFunc.WriteBYTE(data, self.Count) + for i in range(self.Count): + data = CommFunc.WriteString(data, self.InfoList[i].GetLength(), self.InfoList[i].GetBuffer()) + return data + + def OutputString(self): + DumpString = ''' + Head:%s, + State:%d, + Energy:%d, + Count:%d, + InfoList:%s + '''\ + %( + self.Head.OutputString(), + self.State, + self.Energy, + self.Count, + "..." + ) + return DumpString + + +m_NAtagMCFairyDomainInfo=tagMCFairyDomainInfo() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCFairyDomainInfo.Head.Cmd,m_NAtagMCFairyDomainInfo.Head.SubCmd))] = m_NAtagMCFairyDomainInfo #------------------------------------------------------ @@ -25700,62 +25942,6 @@ m_NAtagMCBossRebornPlayerInfo=tagMCBossRebornPlayerInfo() ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCBossRebornPlayerInfo.Head.Cmd,m_NAtagMCBossRebornPlayerInfo.Head.SubCmd))] = m_NAtagMCBossRebornPlayerInfo - - -#------------------------------------------------------ -# AB 07 节日活动奖励状态 #tagMCFestivalLoginAwardState - -class tagMCFestivalLoginAwardState(Structure): - _pack_ = 1 - _fields_ = [ - ("Cmd", c_ubyte), - ("SubCmd", c_ubyte), - ("FestivalType", c_ubyte), # 节日类型 - ("State", c_int), # 领取状态 <按位取值,0-未领取 1-可领取 2-已领取> - ] - - def __init__(self): - self.Clear() - self.Cmd = 0xAB - 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 = 0xAB - self.SubCmd = 0x07 - self.FestivalType = 0 - self.State = 0 - return - - def GetLength(self): - return sizeof(tagMCFestivalLoginAwardState) - - def GetBuffer(self): - return string_at(addressof(self), self.GetLength()) - - def OutputString(self): - DumpString = '''// AB 07 节日活动奖励状态 //tagMCFestivalLoginAwardState: - Cmd:%s, - SubCmd:%s, - FestivalType:%d, - State:%d - '''\ - %( - self.Cmd, - self.SubCmd, - self.FestivalType, - self.State - ) - return DumpString - - -m_NAtagMCFestivalLoginAwardState=tagMCFestivalLoginAwardState() -ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCFestivalLoginAwardState.Cmd,m_NAtagMCFestivalLoginAwardState.SubCmd))] = m_NAtagMCFestivalLoginAwardState #------------------------------------------------------ -- Gitblit v1.8.0