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 | 601 ++++++++++++++++++++++++------------------------------ 1 files changed, 267 insertions(+), 334 deletions(-) diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/ChPyNetSendPack.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/ChPyNetSendPack.py index 45da1bb..dafb1ce 100644 --- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/ChPyNetSendPack.py +++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/ChPyNetSendPack.py @@ -3849,114 +3849,6 @@ #------------------------------------------------------ -# 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 - - -#------------------------------------------------------ # A3 B0 玩家购买魔魂铜钱经验额外奖励信息 #tagMCBuySomethingReward class tagMCBuySomethingReward(Structure): @@ -5367,6 +5259,165 @@ m_NAtagMCFaQiInfo=tagMCFaQiInfo() ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCFaQiInfo.Cmd,m_NAtagMCFaQiInfo.SubCmd))] = m_NAtagMCFaQiInfo + + +#------------------------------------------------------ +# A3 20 玩家副本相关信息 #tagSCFBInfoList + +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, _lpData, _pos=0, _Len=0): + self.Clear() + 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.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): + 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): + 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 = ''' + MapID:%d, + EnterCnt:%d, + ADAddCnt:%d, + BuyAddCnt:%d, + ItemAddCnt:%d, + PassLineID:%d, + PassGradeCnt:%d, + PassGrade:%s + '''\ + %( + self.MapID, + self.EnterCnt, + self.ADAddCnt, + self.BuyAddCnt, + self.ItemAddCnt, + self.PassLineID, + self.PassGradeCnt, + "..." + ) + return DumpString + + +class tagSCFBInfoList(Structure): + Head = tagHead() + FBDataCnt = 0 #(BYTE FBDataCnt)// 副本数据个数 + FBDataList = list() #(vector<tagSCFBInfo> 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 = 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 = 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_NAtagSCFBInfoList=tagSCFBInfoList() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagSCFBInfoList.Head.Cmd,m_NAtagSCFBInfoList.Head.SubCmd))] = m_NAtagSCFBInfoList #------------------------------------------------------ @@ -8186,165 +8237,6 @@ m_NAtagMCPackDownloadRecord=tagMCPackDownloadRecord() ChNetPackDict[eval("0x%02x%02x"%(m_NAtagMCPackDownloadRecord.Cmd,m_NAtagMCPackDownloadRecord.SubCmd))] = m_NAtagMCPackDownloadRecord - - -#------------------------------------------------------ -# 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 #------------------------------------------------------ @@ -15327,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): @@ -17392,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 #------------------------------------------------------ -- Gitblit v1.8.0