From f3aa003e00d2111fc321ac182e1360b3bb11b2af Mon Sep 17 00:00:00 2001 From: hch <305670599@qq.com> Date: 星期五, 23 十一月 2018 23:41:38 +0800 Subject: [PATCH] 4997 【后端】【1.3】冰晶矿脉AI--添加全图搜索逻辑 --- ServerPython/CoreServerGroup/GameServer/Script/ChPyNetPack.py | 221 +++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 215 insertions(+), 6 deletions(-) diff --git a/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetPack.py b/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetPack.py index bd72882..09463a3 100644 --- a/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetPack.py +++ b/ServerPython/CoreServerGroup/GameServer/Script/ChPyNetPack.py @@ -4755,6 +4755,58 @@ #------------------------------------------------------ +# A2 30 设置聊天气泡框 #tagCMSetChatBubbleBox + +class tagCMSetChatBubbleBox(Structure): + _pack_ = 1 + _fields_ = [ + ("Cmd", c_ubyte), + ("SubCmd", c_ubyte), + ("BubbleBoxType", c_ubyte), #气泡框类型 + ] + + def __init__(self): + self.Clear() + self.Cmd = 0xA2 + self.SubCmd = 0x30 + return + + def ReadData(self, stringData, _pos=0, _len=0): + self.Clear() + memmove(addressof(self), stringData[_pos:], self.GetLength()) + return _pos + self.GetLength() + + def Clear(self): + self.Cmd = 0xA2 + self.SubCmd = 0x30 + self.BubbleBoxType = 0 + return + + def GetLength(self): + return sizeof(tagCMSetChatBubbleBox) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// A2 30 设置聊天气泡框 //tagCMSetChatBubbleBox: + Cmd:%s, + SubCmd:%s, + BubbleBoxType:%d + '''\ + %( + self.Cmd, + self.SubCmd, + self.BubbleBoxType + ) + return DumpString + + +m_NAtagCMSetChatBubbleBox=tagCMSetChatBubbleBox() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMSetChatBubbleBox.Cmd,m_NAtagCMSetChatBubbleBox.SubCmd))] = m_NAtagCMSetChatBubbleBox + + +#------------------------------------------------------ # A2 22 设置引导成功 #tagCMSetGuideOK class tagCMSetGuideOK(Structure): @@ -4808,6 +4860,82 @@ m_NAtagCMSetGuideOK=tagCMSetGuideOK() ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMSetGuideOK.Cmd,m_NAtagCMSetGuideOK.SubCmd))] = m_NAtagCMSetGuideOK + + +#------------------------------------------------------ +# A2 29 设置小助手 #tagCMSetLittleHelper + +class tagCMSetLittleHelper(Structure): + _pack_ = 1 + _fields_ = [ + ("Cmd", c_ubyte), + ("SubCmd", c_ubyte), + ("SetNum", c_ubyte), # 托管功能设置编号1~20,每个编号对应的托管功能前端自定义 + ("Value1", c_int), # 自定义值1 + ("Value2", c_int), # 自定义值2 + ("Value3", c_int), # 自定义值3 + ("Value4", c_int), # 自定义值4 + ("Value5", c_int), # 自定义值5 + ("Value6", c_int), # 自定义值6 + ] + + def __init__(self): + self.Clear() + self.Cmd = 0xA2 + self.SubCmd = 0x29 + return + + def ReadData(self, stringData, _pos=0, _len=0): + self.Clear() + memmove(addressof(self), stringData[_pos:], self.GetLength()) + return _pos + self.GetLength() + + def Clear(self): + self.Cmd = 0xA2 + self.SubCmd = 0x29 + self.SetNum = 0 + self.Value1 = 0 + self.Value2 = 0 + self.Value3 = 0 + self.Value4 = 0 + self.Value5 = 0 + self.Value6 = 0 + return + + def GetLength(self): + return sizeof(tagCMSetLittleHelper) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// A2 29 设置小助手 //tagCMSetLittleHelper: + Cmd:%s, + SubCmd:%s, + SetNum:%d, + Value1:%d, + Value2:%d, + Value3:%d, + Value4:%d, + Value5:%d, + Value6:%d + '''\ + %( + self.Cmd, + self.SubCmd, + self.SetNum, + self.Value1, + self.Value2, + self.Value3, + self.Value4, + self.Value5, + self.Value6 + ) + return DumpString + + +m_NAtagCMSetLittleHelper=tagCMSetLittleHelper() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMSetLittleHelper.Cmd,m_NAtagCMSetLittleHelper.SubCmd))] = m_NAtagCMSetLittleHelper #------------------------------------------------------ @@ -6098,6 +6226,8 @@ AddonsItemIndexCnt = 0 #(BYTE AddonsItemIndexCnt)// 附加物品在背包中索引个数 AddonsItemIndex = list() #(vector<BYTE> AddonsItemIndex)// 附加物品在背包的索引列表 AddonsItemCount = list() #(vector<BYTE> AddonsItemCount)// 附加物品在背包的索引对应扣除数量列表 + RateIncreaseItemIndexCnt = 0 #(BYTE RateIncreaseItemIndexCnt)// 提升概率物品在背包中索引个数 + RateIncreaseItemIndex = list() #(vector<BYTE> RateIncreaseItemIndex)// 提升概率物品在背包的索引列表 data = None def __init__(self): @@ -6126,6 +6256,10 @@ for i in range(self.AddonsItemIndexCnt): value,_pos=CommFunc.ReadBYTE(_lpData,_pos) self.AddonsItemCount.append(value) + self.RateIncreaseItemIndexCnt,_pos = CommFunc.ReadBYTE(_lpData, _pos) + for i in range(self.RateIncreaseItemIndexCnt): + value,_pos=CommFunc.ReadBYTE(_lpData,_pos) + self.RateIncreaseItemIndex.append(value) return _pos def Clear(self): @@ -6142,6 +6276,8 @@ self.AddonsItemIndexCnt = 0 self.AddonsItemIndex = list() self.AddonsItemCount = list() + self.RateIncreaseItemIndexCnt = 0 + self.RateIncreaseItemIndex = list() return def GetLength(self): @@ -6156,6 +6292,8 @@ length += 1 length += 1 * self.AddonsItemIndexCnt length += 1 * self.AddonsItemIndexCnt + length += 1 + length += 1 * self.RateIncreaseItemIndexCnt return length @@ -6175,6 +6313,9 @@ data = CommFunc.WriteBYTE(data, self.AddonsItemIndex[i]) for i in range(self.AddonsItemIndexCnt): data = CommFunc.WriteBYTE(data, self.AddonsItemCount[i]) + data = CommFunc.WriteBYTE(data, self.RateIncreaseItemIndexCnt) + for i in range(self.RateIncreaseItemIndexCnt): + data = CommFunc.WriteBYTE(data, self.RateIncreaseItemIndex[i]) return data def OutputString(self): @@ -6188,7 +6329,9 @@ FixedItemIndex:%s, AddonsItemIndexCnt:%d, AddonsItemIndex:%s, - AddonsItemCount:%s + AddonsItemCount:%s, + RateIncreaseItemIndexCnt:%d, + RateIncreaseItemIndex:%s '''\ %( self.Head.OutputString(), @@ -6200,6 +6343,8 @@ "...", self.AddonsItemIndexCnt, "...", + "...", + self.RateIncreaseItemIndexCnt, "..." ) return DumpString @@ -7147,8 +7292,9 @@ ("MapID", c_int), ("LineID", c_ushort), ("Cnt", c_ubyte), # 扫荡次数 - ("IsFinish", c_ubyte), # 是否立即完成 + ("IsFinish", c_ubyte), # 是否立即完成; 0-否;1-花钱立即完成;2-客户端自行倒计时间到后发送2代表领取扫荡完成奖励 ("DataEx", c_int), #附带信息 + ("IsLittleHelper", c_ubyte), # 是否小助手扫荡 ] def __init__(self): @@ -7170,6 +7316,7 @@ self.Cnt = 0 self.IsFinish = 0 self.DataEx = 0 + self.IsLittleHelper = 0 return def GetLength(self): @@ -7186,7 +7333,8 @@ LineID:%d, Cnt:%d, IsFinish:%d, - DataEx:%d + DataEx:%d, + IsLittleHelper:%d '''\ %( self.Cmd, @@ -7195,7 +7343,8 @@ self.LineID, self.Cnt, self.IsFinish, - self.DataEx + self.DataEx, + self.IsLittleHelper ) return DumpString @@ -8752,6 +8901,58 @@ #------------------------------------------------------ +# A5 56 神兵激活 #tagCMGodWeaponActivate + +class tagCMGodWeaponActivate(Structure): + _pack_ = 1 + _fields_ = [ + ("Cmd", c_ubyte), + ("SubCmd", c_ubyte), + ("WeaponType", c_int), # 神兵类型 + ] + + def __init__(self): + self.Clear() + self.Cmd = 0xA5 + self.SubCmd = 0x56 + return + + def ReadData(self, stringData, _pos=0, _len=0): + self.Clear() + memmove(addressof(self), stringData[_pos:], self.GetLength()) + return _pos + self.GetLength() + + def Clear(self): + self.Cmd = 0xA5 + self.SubCmd = 0x56 + self.WeaponType = 0 + return + + def GetLength(self): + return sizeof(tagCMGodWeaponActivate) + + def GetBuffer(self): + return string_at(addressof(self), self.GetLength()) + + def OutputString(self): + DumpString = '''// A5 56 神兵激活 //tagCMGodWeaponActivate: + Cmd:%s, + SubCmd:%s, + WeaponType:%d + '''\ + %( + self.Cmd, + self.SubCmd, + self.WeaponType + ) + return DumpString + + +m_NAtagCMGodWeaponActivate=tagCMGodWeaponActivate() +ChNetPackDict[eval("0x%02x%02x"%(m_NAtagCMGodWeaponActivate.Cmd,m_NAtagCMGodWeaponActivate.SubCmd))] = m_NAtagCMGodWeaponActivate + + +#------------------------------------------------------ # A5 55 神兵升级 #tagCMGodWeaponPlus class tagCMGodWeaponPlus(Structure): @@ -8761,6 +8962,8 @@ ("SubCmd", c_ubyte), ("WeaponType", c_int), # 神兵类型 ("ItemID", c_int), #消耗的物品ID + ("ItemCount", c_ubyte), #消耗个数,默认1 + ("IsAutoBuy", c_ubyte), #是否自动购买,默认0 ] def __init__(self): @@ -8779,6 +8982,8 @@ self.SubCmd = 0x55 self.WeaponType = 0 self.ItemID = 0 + self.ItemCount = 0 + self.IsAutoBuy = 0 return def GetLength(self): @@ -8792,13 +8997,17 @@ Cmd:%s, SubCmd:%s, WeaponType:%d, - ItemID:%d + ItemID:%d, + ItemCount:%d, + IsAutoBuy:%d '''\ %( self.Cmd, self.SubCmd, self.WeaponType, - self.ItemID + self.ItemID, + self.ItemCount, + self.IsAutoBuy ) return DumpString -- Gitblit v1.8.0