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

414 lines
No EOL
14 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 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