PGRData/Resources/Scripts/XManager/XFubenExperimentManager.lua

414 lines
14 KiB
Lua
Raw Normal View History

2022-12-26 14:06:01 +05:30
local CSXTextManagerGetText = CS.XTextManager.GetText
local tableInsert = table.insert
local tableSort = table.sort
local CSGameEventManager = CS.XGameEventManager.Instance
XFubenExperimentManagerCreator = function()
local XFubenExperimentManager = {}
local TrialGroup = {}
local TrialLevel = {}
local TrialLevelDic = {}
local ShowTrialGroup = {}
-- local BattleTrial = {}
local FinishExperimentIds = {}
local ExperimentInfos = {} -- 关卡完成信息字典(k:关卡Id,v:信息)
--服务器获取的副本结束时间信息
local CurStageId
XFubenExperimentManager.TrialLevelType = {
Signle = 1,
Mult = 2,
Switch = 3,
SkinTrial = 5,
}
XFubenExperimentManager.TabGroupId = {
SkinTrial = 18 --涂装试玩
}
local FUBEN_EXPERIMENT_PROTO = {
ExperimentStarRewardRequest = "ExperimentStarRewardRequest",
}
local function InitLevelDic()
for i, v in ipairs(TrialLevel) do
if not TrialLevelDic[v.GroupID] then
TrialLevelDic[v.GroupID] = {v}
else
tableInsert(TrialLevelDic[v.GroupID],v)
end
end
end
function XFubenExperimentManager.Init()
TrialGroup = XFubenExperimentConfigs.GetTrialGroupCfg()
TrialLevel = XFubenExperimentConfigs.GetTrialLevelCfg()
InitLevelDic()
-- BattleTrial = XFubenExperimentConfigs.GetBattleTrialCfg()
end
local GetStarsCount = function(starsMark)
local count = (starsMark & 1) + (starsMark & 2 > 0 and 1 or 0) + (starsMark & 4 > 0 and 1 or 0)
local map = {(starsMark & 1) > 0, (starsMark & 2) > 0, (starsMark & 4) > 0 }
return count, map
end
function XFubenExperimentManager.GetTrialGroup()
return TrialGroup
end
function XFubenExperimentManager.GetSkinTrialTime()
local levels = TrialLevelDic[XFubenExperimentManager.TabGroupId.SkinTrial]
if #levels == 0 then return end
local startTime = math.huge
local endTime = 0
for i = 1, #levels do
local timeId = levels[i].TimeId
if timeId and timeId ~= 0 and XFunctionManager.IsEffectiveTimeId(timeId) then
local levelStartTime,levelEndTime = XFunctionManager.GetTimeByTimeId(timeId)
if startTime > levelStartTime then startTime = levelStartTime end
if endTime < levelEndTime then endTime = levelEndTime end
end
end
return startTime,endTime
end
function XFubenExperimentManager.GetTrialLevelByGroupID(groupID)
local levels = TrialLevelDic[groupID] or {}
local temps = {}
for _, v in ipairs(levels) do
if v.TimeId and v.TimeId ~= 0 then
if XFunctionManager.CheckInTimeByTimeId(v.TimeId) then
tableInsert(temps,v)
end
else
tableInsert(temps,v)
end
end
return temps
end
function XFubenExperimentManager.CheckGroupHasInTimeTask(groupId)
local levels = XFubenExperimentManager.GetTrialLevelByGroupID(groupId)
return #levels > 0
end
function XFubenExperimentManager.GetShowTrialGroup(func)
ShowTrialGroup = {}
for k, v in pairs(TrialGroup) do
if v.SubIndex == 0 and v.TimeId == 0 then
tableInsert(ShowTrialGroup,v)
elseif XFubenExperimentManager.CheckGroupHasInTimeTask(v.Id) then
tableInsert(ShowTrialGroup,v)
end
end
if func then
tableSort(ShowTrialGroup,func)
end
return ShowTrialGroup
end
function XFubenExperimentManager.GetEndTime(id)
if ShowTrialGroup[id] then
local timeId = ShowTrialGroup[id].TimeId
return XFunctionManager.GetEndTimeByTimeId(timeId)
end
return nil
end
function XFubenExperimentManager.GetStartTime(id)
if ShowTrialGroup[id] then
local timeId = ShowTrialGroup[id].TimeId
return XFunctionManager.GetStartTimeByTimeId(timeId)
end
return nil
end
function XFubenExperimentManager.GetStageCondition(id)
return TrialLevel[id].ConditionId
end
function XFubenExperimentManager.GetStageShowPass(id)
return TrialLevel[id].ShowPass
end
function XFubenExperimentManager.GetCurExperimentLevelId()
return CurStageId
end
function XFubenExperimentManager.SetCurExperimentLevelId(id)
CurStageId = id
end
function XFubenExperimentManager.GetCurExperiment()
return XFubenExperimentConfigs.GetTrialLevelCfgById(CurStageId)
end
function XFubenExperimentManager.GetFinishExperimentIds()
return FinishExperimentIds
end
function XFubenExperimentManager.SetFinishExperimentIds(list)
FinishExperimentIds = list
end
function XFubenExperimentManager.UpdateFinishExperimentId(id)
table.insert(FinishExperimentIds, id)
end
function XFubenExperimentManager.CheckExperimentIsFinish(Id)
for _, v in pairs(FinishExperimentIds) do
if v == Id then
return true
end
end
return false
end
function XFubenExperimentManager.SetExperimentInfo(experimentInfo)
ExperimentInfos[experimentInfo.Id] = experimentInfo
end
function XFubenExperimentManager.GetExperimentInfo(id)
if not ExperimentInfos[id] then
return nil
end
return ExperimentInfos[id]
end
function XFubenExperimentManager.HandleExperimentData(data)
XFubenExperimentManager.SetFinishExperimentIds(data.FinishIds)
if data.ExperimentInfos then
for _, experimentInfo in ipairs(data.ExperimentInfos) do
XFubenExperimentManager.SetExperimentInfo(experimentInfo)
end
end
end
function XFubenExperimentManager.SetStarReward(id, starNum)
if not ExperimentInfos[id] then
return
end
if not ExperimentInfos[id].StarList then
ExperimentInfos[id].StarList = {}
end
tableInsert(ExperimentInfos[id].StarList, starNum)
end
function XFubenExperimentManager.GetStarReward(levelId, rewardIndex)
-- TODO 本地校验
if XFubenExperimentManager.CheckExperimentRewardIsTaked(levelId, rewardIndex) then
XUiManager.TipError(CSXTextManagerGetText("FuBenExperimentRewardIsTaked"))
return
end
if not XFubenExperimentManager.CheckExperimentRewardIsCanTake(levelId, rewardIndex) then
XUiManager.TipError(CSXTextManagerGetText("FuBenExperimentTakeRewardFaild"))
return
end
local starNum = XFubenExperimentManager.GetStardRewardNeedStarNum(levelId, rewardIndex)
XNetwork.Call(FUBEN_EXPERIMENT_PROTO.ExperimentStarRewardRequest, {Id = levelId, StarNum = starNum},function(res)
if res.Code ~= XCode.Success then
XUiManager.TipCode(res.Code)
return
end
XFubenExperimentManager.SetStarReward(levelId, starNum)
XUiManager.OpenUiObtain(res.RewardList)
CSGameEventManager:Notify(XEventId.EVENT_EXPERIMENT_GET_STAR_REWARD)
XEventManager.DispatchEvent(XEventId.EVENT_EXPERIMENT_GET_STAR_REWARD)
end)
end
function XFubenExperimentManager.GetExperimentStarProgressById(id)
local levelCfg = XFubenExperimentConfigs.GetTrialLevelCfgById(id)
if not levelCfg then
return
end
local starRewardCfg = XFubenExperimentConfigs.GetTrialStarRewardCfgById(levelCfg.StarReward)
if not starRewardCfg then
return
end
local curStarNum = 0
local experimentInfo = XFubenExperimentManager.GetExperimentInfo(id)
if experimentInfo then
if experimentInfo.StarsMark then
curStarNum = GetStarsCount(experimentInfo.StarsMark)
end
end
local maxStarNum = 0
for _, starNum in pairs(starRewardCfg.StarNum) do
if starNum > maxStarNum then
maxStarNum = starNum
end
end
return curStarNum, maxStarNum
end
function XFubenExperimentManager.CheckTargetComplete(id, targetIndex)
local experimentInfo = ExperimentInfos[id]
if not experimentInfo then
return false
end
local starsMark = experimentInfo.StarsMark
local starCount, starMap = GetStarsCount(experimentInfo.StarsMark)
if starMap[targetIndex] then
return true
end
return false
end
function XFubenExperimentManager.CheckExperimentRewardIsTaked(id, rewardIndex)
local experimentInfo = XFubenExperimentManager.GetExperimentInfo(id)
if not experimentInfo then
return false
end
local starNum = XFubenExperimentManager.GetStardRewardNeedStarNum(id, rewardIndex)
if not starNum then
return false
end
if not experimentInfo.StarList then
return false
end
for _, isTakedStarNum in pairs(experimentInfo.StarList) do
if starNum == isTakedStarNum then
return true
end
end
return false
end
-- 判断可领取该星级奖励(不判断是否已经领取已经领取用CheckExperimentRewardIsTaked判断)
function XFubenExperimentManager.CheckExperimentRewardIsCanTake(id, rewardIndex)
local experimentInfo = ExperimentInfos[id]
if not experimentInfo then
return false
end
local starCount = GetStarsCount(experimentInfo.StarsMark)
local starNum = XFubenExperimentManager.GetStardRewardNeedStarNum(id, rewardIndex)
if not starNum then
return false
end
if starCount < starNum then
return false
end
return true
end
function XFubenExperimentManager.GetStardRewardNeedStarNum(id, rewardIndex)
local trainedLevelCfg = XFubenExperimentConfigs.GetTrialLevelCfgById(id)
local trialRewardCfg = XFubenExperimentConfigs.GetTrialStarRewardCfgById(trainedLevelCfg.StarReward)
local starNumList = trialRewardCfg.StarNum
if not starNumList[rewardIndex] then
return nil
end
return starNumList[rewardIndex]
end
function XFubenExperimentManager.CheckBannerRedPoint(trialLevelInfo) -- 检查红点
local isShowRed = false
if trialLevelInfo.StarReward and trialLevelInfo.StarReward > 0 then -- 带有奖励的试玩关
local starRewardId = trialLevelInfo.StarReward
local rewardList = XFubenExperimentConfigs.GetTrialStarRewardCfgById(starRewardId).StarNum
if not rewardList then
return false
end
for index, _ in ipairs(rewardList) do
if XFubenExperimentManager.CheckExperimentRewardIsCanTake(trialLevelInfo.Id, index) and not XFubenExperimentManager.CheckExperimentRewardIsTaked(trialLevelInfo.Id, index) then
isShowRed = true
break
end
end
elseif trialLevelInfo.Type == XFubenExperimentManager.TrialLevelType.SkinTrial then
if not XFubenExperimentManager.CheckExperimentIsFinish(trialLevelInfo.Id) then
isShowRed = true
end
end
return isShowRed
end
function XFubenExperimentManager.CheckExperimentGroupHaveRedPoint(groupId)
local levelTamplates = XFubenExperimentManager.GetTrialLevelByGroupID(groupId)
for _, trialLevelInfo in ipairs(levelTamplates) do
if XFubenExperimentManager.CheckBannerRedPoint(trialLevelInfo) then
return true
end
end
end
function XFubenExperimentManager.CheckSkinTrialRedPoint()
return XFubenExperimentManager.CheckExperimentGroupHaveRedPoint(XFubenExperimentManager.TabGroupId.SkinTrial)
end
function XFubenExperimentManager.InitStageInfo()
for k, v in ipairs(TrialLevel) do
if v.SingStageId and v.SingStageId ~= 0 then
local stageInfo = XDataCenter.FubenManager.GetStageInfo(v.SingStageId)
stageInfo.Type = XDataCenter.FubenManager.StageType.Experiment
if v.StarReward and v.StarReward ~= 0 then stageInfo.HasReward = true end
end
if v.MultStageId and v.MultStageId ~= 0 then
local stageInfo = XDataCenter.FubenManager.GetStageInfo(v.MultStageId)
stageInfo.Type = XDataCenter.FubenManager.StageType.Experiment
if v.StarReward and v.StarReward ~= 0 then stageInfo.HasReward = true end
end
end
end
function XFubenExperimentManager.ShowReward(winData)
local stageId = winData.StageId
local stageCfg = XDataCenter.FubenManager.GetStageCfg(stageId)
if next(stageCfg.StarDesc) then
XLuaUiManager.Open("UiSettleWinMainLine", winData)
else
XLuaUiManager.Open("UiSettleWin", winData)
end
end
function XFubenExperimentManager.CheckExperimentRedPoint()
local experimentGroups = XFubenExperimentManager.GetShowTrialGroup()
for _, groupTemplate in ipairs(experimentGroups) do
if XFubenExperimentManager.CheckExperimentGroupHaveRedPoint(groupTemplate.Id) then
return true
end
end
return false
end
XFubenExperimentManager.Init()
return XFubenExperimentManager
end
XRpc.NotifyUpdateExperimentId = function(data)
XDataCenter.FubenExperimentManager.UpdateFinishExperimentId(data.Id)
if data.Info then
XDataCenter.FubenExperimentManager.SetExperimentInfo(data.Info)
end
XEventManager.DispatchEvent(XEventId.EVENT_UPDATE_EXPERIMENT)
end
XRpc.NotifyExperimentData = function(data)
XDataCenter.FubenExperimentManager.HandleExperimentData(data)
end