From c613115bfffc33e6daa7ba37ec0628c580d232d3 Mon Sep 17 00:00:00 2001 From: hxp <ale99527@vip.qq.com> Date: 星期日, 30 十二月 2018 10:38:44 +0800 Subject: [PATCH] 5424 【后端】【1.4】跨服竞技场开发(查看玩家信息增加标记是否跨服玩家) --- ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerActivity.py | 44 ++++++++++++++++++++++++++++---------------- 1 files changed, 28 insertions(+), 16 deletions(-) diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerActivity.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerActivity.py index 19da755..90264dc 100644 --- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerActivity.py +++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerActivity.py @@ -69,7 +69,9 @@ if onEventType == ShareDefine.Def_OnEventTypeEx: # 重置完成次数 for i in xrange(ipyDataMgr.GetDailyQuestCount()): - key = ChConfig.Def_PDict_Activity_FinishCnt % (i+1) + ipyData = ipyDataMgr.GetDailyQuestByIndex(i) + + key = ChConfig.Def_PDict_Activity_FinishCnt % ipyData.GetID() curPBCnt = __GetPDictValue(curPlayer, key) #单次进度值 if curPBCnt: __SetPDictValue(curPlayer, key, 0) @@ -77,6 +79,8 @@ __SetPDictValue(curPlayer, ChConfig.Def_PDict_Activity_TotalPoint, 0) # 重置领奖记录 __SetPDictValue(curPlayer, ChConfig.Def_PDict_ActivityAwardRecord, 0) + #重置额外获得修行点数 + __SetPDictValue(curPlayer, ChConfig.Def_PDict_Activity_ExtraRealmPoint, 0) #重新计算奖励阶段 __CalcAwardStage(curPlayer) #重置可领取修行点,未领取的发邮件 @@ -230,30 +234,33 @@ multiple = 1 if addValue: #__SetPDictValue(curPlayer, ChConfig.Def_PDict_Activity_TotalPoint, nuwTotalPoint) - multiple = __GetActionAddPer(curPlayer) - addValue *= multiple + multiple, extraPointLimit = __GetActionAddPer(curPlayer) + curExtraPoint = __GetPDictValue(curPlayer, ChConfig.Def_PDict_Activity_ExtraRealmPoint) + addExtraPoint = max(0, min(addValue*(multiple-1),extraPointLimit-curExtraPoint)) if extraPointLimit else addValue*(multiple-1) + __SetPDictValue(curPlayer, ChConfig.Def_PDict_Activity_ExtraRealmPoint, curExtraPoint+addExtraPoint) + addValue = addValue + addExtraPoint realmPoint = __GetPDictValue(curPlayer, ChConfig.Def_PDict_Activity_RealmPoint) __SetPDictValue(curPlayer, ChConfig.Def_PDict_Activity_RealmPoint, realmPoint+addValue) SyncDailyActivityInfo(curPlayer) - GameWorld.DebugLog("增加活跃度任务次数,activityNum=%s,addPbCnt=%s,addValue=%s, multiple=%s" - % (activityNum, addPbCnt, addValue, multiple), curPlayer.GetPlayerID()) + GameWorld.DebugLog("增加活跃度任务次数,activityNum=%s,addPbCnt=%s,addValue=%s, multiple=%s, addExtraPoint=%s,curExtraPoint=%s" + % (activityNum, addPbCnt, addValue, multiple, addExtraPoint, curExtraPoint), curPlayer.GetPlayerID()) return def __GetActionAddPer(curPlayer): - multiple = 1 + multiple, extraPointLimit = 1, 0 #倍数、额外可获得修行点上限 actRealmPointInfo = PyGameData.g_operationActionDict.get(ShareDefine.OperationActionName_RealmPoint, {})# 多倍修行点活动 if not actRealmPointInfo: - return multiple + return multiple, extraPointLimit if not actRealmPointInfo.get(ShareDefine.ActKey_State): - return multiple + return multiple, extraPointLimit actRealmPointIpyData = IpyGameDataPY.GetIpyGameData("ActRealmPoint", actRealmPointInfo.get(ShareDefine.ActKey_CfgID, 0)) if not actRealmPointIpyData: - return multiple + return multiple, extraPointLimit if curPlayer.GetLV() < actRealmPointIpyData.GetLVLimit(): - return multiple - return actRealmPointIpyData.GetMultiple() + return multiple, extraPointLimit + return actRealmPointIpyData.GetMultiple(), actRealmPointIpyData.GetPointLimit() ## 同步活跃度信息 # @param curPlayer @@ -266,6 +273,7 @@ sendPack.StageIndex = __GetPDictValue(curPlayer, ChConfig.Def_PDict_Activity_AwardStage) sendPack.AwardRecord = __GetPDictValue(curPlayer, ChConfig.Def_PDict_ActivityAwardRecord) sendPack.RealmPoint = __GetPDictValue(curPlayer, ChConfig.Def_PDict_Activity_RealmPoint) + sendPack.ExtraPoint = __GetPDictValue(curPlayer, ChConfig.Def_PDict_Activity_ExtraRealmPoint) NetPackCommon.SendFakePack(curPlayer, sendPack) return @@ -361,9 +369,11 @@ # return # 由GameServer决定 - if not GameWorld.GetGameWorld().GetGameWorldDictByKey(ShareDefine.Def_Notify_WorldKey_DailyActionState % dailyID): - GameWorld.DebugLog("日常活动未开启!dailyID=%s" % dailyID) - return + # 目前跨服PK暂不需要判断,因为跨服PK次数结算在本服,玩家可能上次未结算离线,等非匹配期间上线,也需要加上,所以暂不判断 + if dailyID not in [ShareDefine.DailyActionID_CrossReamPK]: + if not GameWorld.GetGameWorld().GetGameWorldDictByKey(ShareDefine.Def_Notify_WorldKey_DailyActionState % dailyID): + GameWorld.DebugLog("日常活动未开启!dailyID=%s" % dailyID) + return dayTimesLimit = GetMaxDayTimes(ipyData)#ipyData.GetDayTimes() weekTimesLimit = ipyData.GetWeekTimes() @@ -384,15 +394,17 @@ if not unLimitCnt and curDayTimes >= dayTimesLimit: return updDayTimes = curDayTimes+addCnt if unLimitCnt else min(dayTimesLimit, curDayTimes+addCnt) + addCnt = updDayTimes - curDayTimes PlayerControl.NomalDictSetProperty(curPlayer, key, updDayTimes) GameWorld.DebugLog('增加日常活动完成次数 dailyID=%s, curDayTimes=%s, updDayTimes=%s'%(dailyID, curDayTimes, updDayTimes)) - + updWeekTimes = 0 if weekTimesLimit: key = ChConfig.Def_PDict_DailyActionWeekTimes%dailyID curWeekTimes = curPlayer.NomalDictGetProperty(key) if not unLimitCnt and curWeekTimes >= weekTimesLimit: return updWeekTimes = curWeekTimes+addCnt if unLimitCnt else min(weekTimesLimit, curWeekTimes+addCnt) + addCnt = updWeekTimes - curWeekTimes PlayerControl.NomalDictSetProperty(curPlayer, key, updWeekTimes) GameWorld.DebugLog('增加日常活动完成次数 dailyID=%s, curWeekTimes=%s, updWeekTimes=%s'%(dailyID, curWeekTimes, updWeekTimes)) @@ -400,7 +412,7 @@ #对应的日常任务表ID updTimes = updDayTimes or updWeekTimes - if updTimes and dailyQuestData: + if addCnt and updTimes and dailyQuestData: AddActivityFinishCnt(curPlayer, activityNum, updTimes, addCnt) return True -- Gitblit v1.8.0