local XBabelTowerStageData = require("XEntity/XBabelTower/XBabelTowerStageData") XFubenBabelTowerManagerCreator = function() local XFubenBabelTowerManager = {} local RequestRpc = { BabelTowerSelect = "BabelTowerSelectRequest", --关卡选择请求 BabelTowerStageReset = "BabelTowerStageResetRequest", --关卡重置请求 BabelTowerStageWipeOut = "BabelTowerStageWipeOutRequest", --关卡扫荡请求 BabelTowerGetRank = "BabelTowerGetRankRequest", --获取排名 } local CurrentActivityNo = nil --当前活动id local CurrentActivityMaxScore = 0 --当前活动最高等级 local CurrentRankLevel = 0 --当前排行榜等级 local BabelActivityStatus = {} --{活动id = 活动状态} local BabelActivityStages = {} --{活动id = 活动Stage列表} local Stage2ActivityMap = {} --{stageId = activityId} local StageSupportDefaultBuffList = {} local CurStageId = nil -- 当前通关的副本 local CurTeamId = nil -- 当前通关的副本 local CurStageGuideId = nil -- 当前通关的副本阶段 local CurTeamList = nil -- 当前组队信息 local CurCaptainPos = nil local CurFirstFightPos = nil local CurStageLevel = nil local ChallengeBuffList = nil -- 当前选择的挑战信息 local SupportBuffList = nil -- 当前选择的支援信息 local CurTeamScore = nil local CurActivityMaxScore = nil -- 获取排名 local CurScore = 0 local CurRank = 0 local TotalRank = 0 local RankInfos = {} local LastOpenStageId = nil local function GetStageDatas() local stageDatas = BabelActivityStages[CurrentActivityNo] if not stageDatas then return {} end return stageDatas end local function GetStageData(stageId) local stageDatas = GetStageDatas() local stageData = stageDatas and stageDatas[stageId] if not stageData then return end return stageData end local function GetTeamData(stageId, teamId) local stageData = GetStageData(stageId) local teamData = stageData and stageData:GetTeamData(teamId) if not teamData then return end return teamData end function XFubenBabelTowerManager.InitStageInfo() local allBabelActivityTemplates = XFubenBabelTowerConfigs.GetAllBabelTowerActivityTemplate() if allBabelActivityTemplates then for _, activityTemplate in pairs(allBabelActivityTemplates) do for _, stageId in pairs(activityTemplate.StageId or {}) do Stage2ActivityMap[stageId] = activityTemplate.Id local stageInfo = XDataCenter.FubenManager.GetStageInfo(stageId) if stageInfo then stageInfo.Type = XDataCenter.FubenManager.StageType.BabelTower end end end XFubenBabelTowerManager.RefreshStagePassed() end end function XFubenBabelTowerManager.OpenFightLoading(stageId) XDataCenter.FubenManager.OpenFightLoading(stageId) end function XFubenBabelTowerManager.CloseFightLoading(stageId) XDataCenter.FubenManager.CloseFightLoading(stageId) XLuaUiManager.Open("UiFightBabelTower", stageId, XFubenBabelTowerConfigs.BattleReady) end function XFubenBabelTowerManager.ShowReward(winData) if not winData or not winData.SettleData then XLuaUiManager.Open("UiSettleWin", winData) return end XFubenBabelTowerManager.RefreshStagePassed() XLuaUiManager.Open("UiFightBabelTower", winData.SettleData.StageId, XFubenBabelTowerConfigs.BattleEnd) end function XFubenBabelTowerManager.FinishFight(settle) XFubenBabelTowerManager.SetNeedShowUiDifficult(true) XDataCenter.FubenManager.FinishFight(settle) end local __IsNeedShowUiDifficult = false function XFubenBabelTowerManager.IsNeedShowUiDifficult() return __IsNeedShowUiDifficult end function XFubenBabelTowerManager.SetNeedShowUiDifficult(value) __IsNeedShowUiDifficult = value and true or false end -- stageInfo刷新 -- 选中的关卡临时数据 function XFubenBabelTowerManager.SaveCurStageInfo(stageId, teamId, guideId, teamList, challengeBuffs, supportBuffs, captainPos, stageLevel, firstFightPos) CurStageId = stageId CurTeamId = teamId CurStageGuideId = guideId CurTeamList = teamList ChallengeBuffList = challengeBuffs SupportBuffList = supportBuffs CurCaptainPos = captainPos CurStageLevel = stageLevel CurFirstFightPos = firstFightPos CurTeamScore = XDataCenter.FubenBabelTowerManager.GetTeamMaxScore(stageId, teamId) CurActivityMaxScore = XFubenBabelTowerManager.GetCurrentActivityMaxScore() end function XFubenBabelTowerManager.GetCurStageInfo() return CurStageId, CurTeamId, CurStageGuideId, CurTeamList, ChallengeBuffList, SupportBuffList , CurCaptainPos, CurStageLevel, CurFirstFightPos, CurTeamScore, CurActivityMaxScore end function XFubenBabelTowerManager.ClearCurStageInfo() CurStageId = nil CurTeamId = nil CurStageGuideId = nil CurTeamList = nil ChallengeBuffList = nil SupportBuffList = nil CurCaptainPos = nil CurFirstFightPos = nil CurStageLevel = nil CurTeamScore = nil CurActivityMaxScore = nil end -- 保存红点 babelenvironment_playerId_activityId_stageId = (1代表打开过、0或者nil代表没有打开过) function XFubenBabelTowerManager.UpdateBabalPrefsByKey(key, value) if key then CS.UnityEngine.PlayerPrefs.SetInt(key, value) CS.UnityEngine.PlayerPrefs.Save() end end function XFubenBabelTowerManager.GetBabelPrefsByKey(key, defaultValue) if key then if CS.UnityEngine.PlayerPrefs.HasKey(key) then local babelTowerPref = CS.UnityEngine.PlayerPrefs.GetInt(key) return (babelTowerPref == nil) and defaultValue or babelTowerPref end end return defaultValue end -- 保存本地数据 function XFubenBabelTowerManager.SaveBabelTowerPrefs(key, value) if XPlayer.Id and CurrentActivityNo then key = string.format("%s_%s_%s", key, tostring(XPlayer.Id), tostring(CurrentActivityNo)) CS.UnityEngine.PlayerPrefs.SetInt(key, value) CS.UnityEngine.PlayerPrefs.Save() end end function XFubenBabelTowerManager.GetBabelTowerPrefs(key, defaultValue) if XPlayer.Id and CurrentActivityNo then key = string.format("%s_%s_%s", key, tostring(XPlayer.Id), tostring(CurrentActivityNo)) if CS.UnityEngine.PlayerPrefs.HasKey(key) then local babelTowerPref = CS.UnityEngine.PlayerPrefs.GetInt(key) return (babelTowerPref == nil or babelTowerPref == 0) and defaultValue or babelTowerPref end end return defaultValue end -- 是否为自选战略 function XFubenBabelTowerManager.IsStageGuideAuto(guideId) local stageGuideTemplate = XFubenBabelTowerConfigs.GetBabelTowerStageGuideTemplate(guideId) return #stageGuideTemplate.BuffGroup <= 0 and #stageGuideTemplate.BuffId <= 0 end function XFubenBabelTowerManager.IsStagePassed(stageId) local stageData = GetStageData(stageId) return stageData:IsSyned() end function XFubenBabelTowerManager.IsStageTeamHasRecord(stageId, teamId) if not XFubenBabelTowerManager.IsStagePassed(stageId) then return false end local teamData = GetTeamData(stageId, teamId) return teamData:IsSyned() end function XFubenBabelTowerManager.GetStageTotalScore(stageId) local stageData = GetStageData(stageId) return stageData and stageData:GetTotalScore() or 0 end function XFubenBabelTowerManager.GetStageGuideId(stageId) local stageData = GetStageData(stageId) return stageData and stageData:GetGudieId() or 0 end function XFubenBabelTowerManager.GetStageTeamIdList(stageId) local stageData = GetStageData(stageId) return stageData and stageData:GetTeamIdList() or {} end function XFubenBabelTowerManager.GetStageUnlockTeamNum() local unlockTeamNum local stageDatas = GetStageDatas() for _, stageData in pairs(stageDatas) do local stageTeamNum = stageData:GetSynTeamNum() unlockTeamNum = unlockTeamNum or stageTeamNum if stageTeamNum < unlockTeamNum then unlockTeamNum = stageTeamNum end end return unlockTeamNum or 0 end function XFubenBabelTowerManager.WipeOutBlackList(paramStageId, paramTeamId) local blackList = {} local stageDatas = GetStageDatas() for stageId, stageData in pairs(stageDatas) do if stageId ~= paramStageId then local totalCharacterIds = stageData:GetTotalUsedCharacterIds(paramTeamId) for characterId in pairs(totalCharacterIds) do blackList[characterId] = true end end end return blackList end function XFubenBabelTowerManager.GetActivityBeginTime(activityNo) if not activityNo then return nil end local activityTemplate = XFubenBabelTowerConfigs.GetBabelTowerActivityTemplateById(activityNo) return XFunctionManager.GetStartTimeByTimeId(activityTemplate.ActivityTimeId) end function XFubenBabelTowerManager.GetFightEndTime(activityNo) if not activityNo then return nil end local activityTemplate = XFubenBabelTowerConfigs.GetBabelTowerActivityTemplateById(activityNo) return XFunctionManager.GetEndTimeByTimeId(activityTemplate.FightTimeId) end function XFubenBabelTowerManager.GetActivityEndTime(activityNo) if not activityNo then return nil end local activityTemplate = XFubenBabelTowerConfigs.GetBabelTowerActivityTemplateById(activityNo) return XFunctionManager.GetEndTimeByTimeId(activityTemplate.ActivityTimeId) end function XFubenBabelTowerManager.GetBanCharacterIdsByBuff(challengeBuffList) local banCharacterIds = {} if challengeBuffList then for _, buffDatas in pairs(challengeBuffList) do local buffTemplate = XFubenBabelTowerConfigs.GetBabelTowerBuffTemplate(buffDatas.SelectBuffId) for _, banChar in pairs(buffTemplate.BanCharacterId) do banCharacterIds[banChar] = true end end end return banCharacterIds end -- 当前角色是否被锁定 function XFubenBabelTowerManager.IsCharacterLockByStageId(cid, curStageId, curTeamId) local stageDatas = GetStageDatas() for stageId, stageData in pairs(stageDatas) do if stageId == curStageId then local totalCharacterIds = stageData:GetTotalUsedCharacterIds(curTeamId) if totalCharacterIds[cid] then return true end else local totalCharacterIds = stageData:GetTotalUsedCharacterIds() if totalCharacterIds[cid] then return true end end end return false end -- 获取被禁用的角色 -- function XFubenBabelTowerManager.GetBanCharactersByBuffs(challengeBuffList) -- -- 排除选中buff的禁用角色--可以放出来 -- local banCharList = {} -- if challengeBuffList then -- for _, buffDatas in pairs(challengeBuffList) do -- local buffTemplate = XFubenBabelTowerConfigs.GetBabelTowerBuffTemplate(buffDatas.SelectBuffId) -- for _, banChar in pairs(buffTemplate.BanCharacterId) do -- banCharList[banChar] = true -- end -- end -- end -- return banCharList -- end function XFubenBabelTowerManager.GetCurrentActivityNo() return CurrentActivityNo end function XFubenBabelTowerManager.GetNewActivityNo() local activityTemplateList = XFubenBabelTowerConfigs.GetAllBabelTowerActivityTemplate() local newActivityId for _, v in pairs(activityTemplateList) do newActivityId = v.Id end return newActivityId end function XFubenBabelTowerManager.GetCurrentActivityMaxScore() return CurrentActivityMaxScore end function XFubenBabelTowerManager.GetCurrentActivityScores() local curScore = 0 local stageDatas = GetStageDatas() for _, stageData in pairs(stageDatas) do curScore = curScore + stageData:GetTotalScore() end local maxScore = CurrentActivityMaxScore return curScore, maxScore end -- stageId的引导关是否开启 function XFubenBabelTowerManager.IsBabelStageGuideUnlock(stageId, guideId) local isStageUnlock = XFubenBabelTowerManager.IsBabelStageUnlock(stageId) if not isStageUnlock then return false end -- 上一关是否开启 local stageTemplate = XFubenBabelTowerConfigs.GetBabelTowerStageTemplate(stageId) local serverGuideId = XFubenBabelTowerManager.GetStageGuideId(stageId) if serverGuideId == 0 then return stageTemplate.StageGuideId[1] == guideId else local stageGuideMap = {} for i = 1, #stageTemplate.StageGuideId do local curGuideId = stageTemplate.StageGuideId[i] stageGuideMap[curGuideId] = i end local maxIndex = (stageGuideMap[serverGuideId] or 0) + 1 return maxIndex >= stageGuideMap[guideId] or false end end -- stageId是否开启 function XFubenBabelTowerManager.IsBabelStageUnlock(stageId) -- 未到开启时间 local activityNo = Stage2ActivityMap[stageId] if not XFubenBabelTowerManager.IsInActivityFightTime(activityNo) then return false, CS.XTextManager.GetText("BabelTowerNoneFight") end -- stage开启时间 local stageTemplate = XFubenBabelTowerConfigs.GetBabelTowerStageTemplate(stageId) local now = XTime.GetServerNowTimestamp() local beginTime, endTime = XFunctionManager.GetTimeByTimeId(stageTemplate.TimeId) if not beginTime or not endTime then return false, "" end if now < beginTime or now > endTime then return false, CS.XTextManager.GetText("BabelTowerNoneOpen") end -- 上一个stage是否开启 local stageInfo = XDataCenter.FubenManager.GetStageInfo(stageId) local stageCfg = XDataCenter.FubenManager.GetStageCfg(stageId) local desc = "" for _, prestageId in pairs(stageCfg.PreStageId or {}) do if prestageId > 0 then local preStageConfigs = XFubenBabelTowerConfigs.GetBabelStageConfigs(prestageId) desc = CS.XTextManager.GetText("BabelTowerNotEnoughScore", preStageConfigs.Name, stageTemplate.PreStageScore) end end return stageInfo.Unlock, desc end -- 是否处于活动战斗时间 function XFubenBabelTowerManager.IsInActivityFightTime(activityNo) if not activityNo then return false end local activityTemplate = XFubenBabelTowerConfigs.GetBabelTowerActivityTemplateById(activityNo) if not activityTemplate then return false end local serverStatus = BabelActivityStatus[activityNo] if serverStatus ~= XFubenBabelTowerConfigs.BabelTowerStatus.Open then return false end local now = XTime.GetServerNowTimestamp() local beginTime = XFunctionManager.GetStartTimeByTimeId(activityTemplate.ActivityTimeId) local fightEndTime = XFunctionManager.GetEndTimeByTimeId(activityTemplate.FightTimeId) if not beginTime or not fightEndTime then return false end return now >= beginTime and now <= fightEndTime end -- 是否处于活动时间 function XFubenBabelTowerManager.IsInActivityTime(activityNo) if not activityNo then return false end local activityTemplate = XFubenBabelTowerConfigs.GetBabelTowerActivityTemplateById(activityNo) if not activityTemplate then return false end local serverStatus = BabelActivityStatus[activityNo] if serverStatus ~= XFubenBabelTowerConfigs.BabelTowerStatus.Open and serverStatus ~= XFubenBabelTowerConfigs.BabelTowerStatus.FightEnd then return false end local now = XTime.GetServerNowTimestamp() local beginTime, endTime = XFunctionManager.GetTimeByTimeId(activityTemplate.ActivityTimeId) if not beginTime or not endTime then return false end return now >= beginTime and now <= endTime end -- StageInfo相关 -- 刷新通过的StageInfo -- 登录同步数据之后,刷新setWinDatas之后,InitStageInfo之后 function XFubenBabelTowerManager.RefreshStagePassed() local allBabelActivityTemplates = XFubenBabelTowerConfigs.GetAllBabelTowerActivityTemplate() if allBabelActivityTemplates then for _, activityTemplate in pairs(allBabelActivityTemplates) do local activityStageList = BabelActivityStages[activityTemplate.Id] if not activityStageList then return end for _, stageId in pairs(activityTemplate.StageId or {}) do local stageInfo = XDataCenter.FubenManager.GetStageInfo(stageId) local stageCfg = XDataCenter.FubenManager.GetStageCfg(stageId) if stageInfo then stageInfo.Passed = activityStageList[stageId] ~= nil stageInfo.Unlock = true stageInfo.IsOpen = true if stageCfg.RequireLevel > 0 and XPlayer.Level < stageCfg.RequireLevel then stageInfo.Unlock = false stageInfo.IsOpen = false end for _, prestageId in pairs(stageCfg.PreStageId or {}) do if prestageId > 0 then local needScore = XFubenBabelTowerConfigs.GetBabelTowerStageTemplate(stageId).PreStageScore or 0 local preScore = (activityStageList[prestageId] ~= nil) and activityStageList[prestageId].MaxScore or 0 if needScore > preScore then stageInfo.Unlock = false stageInfo.IsOpen = false break end end end end end end end end -- 是否在显示等级的时间段 function XFubenBabelTowerManager.IsBabelTowerInShowTime() local activityNo = XFubenBabelTowerManager.GetCurrentActivityNo() if not activityNo then return false end local activityTemplate = XFubenBabelTowerConfigs.GetBabelTowerActivityTemplateById(activityNo) if not activityTemplate then return false end local now = XTime.GetServerNowTimestamp() local beginTime = XFunctionManager.GetStartTimeByTimeId(activityTemplate.ActivityTimeId) local shwoEndTime = XFunctionManager.GetEndTimeByTimeId(activityTemplate.ShowTimeId) if not beginTime or not shwoEndTime then return false end return now >= beginTime and now <= shwoEndTime end -- RPC -- 选择关卡 function XFubenBabelTowerManager.SelectBabelTowerStage(stageId, guideId, teamList, challengeBuffInfos, supportBuffInfos, func, stageLevel, teamId) local req = { StageId = stageId, GuideId = guideId, TeamList = teamList, ChallengeBuffInfos = challengeBuffInfos, SupportBuffInfos = supportBuffInfos, StageLevel = stageLevel, TeamId = teamId, } XNetwork.Call(RequestRpc.BabelTowerSelect, req, function(res) if res.Code ~= XCode.Success then XUiManager.TipCode(res.Code) return end if func then func() end end) end -- 重置关卡 function XFubenBabelTowerManager.ResetBabelTowerStage(stageId, teamId, func) XNetwork.Call(RequestRpc.BabelTowerStageReset, { StageId = stageId, TeamId = teamId }, function(res) if res.Code ~= XCode.Success then XUiManager.TipCode(res.Code) return end local teamData = GetTeamData(stageId, teamId) teamData:Reset() XEventManager.DispatchEvent(XEventId.EVENT_BABEL_RESET_STATUES_CHANGED) if func then func() end end) end -- 扫荡关卡 function XFubenBabelTowerManager.WipeOutBabelTowerStage(stageId, teamId, func) XNetwork.Call(RequestRpc.BabelTowerStageWipeOut, { StageId = stageId, TeamId = teamId }, function(res) if res.Code ~= XCode.Success then XUiManager.TipCode(res.Code) return end local teamData = GetTeamData(stageId, teamId) teamData:Recover() XEventManager.DispatchEvent(XEventId.EVENT_BABEL_RESET_STATUES_CHANGED) if func then func() end end) end function XFubenBabelTowerManager.GetRank(func) XNetwork.Call(RequestRpc.BabelTowerGetRank, {}, function(res) if res.Code ~= XCode.Success then XUiManager.TipCode(res.Code) return end CurScore = res.Score CurRank = res.Rank TotalRank = res.TotalRank RankInfos = res.RankInfos if func then func() end end) end -- 获取排名信息 function XFubenBabelTowerManager.GetScoreInfos() return CurScore, CurRank, TotalRank end -- 获取排名信息 function XFubenBabelTowerManager.GetRankInfos() return RankInfos end --战斗失败返回 -- 获取当前排行等级 function XFubenBabelTowerManager.GetRankLevel() return CurrentRankLevel end function XFubenBabelTowerManager.SetTeamChace(stageId, teamId, team, captainPos, firstFightPos) local teamData = GetTeamData(stageId, teamId) if teamData:IsSyned() then return end --如果该关卡下已经有通关记录,那么不进行队伍配置缓存 teamData:UpdateCharacterIds(team) teamData:SetCaptainPos(captainPos) teamData:SetFirstFightPos(firstFightPos) end function XFubenBabelTowerManager.ClearTeamChace(stageId) local teamIdList = XFubenBabelTowerManager.GetStageTeamIdList(stageId) for _, teamId in pairs(teamIdList) do local teamData = GetTeamData(stageId, teamId) if not teamData:IsSyned() then teamData:ClearCharacterIds() end end end -- 支援缓存相关 function XFubenBabelTowerManager.GetSupportBuffListCacheByStageId(stageId, teamId) local teamData = GetTeamData(stageId, teamId) return teamData:GetSupportBuffDic() end function XFubenBabelTowerManager.UpdateSupportBuffListCache(stageId, supportBuffList, teamId) local teamData = GetTeamData(stageId, teamId) teamData:UpdateSupportBuffDic(supportBuffList) end -- 挑战缓存相关 function XFubenBabelTowerManager.GetBuffListCacheByStageId(stageId, teamId) local teamData = GetTeamData(stageId, teamId) return teamData:GetChallengeBuffDic() end function XFubenBabelTowerManager.UpdateBuffListCache(stageId, challengeBuffList, teamId) local teamData = GetTeamData(stageId, teamId) teamData:UpdateChallengeBuffDic(challengeBuffList) end function XFubenBabelTowerManager.IsTeamReseted(stageId, teamId) local teamData = GetTeamData(stageId, teamId) return teamData:IsReseted() end function XFubenBabelTowerManager.GetTeamCharacterIds(stageId, teamId, includeReset) local teamData = GetTeamData(stageId, teamId) return teamData:GetCharacterIds(includeReset) end function XFubenBabelTowerManager.GetTeamMaxScore(stageId, teamId) local teamData = GetTeamData(stageId, teamId) return teamData and teamData:GetMaxScore() or 0 end function XFubenBabelTowerManager.GetTeamCaptainPos(stageId, teamId) local teamData = GetTeamData(stageId, teamId) return teamData:GetCaptainPos() end function XFubenBabelTowerManager.GetTeamFirstFightPos(stageId, teamId) local teamData = GetTeamData(stageId, teamId) return teamData:GetFirstFightPos() end function XFubenBabelTowerManager.CheckTeamHasCaptain(stageId, teamId) local teamData = GetTeamData(stageId, teamId) return teamData:HasCaptain() end function XFubenBabelTowerManager.GetCacheTeam(stageId, teamId, characterIds, captainPos, firstFightPos) local curTeam = { TeamData = characterIds or XFubenBabelTowerManager.GetTeamCharacterIds(stageId, teamId), CaptainPos = captainPos or XFubenBabelTowerManager.GetTeamCaptainPos(stageId, teamId), FirstFightPos = firstFightPos or XFubenBabelTowerManager.GetTeamFirstFightPos(stageId, teamId), } return curTeam end function XFubenBabelTowerManager.GetTeamCurScore(stageId, teamId, ignoreReset) local teamData = GetTeamData(stageId, teamId) return teamData:GetScore(ignoreReset) end function XFubenBabelTowerManager.GetTeamSelectDifficult(stageId, teamId) local teamData = GetTeamData(stageId, teamId) return teamData:GetSelectDiffcult() end function XFubenBabelTowerManager.UpdateTeamSelectDifficult(stageId, teamId, difficult) local teamData = GetTeamData(stageId, teamId) teamData:SelectDiffcult(difficult) end -- 打开巴贝塔之前检查是否需要播剧情 function XFubenBabelTowerManager.OpenBabelTowerCheckStory() local value = XFubenBabelTowerManager.GetBabelTowerPrefs(XFubenBabelTowerConfigs.HAS_PLAY_BEGINSTORY, 0) local activityNo = XFubenBabelTowerManager.GetCurrentActivityNo() local hasPlay = value == 1 if not hasPlay and activityNo then local storyId = XFubenBabelTowerConfigs.GetActivityBeginStory(activityNo) -- 播放剧情 if storyId then XDataCenter.MovieManager.PlayMovie(storyId, function() XLuaUiManager.Open("UiBabelTowerMainNew") end) else XLuaUiManager.Open("UiBabelTowerMainNew") end -- XDataCenter.FubenBabelTowerManager.SaveBabelTowerPrefs(XFubenBabelTowerConfigs.HAS_PLAY_BEGINSTORY, 1) else XLuaUiManager.Open("UiBabelTowerMainNew") end end local function UpdateBabelActivityStages(activityNo, stageDatas) if not activityNo then return end local clientStageDatas = BabelActivityStages[activityNo] if not clientStageDatas then clientStageDatas = {} local config = XFubenBabelTowerConfigs.GetBabelTowerActivityTemplateById(activityNo) for _, stageId in pairs(config.StageId) do if stageId > 0 then local clientStageData = XBabelTowerStageData.New(stageId) clientStageDatas[stageId] = clientStageData end end BabelActivityStages[activityNo] = clientStageDatas end if not stageDatas then return end for _, stageData in pairs(stageDatas) do local stageId = stageData.Id local clientStageData = clientStageDatas[stageId] clientStageData:UpdateData(stageData) end XEventManager.DispatchEvent(XEventId.EVENT_BABEL_ACTIVITY_STATUS_CHANGED) end -- 登录同步 function XFubenBabelTowerManager.AsyncBabelTowerData(notifyData) if not notifyData then return end CurrentActivityNo = notifyData.ActivityNo CurrentActivityMaxScore = notifyData.MaxScore CurrentRankLevel = notifyData.RankLevel UpdateBabelActivityStages(CurrentActivityNo, notifyData.StageDatas) XFubenBabelTowerManager.RefreshStagePassed() end -- 同步活动状态 function XFubenBabelTowerManager.AsyncActivityStatus(notifyData) if not notifyData then return end BabelActivityStatus[notifyData.ActivityNo] = notifyData.Status XEventManager.DispatchEvent(XEventId.EVENT_BABEL_ACTIVITY_STATUS_CHANGED) end -- 同步单个关卡数据 function XFubenBabelTowerManager.AsyncActivityStageInfo(notifyData) if not notifyData then return end CurrentActivityMaxScore = notifyData.MaxScore local stageId = notifyData.StageId local clientStageData = GetStageData(stageId) clientStageData:Syn() local teamData = notifyData.TeamData local clientTeamData = GetTeamData(stageId, teamData.Id) clientTeamData:UpdateData(teamData) XFubenBabelTowerManager.RefreshStagePassed() XEventManager.DispatchEvent(XEventId.EVENT_BABEL_STAGE_INFO_ASYNC) end function XFubenBabelTowerManager.GetBabelTowerSection() local sections = {} if XFubenBabelTowerManager.IsInActivityTime(CurrentActivityNo) then local section = { Id = CurrentActivityNo, Type = XDataCenter.FubenManager.ChapterType.ActivityBabelTower, BannerBg = CS.XGame.ClientConfig:GetString("FubenBabelTowerBannerBg"), } table.insert(sections, section) end return sections end -- 设置最后打开的关卡id function XFubenBabelTowerManager.SetLastOpenStageId(value) LastOpenStageId = value end function XFubenBabelTowerManager.GetLastOpenStageId() return LastOpenStageId end return XFubenBabelTowerManager end --登录,或者开启通知玩法数据,活动未开启不下发 XRpc.NotifyBabelTowerData = function(notifyData) XDataCenter.FubenBabelTowerManager.AsyncBabelTowerData(notifyData) end --通知活动状态,先下发这条协议,后下发NotifyBabelTowerData XRpc.NotifyBabelTowerActivityStatus = function(notifyData) XDataCenter.FubenBabelTowerManager.AsyncActivityStatus(notifyData) end --更新单个关卡数据 XRpc.NotifyBabelTowerTeamData = function(notifyData) XDataCenter.FubenBabelTowerManager.AsyncActivityStageInfo(notifyData) end