From c060aabfb4621e897f7b69d6e537fc3ccf59d860 Mon Sep 17 00:00:00 2001 From: xdh <xiefantasy@qq.com> Date: 星期一, 28 一月 2019 20:44:25 +0800 Subject: [PATCH] 2969 【BUG】【1.5.200】限时抢购,重新开服全服抢购次数会重置 --- ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerCrossRealmPK.py | 101 ++++++++++++++++++++++++++++++++++++++------------ 1 files changed, 77 insertions(+), 24 deletions(-) diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerCrossRealmPK.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerCrossRealmPK.py index f1b09e7..226837f 100644 --- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerCrossRealmPK.py +++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerCrossRealmPK.py @@ -19,9 +19,12 @@ import PlayerControl import NetPackCommon import IpyGameDataPY +import PlayerActivity import ChPyNetSendPack import CrossRealmPlayer +import FunctionNPCCommon import DataRecordPack +import PlayerWeekParty import IPY_GameWorld import ItemControler import ItemCommon @@ -30,9 +33,10 @@ ## 是否匹配中 def SetIsCrossPKMatching(curPlayer, isMatching): - curPlayer.SetDict(ChConfig.Def_PlayerKey_IsCrossPKMatching, isMatching) + PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PlayerKey_IsCrossPKMatching, isMatching) return -def GetIsCrossPKMatching(curPlayer): return curPlayer.GetDictByKey(ChConfig.Def_PlayerKey_IsCrossPKMatching) +def GetIsCrossPKMatching(curPlayer): + return curPlayer.NomalDictGetProperty(ChConfig.Def_PlayerKey_IsCrossPKMatching) and IsCrossRealmPKMatchState() def DoPlayerOnDay(curPlayer): if GameWorld.IsCrossServer(): @@ -61,6 +65,7 @@ PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_TodayPKCount, 0) PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_TodayWinCount, 0) PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_TodayBuyCount, 0) + PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_ItemAddCount, 0) PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_DayPKCountAwardState, 0) PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_DayWinCountAwardState, 0) SyncCrossRealmPKPlayerInfo(curPlayer) @@ -151,7 +156,7 @@ DR_GetCrossPKAward(curPlayer, zoneID, seasonID, eventName, True, mailDetail) # 查询 GameServer 玩家赛季排名 - if not curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_CrossPK_SeasonAwardState): + if not curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_CrossPK_SeasonAwardState) and playerDanLV: OnQueryCrossPKSeasonOrderAward(curPlayer, zoneID, seasonID, True) # 重置状态 @@ -164,6 +169,7 @@ PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_TodayPKCount, 0) PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_TodayWinCount, 0) PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_TodayBuyCount, 0) + PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_ItemAddCount, 0) PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_DayPKCountAwardState, 0) PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_DayWinCountAwardState, 0) PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_DanLVAwardState, 0) @@ -173,6 +179,9 @@ SyncCrossRealmPKPlayerInfo(curPlayer) SyncCrossRealmPKAwardState(curPlayer) + + # 重置商店物品 + FunctionNPCCommon.ShopItemOnCrossPKSeasonChange(curPlayer) return True #// C1 01 跨服PK匹配 #tagCMCrossRealmPKMatch @@ -190,6 +199,10 @@ if GameWorld.IsCrossServer(): GameWorld.DebugLog("跨服服务器无法发起匹配!", playerID) + return + + if not CrossRealmPlayer.IsCrossServerOpen(): + PlayerControl.NotifyCode(curPlayer, "CrossMatching18") return if GameWorld.GetMap().GetMapFBType() != IPY_GameWorld.fbtNull: @@ -218,9 +231,11 @@ if dayFreeMatchCountMax: todayPKCount = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_CrossPK_TodayPKCount) todayBuyCount = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_CrossPK_TodayBuyCount) - if todayPKCount >= (dayFreeMatchCountMax + todayBuyCount): - GameWorld.DebugLog("PK次数不足,无法发起匹配! todayPKCount=%s >= (dayFreeMatchCountMax=%s + todayBuyCount=%s)" - % (todayPKCount, dayFreeMatchCountMax, todayBuyCount), playerID) + todayItemAddCount = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_CrossPK_ItemAddCount) + + if todayPKCount >= (dayFreeMatchCountMax + todayBuyCount + todayItemAddCount): + GameWorld.DebugLog("PK次数不足,无法发起匹配! todayPKCount=%s >= (dayFreeMatchCountMax=%s + todayBuyCount=%s + todayItemAddCount=%s)" + % (todayPKCount, dayFreeMatchCountMax, todayBuyCount, todayItemAddCount), playerID) return dataMsg = { @@ -232,6 +247,7 @@ "playerJob":curPlayer.GetJob(), "playerLV":curPlayer.GetLV(), "maxHP":curPlayer.GetMaxHP(), + "maxProDef":PlayerControl.GetMaxProDef(curPlayer), "fightPower":curPlayer.GetFightPower(), "realmLV":curPlayer.GetOfficialRank(), "pkScore":curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_CrossPK_TotalScore), # 当前积分 @@ -270,27 +286,37 @@ PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_ZoneID, zoneID) PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_SeasonID, seasonID) PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_SeasonDanLV % seasonID, danLV) + PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_SeasonScore % seasonID, pkScore) PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_TotalScore, pkScore) PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_DanLV, danLV) pkCount = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_CrossPK_PKCount) + 1 PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_PKCount, pkCount) + GameWorld.Log(" 更新数据: danLV=%s,pkScore=%s,pkCount=%s" % (danLV, pkScore, pkCount), playerID) if isWinner: winCount = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_CrossPK_WinCount) + 1 PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_WinCount, winCount) PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_CWinCount, cWinCount) + GameWorld.Log(" winner winCount=%s,cWinCount=%s" % (winCount, cWinCount), playerID) else: PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_CWinCount, 0) - + GameWorld.Log(" loser cWinCount=0", playerID) + # 同一天的话增加当日PK次数 if GameWorld.CheckTimeIsSameServerDayEx(GameWorld.ChangeTimeStrToNum(timeStr)): todayPKCount = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_CrossPK_TodayPKCount) + 1 PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_TodayPKCount, todayPKCount) + GameWorld.Log(" 同一天的PK结算增加今日PK次数: todayPKCount=%s" % todayPKCount, playerID) if isWinner: todayWinCount = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_CrossPK_TodayWinCount) + 1 PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_TodayWinCount, todayWinCount) - + GameWorld.Log(" 增加今日已获胜次数: todayWinCount=%s" % todayWinCount, playerID) + PlayerActivity.AddDailyActionFinishCnt(curPlayer, ShareDefine.DailyActionID_CrossReamPK) + PlayerWeekParty.AddWeekPartyActionCnt(curPlayer, ChConfig.Def_WPAct_CrossPK, 1) + else: + GameWorld.Log(" 不同天的PK结算不增加今日PK次数! ", playerID) + SyncCrossRealmPKPlayerInfo(curPlayer) ## 跨服已经通知过了,证明还在跨服服务器,不做以下的处理 @@ -322,6 +348,12 @@ def OnCrossRealmPKBuy(index, clientData, tick): curPlayer = GameWorld.GetPlayerManager().GetPlayerByIndex(index) playerID = curPlayer.GetPlayerID() + if not CrossRealmPlayer.IsCrossServerOpen(): + PlayerControl.NotifyCode(curPlayer, "CrossMatching18") + return + if not IsCrossRealmPKMatchState(): + GameWorld.DebugLog("跨服匹配未开启,不可进行购买次数!", playerID) + return dayFreeMatchCountMax = IpyGameDataPY.GetFuncCfg("CrossRealmPKMatchCount", 1) if not dayFreeMatchCountMax: GameWorld.DebugLog("每日匹配次数没有限制,不需要购买次数!", playerID) @@ -378,14 +410,15 @@ return dayPKCountAwardDict = IpyGameDataPY.GetFuncEvalCfg("CrossRealmPKAward", 1, {}) # {"次数":[[物品ID,个数,是否绑定], ...], ...} awardPKCountList = dayPKCountAwardDict.keys() + awardPKCountList = [int(k) for k in awardPKCountList] awardPKCountList.sort() - awardPKCountStr = str(awardPKCount) - if awardPKCountStr not in awardPKCountList: + GameWorld.DebugLog(" awardPKCountList=%s" % awardPKCountList, playerID) + if awardPKCount not in awardPKCountList: GameWorld.DebugLog(" 没有该PK次数奖励!") return - awardIndex = awardPKCountList.index(awardPKCountStr) + awardIndex = awardPKCountList.index(awardPKCount) awardStateDictName = ChConfig.Def_PDict_CrossPK_DayPKCountAwardState - awardItemList = dayPKCountAwardDict[awardPKCountStr] + awardItemList = dayPKCountAwardDict[str(awardPKCount)] eventName = "PKCount" drDataDict = {"awardPKCount":awardPKCount} @@ -398,14 +431,15 @@ return dayWinCountAwardDict = IpyGameDataPY.GetFuncEvalCfg("CrossRealmPKAward", 2, {}) # {"次数":[[物品ID,个数,是否绑定], ...], ...} awardWinCountList = dayWinCountAwardDict.keys() + awardWinCountList = [int(k) for k in awardWinCountList] awardWinCountList.sort() - awardWinCountStr = str(awardWinCount) - if awardWinCountStr not in awardWinCountList: + GameWorld.DebugLog(" awardWinCountList=%s" % awardWinCountList, playerID) + if awardWinCount not in awardWinCountList: GameWorld.DebugLog(" 没有该胜利次数奖励!", playerID) return - awardIndex = awardWinCountList.index(awardWinCountStr) + awardIndex = awardWinCountList.index(awardWinCount) awardStateDictName = ChConfig.Def_PDict_CrossPK_DayWinCountAwardState - awardItemList = dayWinCountAwardDict[awardWinCountStr] + awardItemList = dayWinCountAwardDict[str(awardWinCount)] eventName = "WinCount" drDataDict = {"awardWinCount":awardWinCount} @@ -427,6 +461,10 @@ elif awardType == 4: GameWorld.DebugLog("玩家领取赛季结算奖励!", playerID) + totalScore = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_CrossPK_TotalScore) + if not totalScore: + GameWorld.DebugLog("无赛季积分无法领取奖励!", playerID) + return if GameWorld.GetGameWorld().GetGameWorldDictByKey(ShareDefine.Def_Notify_WorldKey_CrossPKSeasonState) != 2: GameWorld.DebugLog("非赛季结算阶段,不可领取!", playerID) return @@ -465,6 +503,9 @@ for itemID, itemCnt, isBind in awardItemList: ItemControler.GivePlayerItem(curPlayer, itemID, itemCnt, isBind, [IPY_GameWorld.rptItem]) + if awardType == 3: + PlayerControl.WorldNotify(0, "CrossMatching22", [curPlayer.GetPlayerName(), awardDanLV]) + DR_GetCrossPKAward(curPlayer, zoneID, seasonID, eventName, False, drDataDict) return @@ -472,16 +513,17 @@ ## 邮件发放未领取的每日奖励 playerID = curPlayer.GetPlayerID() awardCountList = awardItemDict.keys() + awardCountList = [int(k) for k in awardCountList] awardCountList.sort() - for i, awardCountStr in enumerate(awardCountList): - awardCount = int(awardCountStr) + GameWorld.DebugLog(" awardCountList=%s" % awardCountList, playerID) + for i, awardCount in enumerate(awardCountList): if dataCount < awardCount: GameWorld.DebugLog("跨服PK每日奖励次数不足: eventName=%s,i=%s,awardCount=%s > dataCount=%s" % (eventName, i, awardCount, dataCount), playerID) break if pow(2, i) & awardState: GameWorld.DebugLog("已领取该跨服PK每日奖励: eventName=%s,i=%s,awardCount=%s" % (eventName, i, awardCount), playerID) continue - awardItemList = awardItemDict[awardCountStr] + awardItemList = awardItemDict[str(awardCount)] GameWorld.Log("邮件发放跨服PK未领取的每日奖励: zoneID=%s,seasonID=%s,eventName=%s,i=%s,awardCount=%s,dataCount=%s,awardState=%s,awardItemList=%s" % (zoneID, seasonID, eventName, i, awardCount, dataCount, awardState, awardItemList), playerID) @@ -513,7 +555,8 @@ def DoGetPKSeasonAward(curPlayer, eventName, zoneID, seasonID, order, danLV, isMail): ## 执行发放赛季结算奖励,名次奖励与最高段位奖励互斥,优先名次奖励 - + isNotify = not isMail + notifyKey = "" awardItemList = [] seasonAwardLV = danLV playerID = curPlayer.GetPlayerID() @@ -525,17 +568,20 @@ if order > 0: PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_SeasonOrder % seasonID, order) seasonOrderAwardDict = IpyGameDataPY.GetFuncEvalCfg("CrossRealmPKAward", 3, {}) # {"名次":[[物品ID,个数,是否绑定], ...], ...} + awardOrderList = seasonOrderAwardDict.keys() + awardOrderList = [int(k) for k in awardOrderList] + awardOrderList.sort() + GameWorld.DebugLog(" awardOrderList=%s" % awardOrderList, playerID) fromOrder, toOrder = 1, 1 - awardOrderList = sorted(seasonOrderAwardDict.keys()) - for i, awardOrderStr in enumerate(awardOrderList): - awardOrder = int(awardOrderStr) + for i, awardOrder in enumerate(awardOrderList): if order <= awardOrder: toOrder = awardOrder - awardItemList = seasonOrderAwardDict[awardOrderStr] + awardItemList = seasonOrderAwardDict[str(awardOrder)] maxDanLV = IpyGameDataPY.IPY_Data().GetCrossRealmPKDanCount() - 1 # 因为段位等级从0开始,所以最大段位等级要减1 seasonAwardLV = maxDanLV + (len(awardOrderList) - i) GameWorld.Log("获得排名奖励, 更新奖励等级: awardOrderList=%s,i=%s,maxDanLV=%s,seasonAwardLV=%s" % (awardOrderList, i, maxDanLV, seasonAwardLV), playerID) mailTypeKey = "CrossServer4" + notifyKey = "CrossMatching23" mailParamList = [seasonID, fromOrder, toOrder] break fromOrder = awardOrder + 1 @@ -547,6 +593,7 @@ return awardItemList = danLVIpyData.GetSeasonDanLVAwardList() mailTypeKey = "CrossServer5" + notifyKey = "CrossMatching24" mailParamList = [seasonID, danLV] if not awardItemList: @@ -561,6 +608,7 @@ SyncCrossRealmPKAwardState(curPlayer) GameWorld.Log("还是同一个赛季,设置赛季奖励已领取!") PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_CrossPK_SeasonAwardLV % seasonID, seasonAwardLV) + SyncCrossRealmPKHisSeasonInfo(curPlayer) if not isMail: needSpace = len(awardItemList) @@ -577,6 +625,9 @@ GameWorld.Log("领取成功! awardItemList=%s" % (awardItemList), playerID) drDataDict = {"awardItemList":awardItemList, "order":order, "danLV":danLV, "seasonAwardLV":seasonAwardLV, "isMail":isMail} DR_GetCrossPKAward(curPlayer, zoneID, seasonID, eventName, isMail, drDataDict) + + if isNotify and notifyKey: + PlayerControl.WorldNotify(0, notifyKey, [curPlayer.GetPlayerName()] + mailParamList + [awardItemList[0][0]]) return def SyncCrossRealmPKPlayerInfo(curPlayer): @@ -590,6 +641,7 @@ pkPlayerInfo.DayPKCount = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_CrossPK_TodayPKCount) pkPlayerInfo.DayWinCount = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_CrossPK_TodayWinCount) pkPlayerInfo.DayBuyCount = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_CrossPK_TodayBuyCount) + pkPlayerInfo.DayItemAddCount = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_CrossPK_ItemAddCount) NetPackCommon.SendFakePack(curPlayer, pkPlayerInfo) return @@ -611,6 +663,7 @@ seasonInfo = ChPyNetSendPack.tagMCCrossRealmPKPlayerHisSeason() seasonInfo.SeasonID = seasonID seasonInfo.DanLV = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_CrossPK_SeasonDanLV % seasonID) + seasonInfo.Score = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_CrossPK_SeasonScore % seasonID) seasonInfo.Order = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_CrossPK_SeasonOrder % seasonID) seasonInfo.AwardLV = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_CrossPK_SeasonAwardLV % seasonID) hisSeasonInfo.SeasonList.append(seasonInfo) -- Gitblit v1.8.0