PGRData/Resources/Scripts/XManager/XFubenBabelTowerManager.lua
2022-12-26 14:06:01 +05:30

812 lines
No EOL
31 KiB
Lua
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

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