From 9de3ec62ce339d8c60be4d759ba2033a25b66a27 Mon Sep 17 00:00:00 2001 From: hxp <ale99527@vip.qq.com> Date: 星期六, 27 四月 2019 16:42:37 +0800 Subject: [PATCH] 6628 【2.0】【后端】查看玩家装备和查看玩家战力功能(查看玩家缓存相关功能修改) --- ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerFlashGiftbag.py | 70 +++++++++++++++++++++-------------- 1 files changed, 42 insertions(+), 28 deletions(-) diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerFlashGiftbag.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerFlashGiftbag.py index 43396b0..45d0497 100644 --- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerFlashGiftbag.py +++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerFlashGiftbag.py @@ -24,30 +24,24 @@ import DataRecordPack import ItemControler import IPY_GameWorld +import PlayerWeekParty import ItemCommon import GameWorld import ChConfig -def GetGiftbagTypeList(cfgID, dayIndex): +def GetGiftbagTypeList(cfgID, dayIndex, woldLV): if cfgID == None or dayIndex == None: return [] ipyData = IpyGameDataPY.GetIpyGameData("ActFlashGiftbag", cfgID) if not ipyData: return [] - giftbagTypeList = ipyData.GetGiftbagTypeList() + giftbagTypeList = GameWorld.GetDictValueByRangeKey(ipyData.GetGiftbagTypeList(), woldLV, []) todayGiftbag = giftbagTypeList[-1] if dayIndex >= len(giftbagTypeList) else giftbagTypeList[dayIndex] return todayGiftbag def OnPlayerLogin(curPlayer): - isReset = __CheckPlayerFlashGiftbagAction(curPlayer) - if not isReset: - actInfo = PyGameData.g_operationActionDict.get(ShareDefine.OperationActionName_FlashGiftbag, {}) - # 活动中同步活动信息 - if actInfo.get(ShareDefine.ActKey_State): - giftbagTypeList = GetGiftbagTypeList(actInfo.get(ShareDefine.ActKey_CfgID, 0), actInfo.get(ShareDefine.ActKey_DayIndex, 0)) - SyncFlashGiftbagBuyCount(curPlayer, giftbagTypeList=giftbagTypeList) - Sync_FlashGiftbagActionInfo(curPlayer) + __CheckPlayerFlashGiftbagAction(curPlayer) return def RefreshFlashGiftbagActionInfo(): @@ -71,10 +65,11 @@ cfgID = actInfo.get(ShareDefine.ActKey_CfgID, 0) playerActID = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_FlashGiftbagID) # 玩家身上的活动ID - + giftbagTypeList = [] if not cfgID else GetGiftbagTypeList(cfgID, actInfo.get(ShareDefine.ActKey_DayIndex, 0), actInfo.get(ShareDefine.ActKey_WorldLV, 0)) + isReset = False if actID != playerActID: - giftbagTypeList = GetGiftbagTypeList(cfgID, actInfo.get(ShareDefine.ActKey_DayIndex, 0)) - ResetGiftbagItemBuyCount(curPlayer, giftbagTypeList) + isReset = True + __ResetGiftbagItemBuyCount(curPlayer, giftbagTypeList) PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_FlashGiftbagID, actID) PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_FlashGiftbagMailState, 0) GameWorld.DebugLog("限时礼包重置! actID=%s,playerActID=%s,state=%s,giftbagTypeList=%s" % (actID, playerActID, state, giftbagTypeList), playerID) @@ -89,9 +84,14 @@ PlayerControl.SendMailByKey(flashGiftbagIpyData.GetMailKey(), [playerID], flashGiftbagIpyData.GetMailItemPrize()) PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_FlashGiftbagMailState, state) GameWorld.DebugLog(" 发送新限时礼包邮件提醒! state=%s,playerMailState=%s" % (state, playerMailState), playerID) - return True + + if not isReset and cfgID: + if giftbagTypeList: + SyncFlashGiftbagBuyCount(curPlayer, giftbagTypeList=giftbagTypeList) + Sync_FlashGiftbagActionInfo(curPlayer) + return isReset -def ResetGiftbagItemBuyCount(curPlayer, giftbagTypeList): +def __ResetGiftbagItemBuyCount(curPlayer, giftbagTypeList): ##重置限时礼包限购物品次数 syncIDList = [] ipyDataMgr = IpyGameDataPY.IPY_Data() @@ -123,7 +123,7 @@ DataRecordPack.DR_CTGError(curPlayer, "FlashGiftbag state is 0!", addDRDict) return - giftbagTypeList = GetGiftbagTypeList(actInfo.get(ShareDefine.ActKey_CfgID, 0), actInfo.get(ShareDefine.ActKey_DayIndex, 0)) + giftbagTypeList = GetGiftbagTypeList(actInfo.get(ShareDefine.ActKey_CfgID, 0), actInfo.get(ShareDefine.ActKey_DayIndex, 0), actInfo.get(ShareDefine.ActKey_WorldLV, 0)) if not giftbagTypeList: DataRecordPack.DR_CTGError(curPlayer, "FlashGiftbag GiftbagTypeList is null!", addDRDict) return @@ -143,7 +143,7 @@ return giftbagID = giftbagIpyData.GetGiftbagID() - giftItemList = giftbagIpyData.GetGiftItemList() + giftItemList = __GetJobItemList(giftbagIpyData.GetGiftItemList(), curPlayer.GetJob()) addDRDict.update({"giftbagID":giftbagID, "giftItemList":giftItemList}) buyCountLimit = giftbagIpyData.GetBuyCountLimit() buyCount = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_FlashGiftbagBuyCount % giftbagID) @@ -162,19 +162,29 @@ PlayerControl.SendMailByKey("", [curPlayer.GetPlayerID()], giftItemList) else: for itemID, itemCount, isBind in giftItemList: - ItemControler.GivePlayerItem(curPlayer, itemID, itemCount, isBind, [IPY_GameWorld.rptItem], + ItemControler.GivePlayerItem(curPlayer, itemID, itemCount, 0, [IPY_GameWorld.rptItem], event=[ChConfig.ItemGive_CTG, True, addDRDict]) # 取玩家APPID,混服使用 - appID = GameWorld.GetPlayerPlatform(curPlayer.GetAccID()) + appID = GameWorld.GetPlayerPlatform(curPlayer) notifyKey = giftbagIpyData.GetNotifyKey() if notifyKey: orderIpyData = GetFlashGiftbagIDOrderInfoIpyData(giftbagID, appID) rmb = 0 if not orderIpyData else int(orderIpyData.GetPayRMBNum()) PlayerControl.WorldNotify(0, notifyKey, [curPlayer.GetPlayerName(), rmb, giftbagIpyData.GetMainItemID()]) - + SyncFlashGiftbagBuyCount(curPlayer, [giftbagID]) + PlayerWeekParty.AddWeekPartyActionCnt(curPlayer, ChConfig.Def_WPAct_GiftBag, actGiftbagType, False) return True + +def __GetJobItemList(itemList, job): + jobItemList = [] + for itemID, itemCnt, isBind in itemList: + if type(itemID) == int: + jobItemList.append([itemID, itemCnt, isBind]) + elif job in itemID: + jobItemList.append([itemID[job], itemCnt, isBind]) + return jobItemList def SyncFlashGiftbagBuyCount(curPlayer, syncIDList=[], giftbagTypeList=[]): ## 通知限时礼包玩家活动信息 @@ -213,13 +223,16 @@ if not actInfo: return - if not actInfo.get(ShareDefine.ActKey_State): - return + #需要提前通知,所以去掉此限制 + #if not actInfo.get(ShareDefine.ActKey_State): + # return cfgID = actInfo.get(ShareDefine.ActKey_CfgID, 0) - giftbagTypeList = GetGiftbagTypeList(actInfo.get(ShareDefine.ActKey_CfgID, 0), actInfo.get(ShareDefine.ActKey_DayIndex, 0)) + if not cfgID: + return + giftbagTypeList = GetGiftbagTypeList(cfgID, actInfo.get(ShareDefine.ActKey_DayIndex, 0), actInfo.get(ShareDefine.ActKey_WorldLV, 0)) - if not cfgID or not giftbagTypeList: + if not giftbagTypeList: return flashGiftbagIpyData = IpyGameDataPY.GetIpyGameData("ActFlashGiftbag", cfgID) @@ -233,11 +246,12 @@ return # 取玩家APPID,混服使用 - appID = GameWorld.GetPlayerPlatform(curPlayer.GetAccID()) + appID = GameWorld.GetPlayerPlatform(curPlayer) + openServerDay = GameWorld.GetGameWorld().GetGameWorldDictByKey(ShareDefine.Def_Notify_WorldKey_ServerDay) + 1 packInfo = ChPyNetSendPack.tagMCFlashGiftbagInfo() - packInfo.StartDate = flashGiftbagIpyData.GetStartDate() - packInfo.EndtDate = flashGiftbagIpyData.GetEndDate() + packInfo.StartDate = GameWorld.GetOperationActionDateStr(flashGiftbagIpyData.GetStartDate(), openServerDay) + packInfo.EndtDate = GameWorld.GetOperationActionDateStr(flashGiftbagIpyData.GetEndDate(), openServerDay) packInfo.AdvanceMinutes = flashGiftbagIpyData.GetAdvanceMinutes() packInfo.ActivityTime = [] for i, startTime in enumerate(startTimeList): @@ -269,7 +283,7 @@ giftBag.RMB = 0 if not orderIpyData else int(orderIpyData.GetPayRMBNum()) giftBag.RMBOriginal = giftIpyData.GetOriginalRMB() giftBag.ItemInfo = [] - for itemID, itemCount, isBind in giftIpyData.GetGiftItemList(): + for itemID, itemCount, isBind in __GetJobItemList(giftIpyData.GetGiftItemList(), curPlayer.GetJob()): item = ChPyNetSendPack.tagMCFlashGiftbagItem() item.ItemID = itemID item.ItemCount = itemCount -- Gitblit v1.8.0