From 922b9a9139f9c86cc48b14668f05615a6ea5fd21 Mon Sep 17 00:00:00 2001 From: hxp <ale99527@vip.qq.com> Date: 星期二, 19 三月 2019 16:02:13 +0800 Subject: [PATCH] 6359 【后端】【2.0】掉落规则调整 --- ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerRecover.py | 45 ++++++++++++++++++++++++++++++++++++--------- 1 files changed, 36 insertions(+), 9 deletions(-) diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerRecover.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerRecover.py index 81e52d8..81dca15 100644 --- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerRecover.py +++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/Player/PlayerRecover.py @@ -32,6 +32,7 @@ import GameFuncComm import PlayerTJG import PlayerActivity +import PlayerSuccess import PyGameData import copy @@ -43,7 +44,7 @@ ) = range(2) Def_TJGRecoverID = 1 #脱机挂找回索引ID - +Def_QueenRelics = 11 #娲皇遗迹找回索引ID ## OnDay处理 # @param curPlayer # @return None @@ -123,6 +124,9 @@ PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_RecoverGainData % index, historyMaxLine) + if dataMapID == ChConfig.Def_FBMapID_MunekadoTrial: + historyStar = GameWorld.GetDictValueByBit(curPlayer, ChConfig.Def_Player_Dict_PlayerFBStar_MapId, historyMaxLine-1, False, [dataMapID]) + PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_PDict_RecoverGainDataEx % index, historyStar) #更新可找回次数 curCommonCnt = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_RecoverFBCommonCnt % index, 0) @@ -257,7 +261,12 @@ infoDict = {ChConfig.Def_Cost_Reason_SonKey:recoverWay} for moneyType, moneyCnt in costMoneyDict.items(): - PlayerControl.PayMoney(curPlayer, moneyType, moneyCnt, ChConfig.Def_Cost_RecoverGain, infoDict) + costMoneyList = PlayerControl.HaveMoneyEx(curPlayer, moneyType, moneyCnt) + GameWorld.DebugLog(' moneyType=%s,moneyCnt=%s,costMoneyList=%s'%(moneyType, moneyCnt, costMoneyList)) + if not costMoneyList: + return + for mType, mCnt in costMoneyList: + PlayerControl.PayMoney(curPlayer, mType, mCnt, ChConfig.Def_Cost_RecoverGain, infoDict) if totalExp > 0: @@ -279,11 +288,12 @@ else: for itemID, itemCnt in totalItemDict.items(): - ItemControler.GivePlayerItem(curPlayer, itemID, itemCnt, 1, [IPY_GameWorld.rptItem, IPY_GameWorld.rptAnyWhere], True, showSysInfo=True) + ItemControler.GivePlayerItem(curPlayer, itemID, itemCnt, 0, [IPY_GameWorld.rptItem, IPY_GameWorld.rptAnyWhere]) if Def_TJGRecoverID in recoverCntDict: #脱机挂经验找回后重置 PlayerTJG.ResetTJGDeadInfo(curPlayer) - + if Def_QueenRelics in recoverCntDict: + PlayerSuccess.DoAddSuccessProgress(curPlayer, ShareDefine.SuccType_QueenRelicsEx, recoverCntDict[Def_QueenRelics]) DataRecordPack.DR_PlayerRecover(curPlayer, recoverWay, recoverCntDict, totalExp, totalMoney, totalSP, totalItemDict) __SetRecoverNum(curPlayer, recoverCntDict) __NotifyRecoverNum(curPlayer) @@ -325,17 +335,16 @@ costMoney = int(normalCostJade * recoverSecond / float(3600)) else: costMoney = min(commonCnt, recoverCnt) * normalCostJade + vipCostJade * max(0, recoverCnt - commonCnt) - costMoneyList = PlayerControl.HaveMoneyEx(curPlayer, ShareDefine.TYPE_Price_Gold_Paper_Money, costMoney) + costMoneyList = [[ShareDefine.TYPE_Price_Gold_Paper_Money, costMoney]] else: costCopper = ipyData.GetCostCopper() if index == Def_TJGRecoverID: costMoney = int(costCopper * recoverSecond / float(3600)) else: costMoney = recoverCnt * costCopper - if PlayerControl.HaveMoney(curPlayer, IPY_GameWorld.TYPE_Price_Silver_Money, costMoney, False): - costMoneyList = [[IPY_GameWorld.TYPE_Price_Silver_Money, costMoney]] - else: - costMoneyList = [] + + costMoneyList = [[IPY_GameWorld.TYPE_Price_Silver_Money, costMoney]] + return costMoneyList, recoverCnt def __GetCanRecoverCnt(curPlayer, index): @@ -390,6 +399,8 @@ reExp = PlayerControl.GetPlayerReExp(curPlayer) expRate = PlayerControl.GetLimitExpRate(curPlayer, ChConfig.ExpRateLimitType_Recover) extraData = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_RecoverGainData % index, 0) + dataEx = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_RecoverGainDataEx % index, 0) + tjgExp = 0 #脱机挂找回经验 exp = 0 sp = 0 @@ -414,6 +425,8 @@ itemInfoList = awardDict.get("item", []) if itemInfoList: + job = curPlayer.GetJob() + jobItemList = ipyData.GetJobItemList() for itemInfo in itemInfoList: itemID = itemInfo.get('ItemID', 0) itemcntFormula = itemInfo.get('ItemCount', '') @@ -422,10 +435,23 @@ itemcnt = recoverCnt * eval(FormulaControl.GetCompileFormula('ResourcesBackitem%s_%s_%s' % (recoverWay, index, itemID), itemcntFormula)) if not itemcnt: continue + itemID = __GetJobItem(job, itemID, jobItemList) itemDict[itemID] = itemcnt return exp, sp, money, itemDict +def __GetJobItem(job, itemID, jobItemList): + ## 获取物品对应的职业物品, 职业从1开始 + for jobItemIDList in jobItemList: + if type(jobItemIDList) not in [list, tuple]: + GameWorld.ErrLog("资源找回职业物品组格式错误!itemID=%s,jobItemList=%s" % (itemID, jobItemList)) + return itemID + if itemID in jobItemIDList: + if job <= 0 or job > len(jobItemIDList): + GameWorld.ErrLog("资源找回职业物品配置错误,没有该职业对应物品ID!itemID=%s,job=%s" % (itemID, job)) + return itemID + return jobItemIDList[job - 1] + return itemID ## 通知找回次数 # @param curPlayer @@ -453,6 +479,7 @@ numInfoPack.RecoverCnt = commonCnt numInfoPack.ExtraCnt = vipExtraCnt numInfoPack.ExtraData = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_RecoverGainData % index, 0) + numInfoPack.ExtraData2 = curPlayer.NomalDictGetProperty(ChConfig.Def_PDict_RecoverGainDataEx % index, 0) sendPack.NumInfo.append(numInfoPack) sendPack.Num = len(sendPack.NumInfo) NetPackCommon.SendFakePack(curPlayer, sendPack) -- Gitblit v1.8.0