|  |  |  | 
|---|
|  |  |  | import PlayerTJG | 
|---|
|  |  |  | import AICommon | 
|---|
|  |  |  | import PlayerSuccess | 
|---|
|  |  |  | import CrossPlayerData | 
|---|
|  |  |  | import PassiveBuffEffMng | 
|---|
|  |  |  | import PlayerFamilyRedPacket | 
|---|
|  |  |  | import FunctionNPCCommon | 
|---|
|  |  |  | import FormulaControl | 
|---|
|  |  |  | import PlayerGoldGift | 
|---|
|  |  |  | import PlayerFlashSale | 
|---|
|  |  |  | import PlayerWing | 
|---|
|  |  |  | import ChEquip | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | if not __DoClientUseSkillEx(curPlayer, useSkillData, tick): | 
|---|
|  |  |  | SkillShell.AttackFailNotify(curPlayer, useSkillData) | 
|---|
|  |  |  | GameWorld.DebugLog("----攻击失败 可能是技能CD %s"%skillTypeID) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | # 根据策划需求 以客户端动作为标准,不可攻击状态也进入CD | 
|---|
|  |  |  | BaseAttack.Sync_AttackResult(curPlayer, useSkillData) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if useSkillData and useSkillData.GetSkillID() != ChConfig.Def_SkillID_Somersault: | 
|---|
|  |  |  | # 跟随玩家同频率攻击 | 
|---|
|  |  |  | PetControl.PetFight(curPlayer, tick) | 
|---|
|  |  |  | 
|---|
|  |  |  | relation = BaseAttack.GetTagRelation(curPlayer, curTag, None, tick) | 
|---|
|  |  |  | #判断是否敌对关系 | 
|---|
|  |  |  | if relation[0] != ChConfig.Type_Relation_Enemy : | 
|---|
|  |  |  | AttackCommon.PlayerAttackFailSysMessanage(curPlayer, relation[1]) | 
|---|
|  |  |  | #AttackCommon.PlayerAttackFailSysMessanage(curPlayer, relation[1]) | 
|---|
|  |  |  | return | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return curTag | 
|---|
|  |  |  | 
|---|
|  |  |  | if tick - curPlayer.GetPlayerActionTick() < curPlayer.GetPrepareTime(): | 
|---|
|  |  |  | #时间间隔没有到 | 
|---|
|  |  |  | if prepareState in [IPY_GameWorld.pstCollecting, IPY_GameWorld.pstMissionCollecting]: | 
|---|
|  |  |  | FBLogic.OnCollecting(curPlayer, tick) | 
|---|
|  |  |  | OnCollecting(curPlayer, tick) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | elif prepareState == IPY_GameWorld.pstMissionCollecting: | 
|---|
|  |  |  | #任务采集 | 
|---|
|  |  |  | PlayerMissionCollect.EndMissionCollect(curPlayer) | 
|---|
|  |  |  | PlayerMissionCollect.EndMissionCollect(curPlayer, tick) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | elif prepareState == ShareDefine.Def_PstProduce: | 
|---|
|  |  |  | #生产采集(进入生产采集状态,不再重置玩家状态) | 
|---|
|  |  |  | 
|---|
|  |  |  | #重置玩家状态 | 
|---|
|  |  |  | curPlayer.SetPrepareState(0)    # 成功 | 
|---|
|  |  |  | PlayerControl.ChangePlayerAction(curPlayer, IPY_GameWorld.paNull) | 
|---|
|  |  |  | return | 
|---|
|  |  |  |  | 
|---|
|  |  |  | def OnCollecting(curPlayer, tick): | 
|---|
|  |  |  | ## 采集中逻辑 | 
|---|
|  |  |  | tagObj = curPlayer.GetActionObj() | 
|---|
|  |  |  | if not tagObj: | 
|---|
|  |  |  | return | 
|---|
|  |  |  | if tagObj.GetGameObjType() != IPY_GameWorld.gotNPC: | 
|---|
|  |  |  | return | 
|---|
|  |  |  | curNPC = GameWorld.GetNPCManager().GetNPCByIndex(tagObj.GetIndex()) | 
|---|
|  |  |  | if not curNPC: | 
|---|
|  |  |  | return | 
|---|
|  |  |  | FBLogic.OnCollecting(curPlayer, tick) | 
|---|
|  |  |  | npcID = curNPC.GetNPCID() | 
|---|
|  |  |  | collectNPCIpyData = IpyGameDataPY.GetIpyGameData("CollectNPC", npcID) | 
|---|
|  |  |  | if collectNPCIpyData: | 
|---|
|  |  |  | DoCollectingLostHP(curPlayer, collectNPCIpyData, tick, False) | 
|---|
|  |  |  | return | 
|---|
|  |  |  |  | 
|---|
|  |  |  | def DoCollectingLostHP(curPlayer, collectNPCIpyData, tick, isEnd): | 
|---|
|  |  |  | ## 执行采集掉血 | 
|---|
|  |  |  | if not collectNPCIpyData.GetLostHPPer(): | 
|---|
|  |  |  | return | 
|---|
|  |  |  | lostSecond, lostHPPer = collectNPCIpyData.GetLostHPPer() | 
|---|
|  |  |  | lastTick = curPlayer.GetDictByKey(ChConfig.Def_PlayerKey_CollectLostHPTick) | 
|---|
|  |  |  | lostTime = (tick - lastTick) / (lostSecond * 1000.0) # 掉血次数 | 
|---|
|  |  |  | if isEnd: | 
|---|
|  |  |  | lostTime = int(round(lostTime)) # 采集完的时候四舍五入 | 
|---|
|  |  |  | else: | 
|---|
|  |  |  | lostTime = int(lostTime) | 
|---|
|  |  |  | if lostTime < 1: | 
|---|
|  |  |  | return | 
|---|
|  |  |  |  | 
|---|
|  |  |  | curPlayer.SetDict(ChConfig.Def_PlayerKey_CollectLostHPTick, tick) | 
|---|
|  |  |  | lostValue = int(GameObj.GetMaxHP(curPlayer) * lostHPPer / 100.0) * lostTime | 
|---|
|  |  |  | skillTypeID, buffOwner = 0, None | 
|---|
|  |  |  | SkillCommon.SkillLostHP(curPlayer, skillTypeID, buffOwner, lostValue, tick) | 
|---|
|  |  |  | GameWorld.DebugLog("采集掉血: npcID=%s,lostHPPer=%s,lostTime=%s,lostValue=%s" % (collectNPCIpyData.GetNPCID(), lostHPPer, lostTime, lostValue)) | 
|---|
|  |  |  | return | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | # @return 布尔值 | 
|---|
|  |  |  | # @remarks 处理耐久计算方式为:现实时间刷新方式的物品 | 
|---|
|  |  |  | def ProcessTimeEquip(curPlayer, tick): | 
|---|
|  |  |  | itemManager = curPlayer.GetItemManager() | 
|---|
|  |  |  | hasItemClear = False | 
|---|
|  |  |  |  | 
|---|
|  |  |  | curPack = itemManager.GetPack(IPY_GameWorld.rptEquip) | 
|---|
|  |  |  | for i in range(0, curPack.GetCount()): | 
|---|
|  |  |  | curItem = curPack.GetAt(i) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #异常物品 | 
|---|
|  |  |  | if not ItemCommon.CheckItemCanUse(curItem): | 
|---|
|  |  |  | continue | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if curItem.GetEndureReduceType() not in [ChConfig.Def_EquipReduceType_RTimeItem, | 
|---|
|  |  |  | ChConfig.Def_EquipReduceType_Time]: | 
|---|
|  |  |  | continue | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #处理现实时间物品逻辑 | 
|---|
|  |  |  | if __DoLogic_ProcessTimeEquip(curPlayer, curItem, i): | 
|---|
|  |  |  | hasItemClear = True | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if hasItemClear: | 
|---|
|  |  |  | #装备重刷属性 | 
|---|
|  |  |  | PlayerWing.CalcWingAttr(curPlayer) | 
|---|
|  |  |  | ChEquip.RefreshPlayerEquipAttribute(curPlayer) | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | # 进行更新时效道具刷新时间 | 
|---|
|  |  |  | curPlayer.SetDict(ChConfig.Def_PlayerKey_EquipTime, tick) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return hasItemClear | 
|---|
|  |  |  | return | 
|---|
|  |  |  | #境界装备修改,暂屏蔽,待优化 | 
|---|
|  |  |  | #    itemManager = curPlayer.GetItemManager() | 
|---|
|  |  |  | #    hasItemClear = False | 
|---|
|  |  |  | # | 
|---|
|  |  |  | #    curPack = itemManager.GetPack(IPY_GameWorld.rptEquip) | 
|---|
|  |  |  | #    for i in range(0, curPack.GetCount()): | 
|---|
|  |  |  | #        curItem = curPack.GetAt(i) | 
|---|
|  |  |  | # | 
|---|
|  |  |  | #        #异常物品 | 
|---|
|  |  |  | #        if not ItemCommon.CheckItemCanUse(curItem): | 
|---|
|  |  |  | #            continue | 
|---|
|  |  |  | # | 
|---|
|  |  |  | #        if curItem.GetEndureReduceType() not in [ChConfig.Def_EquipReduceType_RTimeItem, | 
|---|
|  |  |  | #                                             ChConfig.Def_EquipReduceType_Time]: | 
|---|
|  |  |  | #            continue | 
|---|
|  |  |  | # | 
|---|
|  |  |  | #        #处理现实时间物品逻辑 | 
|---|
|  |  |  | #        if __DoLogic_ProcessTimeEquip(curPlayer, curItem, i): | 
|---|
|  |  |  | #            hasItemClear = True | 
|---|
|  |  |  | # | 
|---|
|  |  |  | # | 
|---|
|  |  |  | #    if hasItemClear: | 
|---|
|  |  |  | #        #装备重刷属性 | 
|---|
|  |  |  | #        PlayerWing.CalcWingAttr(curPlayer) | 
|---|
|  |  |  | #        ChEquip.RefreshPlayerEquipAttribute(curPlayer) | 
|---|
|  |  |  | # | 
|---|
|  |  |  | # | 
|---|
|  |  |  | #    # 进行更新时效道具刷新时间 | 
|---|
|  |  |  | #    curPlayer.SetDict(ChConfig.Def_PlayerKey_EquipTime, tick) | 
|---|
|  |  |  | # | 
|---|
|  |  |  | #    return hasItemClear | 
|---|
|  |  |  | #--------------------------------------------------------------------- | 
|---|
|  |  |  | ## 装备有效时间到了需要脱下,有效时间物品改成不消失,但是无使用效果 可出售和续费 | 
|---|
|  |  |  | def __DoLogic_ProcessTimeEquip(curPlayer, curItem, equipIndex): | 
|---|
|  |  |  | #验证物品是否过期 | 
|---|
|  |  |  | curItemExpireTime = curItem.GetExpireTime() | 
|---|
|  |  |  | curItemExpireTime = curItem.GetUserAttr(ShareDefine.Def_IudetExpireTime) | 
|---|
|  |  |  | if not curItemExpireTime: | 
|---|
|  |  |  | curItemExpireTime = curItem.GetExpireTime() | 
|---|
|  |  |  | curItemPastTime = time.time() - curItem.GetUserAttr(ShareDefine.Def_IudetCreateTime) | 
|---|
|  |  |  | if curItemExpireTime - curItemPastTime > 0: | 
|---|
|  |  |  | return | 
|---|
|  |  |  | 
|---|
|  |  |  | return True | 
|---|
|  |  |  | equipID = result[0] | 
|---|
|  |  |  | equipPlace = result[1] | 
|---|
|  |  |  | if equipPlace == ShareDefine.retGuard: | 
|---|
|  |  |  | if equipPlace in [ShareDefine.retGuard1, ShareDefine.retGuard2]: | 
|---|
|  |  |  | PlayerControl.NotifyCode(curPlayer, 'Guardian_Timeout', [equipID, spaceIndex]) | 
|---|
|  |  |  | elif equipPlace == ShareDefine.retWing: | 
|---|
|  |  |  | PlayerControl.NotifyCode(curPlayer, 'WingTiyan_Timeout') | 
|---|
|  |  |  | 
|---|
|  |  |  | PlayerControl.NotifyCode(curPlayer, 'FirstGoldWPOver') | 
|---|
|  |  |  | PlayerGoldGift.FirstGoldTryItemOutTime(curPlayer) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | # 广播卸装 | 
|---|
|  |  |  | if equipIndex in ChConfig.Def_SyncEquipStateByIndex: | 
|---|
|  |  |  | curPlayer.Sync_UnEquipItem(equipID, equipPlace) | 
|---|
|  |  |  | return True | 
|---|
|  |  |  | #--------------------------------------------------------------------- | 
|---|
|  |  |  | ##全局定时器调用, 刷新玩家状态 | 
|---|
|  |  |  | 
|---|
|  |  |  | #成就 | 
|---|
|  |  |  | PlayerSuccess.FinishDelayAddSuccessProgress(curPlayer, tick, False) | 
|---|
|  |  |  | #开服红包处理 | 
|---|
|  |  |  | PlayerFamilyRedPacket.ProcessOSRedPacket(curPlayer, tick) | 
|---|
|  |  |  | #PlayerFamilyRedPacket.ProcessOSRedPacket(curPlayer, tick) | 
|---|
|  |  |  | #限时抢购 | 
|---|
|  |  |  | PlayerFlashSale.ProcessFlashSaleMail(curPlayer, tick) | 
|---|
|  |  |  | #地图经验 | 
|---|
|  |  |  | ProcessAreaExp(curPlayer, tick) | 
|---|
|  |  |  | #神秘商店刷新 | 
|---|
|  |  |  | FunctionNPCCommon.CheckMysticalShopRefresh(curPlayer, tick) | 
|---|
|  |  |  | #跨服数据同步,放最后 | 
|---|
|  |  |  | CrossPlayerData.ProcessCrossPlayer(curPlayer, tick) | 
|---|
|  |  |  | return | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | curPlayer.SetDict(ChConfig.Def_PDict_PKStateTick, 0) | 
|---|
|  |  |  | curPlayer.SendPropertyRefresh(ShareDefine.CDBPlayerRefresh_PKState, 0, False) | 
|---|
|  |  |  | #GameWorld.DebugLog("退出PK状态!", curPlayer.GetPlayerID()) | 
|---|
|  |  |  | curPlayer.SetDict("StartProDTick", tick) # 开始恢复时间点 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | bossStateTick = curPlayer.GetDictByKey(ChConfig.Def_PDict_BossStateTick) | 
|---|
|  |  |  | if bossStateTick and (tick - bossStateTick) >= validTime: | 
|---|
|  |  |  | curPlayer.SetDict(ChConfig.Def_PDict_BossStateTick, 0) | 
|---|
|  |  |  | curPlayer.SendPropertyRefresh(ShareDefine.CDBPlayerRefresh_BossState, 0, False) | 
|---|
|  |  |  | #GameWorld.DebugLog("退出Boss状态!", curPlayer.GetPlayerID()) | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | # 脱离PK战斗 X秒后按比例恢复 | 
|---|
|  |  |  | ProcessProDef(curPlayer, tick) | 
|---|
|  |  |  | return | 
|---|
|  |  |  |  | 
|---|
|  |  |  | def Sync_PKBossState(curPlayer): | 
|---|
|  |  |  | psState = 1 if curPlayer.GetDictByKey(ChConfig.Def_PDict_PKStateTick) else 0 | 
|---|
|  |  |  | curPlayer.SendPropertyRefresh(ShareDefine.CDBPlayerRefresh_PKState, psState, False) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | bossState = 1 if curPlayer.GetDictByKey(ChConfig.Def_PDict_BossStateTick) else 0 | 
|---|
|  |  |  | curPlayer.SendPropertyRefresh(ShareDefine.CDBPlayerRefresh_BossState, bossState, False) | 
|---|
|  |  |  | return | 
|---|
|  |  |  |  | 
|---|
|  |  |  | # 脱离PK战斗 X秒后按比例恢复 | 
|---|
|  |  |  | def ProcessProDef(curPlayer, tick): | 
|---|
|  |  |  | if PlayerControl.GetProDefHPPer(curPlayer) == 0: | 
|---|
|  |  |  | # 没转化值 | 
|---|
|  |  |  | return | 
|---|
|  |  |  |  | 
|---|
|  |  |  | # 脱离PK战斗 X秒后按比例恢复 | 
|---|
|  |  |  | if IsInPKState(curPlayer): | 
|---|
|  |  |  | return | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if tick - curPlayer.GetDictByKey("StartProDTick") < IpyGameDataPY.GetFuncCfg("MagicExterior", 2) * 1000: | 
|---|
|  |  |  | return | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if curPlayer.GetPlayerAction() == IPY_GameWorld.paDie: | 
|---|
|  |  |  | return | 
|---|
|  |  |  |  | 
|---|
|  |  |  | # 每秒恢复 | 
|---|
|  |  |  | if tick - curPlayer.GetDictByKey("restoreProDTick") < 1000: | 
|---|
|  |  |  | return | 
|---|
|  |  |  |  | 
|---|
|  |  |  | curProDef = PlayerControl.GetProDef(curPlayer) | 
|---|
|  |  |  | maxProDef = PlayerControl.GetMaxProDef(curPlayer) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if curProDef == maxProDef: | 
|---|
|  |  |  | return | 
|---|
|  |  |  |  | 
|---|
|  |  |  | #非PK状态恢复护盾 | 
|---|
|  |  |  | PlayerControl.SetProDef(curPlayer, min(curProDef + \ | 
|---|
|  |  |  | IpyGameDataPY.GetFuncCfg("MagicExterior", 3)*maxProDef/ChConfig.Def_MaxRateValue, maxProDef)) | 
|---|
|  |  |  | curPlayer.SetDict("restoreProDTick", tick) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | def IsInPKState(curPlayer): return curPlayer.GetDictByKey(ChConfig.Def_PDict_PKStateTick) > 0 | 
|---|
|  |  |  | def SetPKStateTick(curPlayer, tick): | 
|---|
|  |  |  | 
|---|
|  |  |  | #GameWorld.DebugLog("设置Boss状态tick!tick=%s" % tick, curPlayer.GetPlayerID()) | 
|---|
|  |  |  | return | 
|---|
|  |  |  |  | 
|---|
|  |  |  | def ProcessAreaExp(curPlayer, tick): | 
|---|
|  |  |  | ##给场景经验 | 
|---|
|  |  |  | if GameWorld.IsCrossServer(): | 
|---|
|  |  |  | return | 
|---|
|  |  |  | if curPlayer.GetDictByKey(ChConfig.Def_PlayerKey_ClientCustomScene): | 
|---|
|  |  |  | return | 
|---|
|  |  |  | crossMapID = PlayerControl.GetCrossMapID(curPlayer) | 
|---|
|  |  |  | mapID = crossMapID if crossMapID else GameWorld.GetMap().GetMapID() | 
|---|
|  |  |  | neutralMapExpAwardDict = IpyGameDataPY.GetFuncEvalCfg('NeutralMapExpAward', 1, {}) | 
|---|
|  |  |  | expAwardInfo = GameWorld.GetDictValueByKey(neutralMapExpAwardDict, mapID) | 
|---|
|  |  |  | if not expAwardInfo: | 
|---|
|  |  |  | return | 
|---|
|  |  |  | if len(expAwardInfo) != 2: | 
|---|
|  |  |  | return | 
|---|
|  |  |  | secondCD, expFormula = expAwardInfo | 
|---|
|  |  |  | lastTick = curPlayer.GetDictByKey(ChConfig.Def_PDict_MapAreaExpTick) | 
|---|
|  |  |  | if not lastTick: | 
|---|
|  |  |  | curPlayer.SetDict(ChConfig.Def_PDict_MapAreaExpTick, tick) | 
|---|
|  |  |  | return | 
|---|
|  |  |  | if tick - lastTick < secondCD: | 
|---|
|  |  |  | return | 
|---|
|  |  |  | curPlayer.SetDict(ChConfig.Def_PDict_MapAreaExpTick, tick) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | reExp = PlayerControl.GetPlayerReExp(curPlayer) | 
|---|
|  |  |  | reLV = curPlayer.GetLV() | 
|---|
|  |  |  | worldLV = GameWorld.GetGameWorld().GetGameWorldDictByKey(ShareDefine.Def_Notify_WorldKey_WorldAverageLv) | 
|---|
|  |  |  | addExp = eval(FormulaControl.GetCompileFormula('NeutralMapExpAward%s'%mapID, expFormula)) | 
|---|
|  |  |  | PlayerControl.PlayerControl(curPlayer).AddExp(addExp) | 
|---|
|  |  |  | return | 
|---|