PGRData/Script/matrix/xmanager/XTRPGManager.lua
2024-09-01 22:49:41 +02:00

2307 lines
No EOL
81 KiB
Lua
Raw Permalink 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 XTRPGMaze = require("XEntity/XTRPG/XTRPGMaze")
local XTRPGBaseInfo = require("XEntity/XTRPG/XTRPGBaseInfo")
local XTRPGThirdAreaInfo = require("XEntity/XTRPG/XTRPGThirdAreaInfo")
local XTRPGRole = require("XEntity/XTRPG/XTRPGRole")
local XTRPGClientShopInfo = require("XEntity/XTRPG/XTRPGClientShopInfo")
local XTRPGBossInfo = require("XEntity/XTRPG/XTRPGBossInfo")
local XTRPGExamine = require("XEntity/XTRPG/XTRPGExamine")
XTRPGManagerCreator = function()
local tableInsert = table.insert
local tableSort = table.sort
local tonumber = tonumber
local mathFloor = math.floor
local mathMax = math.max
local mathCeil = math.ceil
local pairs = pairs
local CSXTextManagerGetText = CS.XTextManager.GetText
local stringFormat = string.format
local BaseInfo = XTRPGBaseInfo.New()
local TargetList = {} --已完成的目标
local RewardList = {} --已领取的奖励id
local ThirdAreaInfos = {}
local DEFUALT_thirdAreaId_FOR_STUPID_DESIGN = -1--数据不一致兼容
local Roles = {}
local ShopInfos = {}
local MazeInfos = {}
local MemoirList = {}
local ItemList = {}
local BossInfo = XTRPGBossInfo.New()
local CurrTargetId = 0
local CurrTargetLinkId = 0
local AddItemMaxCountNum = 0
local CurExmaine = XTRPGExamine.New() --当前检定信息
local AlreadyOpenMazeList = {} --已开启的迷宫列表
local CurrAreaOpenNum = 0
local OldCurrTargetId = 0
local NewTargetTime = 0
local IsCanCheckOpenNewMaze = false
local IsNormalPage = false --当前跑团页面模式false是探索true是常规主线
local StagePassDic = {} --已完成关卡记录
local BagHideItemIdList = {
[XDataCenter.ItemManager.ItemId.TRPGTalen] = 1,
[XDataCenter.ItemManager.ItemId.TRPGMoney] = 1,
[XDataCenter.ItemManager.ItemId.TRPGEXP] = 1,
[XDataCenter.ItemManager.ItemId.TRPGEndurance] = 1,
}
---------------------本地接口 begin------------------
local function UpdateShopInfos(shopInfos)
if not shopInfos then return end
for _, v in pairs(shopInfos) do
if not ShopInfos[v.Id] then
ShopInfos[v.Id] = XTRPGClientShopInfo.New()
end
ShopInfos[v.Id]:UpdateData(v)
end
CsXGameEventManager.Instance:Notify(XEventId.EVENT_TRPG_SHOP_INFO_CHANGE)
end
local function UpdateShopExtraData(extraDatas)
if not extraDatas then return end
for _, v in ipairs(extraDatas) do
if not ShopInfos[v.Id] then
ShopInfos[v.Id] = XTRPGClientShopInfo.New()
end
ShopInfos[v.Id]:UpdateData(v)
end
CsXGameEventManager.Instance:Notify(XEventId.EVENT_TRPG_SHOP_INFO_CHANGE)
end
local function AddBuyTimes(shopId, itemId, count)
if not ShopInfos[shopId] then
XLog.Error("XTRPGManager AddBuyTimes Error: can not found shop, shopId is " .. shopId)
return
end
ShopInfos[shopId]:AddItemBuyCount(itemId, count)
end
local function UpdateCurrTargetLinkId(currTargetLinkId, isNotPlayNewAnima)
local currTargetLinkIsFinish, targetId = XDataCenter.TRPGManager.GetTargetLinkIsFinish(currTargetLinkId)
if currTargetLinkIsFinish then
CurrTargetLinkId, CurrTargetId = XDataCenter.TRPGManager.GetOneCanFindTarget()
else
CurrTargetLinkId, CurrTargetId = currTargetLinkId, targetId
end
XEventManager.DispatchEvent(XEventId.EVENT_TRPG_UPDATE_TARGET, isNotPlayNewAnima)
end
local function UpdateMemoirInfos(memoirList)
for _, memoirId in pairs(memoirList) do
MemoirList[memoirId] = 1
end
end
local function UpdateBossInfo(bossInfo)
if not bossInfo then return end
BossInfo:UpdateBaseData(bossInfo)
end
local function UpdateBossHpInfo(hpInfo)
if not hpInfo then return end
BossInfo:UpdateHpData(hpInfo)
XEventManager.DispatchEvent(XEventId.EVENT_TRPG_BOSS_HP_SYN)
end
local function UpdateBossPhasesRewardListInfo(PhasesRewardList)
if not PhasesRewardList then return end
BossInfo:UpdatePhasesRewardList(PhasesRewardList)
end
local function UpdateWorldBossChallengeCount(count)
BossInfo:UpdateWorldBossChallengeCount(count)
CsXGameEventManager.Instance:Notify(XEventId.EVENT_TRPG_WORLDBOSS_SYNCDATA)
end
local function UpdateRewardList(rewardList)
if not rewardList then return end
for _, rewardId in pairs(rewardList) do
RewardList[rewardId] = 1
end
end
local function UpdateTargetList(targetList)
if not targetList then return end
for _, targetId in pairs(targetList) do
if not TargetList[targetId] then
TargetList[targetId] = 1
end
end
end
local function UpdateAlreadyOpenMaze(mazeId)
AlreadyOpenMazeList[mazeId] = 1
end
local function IsOpenMaze(mazeId)
return AlreadyOpenMazeList[mazeId]
end
local function InitAleardyOpenMazeList()
local secondAreaIdToMazeIdDic = XTRPGConfigs.GetSecondAreaIdToMazeIdDic()
local condition, ret
for secondAreaId, mazeId in pairs(secondAreaIdToMazeIdDic) do
condition = XTRPGConfigs.GetSecondAreaCondition(secondAreaId)
ret = XConditionManager.CheckCondition(condition)
if ret then
UpdateAlreadyOpenMaze(mazeId)
end
end
end
local function UpdateOldCurrTargetId()
OldCurrTargetId = XDataCenter.TRPGManager.GetCurrTargetId()
end
local function GetOldCurrTargetId()
return OldCurrTargetId
end
local function SetIsCanCheckOpenNewMaze(isCanCheckOpenNewMaze)
IsCanCheckOpenNewMaze = isCanCheckOpenNewMaze
end
local function SetIsNormalPage(isNormalPage)
IsNormalPage = isNormalPage
end
local function UpdateStagePassDic(stageList)
for _, stageId in ipairs(stageList or {}) do
StagePassDic[stageId] = true
end
end
---------------------本地接口 end------------------
local XTRPGManager = {}
-----------------功能入口begin----------------
function XTRPGManager.GetProgress()
local areaMaxNum = XTRPGConfigs.GetMainAreaMaxNum()
local curAreaPercent
local totalPercent = 0
for id = 1, areaMaxNum do
curAreaPercent = XTRPGManager.GetAreaRewardPercent(id)
curAreaPercent = curAreaPercent / areaMaxNum
totalPercent = totalPercent + curAreaPercent
end
return mathFloor(totalPercent * 100)
end
function XTRPGManager.InitCurrAreaOpenNum()
local currAreaOpenNum = XSaveTool.GetData("TRPGCurrAreaOpenNum_" .. XPlayer.Id)
if currAreaOpenNum then
XTRPGManager.SetCurrAreaOpenNum(currAreaOpenNum)
end
end
function XTRPGManager.SetCurrAreaOpenNum(currAreaOpenNum)
CurrAreaOpenNum = currAreaOpenNum
end
function XTRPGManager.UpdateCurrAreaOpenNum()
local areaOpenNum = XTRPGManager.GetAreaOpenNum()
XTRPGManager.SetCurrAreaOpenNum(areaOpenNum)
XSaveTool.SaveData("TRPGCurrAreaOpenNum_" .. XPlayer.Id, areaOpenNum)
end
function XTRPGManager.IsActivityShowTag()
local areaOpenNum = XTRPGManager.GetAreaOpenNum()
return CurrAreaOpenNum ~= areaOpenNum
end
function XTRPGManager.IsTRPGClear()
local progress = XTRPGManager.GetProgress()
return progress == 100
end
-----------------功能入口end------------------
-----------------迷宫begin----------------
local __CurrentMazeId = 0
local function GetMaze(mazeId)
return MazeInfos[mazeId]
end
local function InitMazes()
local mazeIds = XTRPGConfigs.GetMazeIds()
for mazeId in pairs(mazeIds) do
local maze = GetMaze(mazeId)
if not maze then
maze = XTRPGMaze.New(mazeId)
MazeInfos[mazeId] = maze
end
end
end
local function UpdateMazeInfo(data)
if not data then return end
local mazeId = data.Id
local maze = GetMaze(mazeId)
maze:UpdateData(data)
end
local function UpdateMazeInfos(mazeInfos)
if not mazeInfos then return end
for _, data in pairs(mazeInfos) do
UpdateMazeInfo(data)
end
end
function XTRPGManager.EnterMaze(mazeId)
__CurrentMazeId = mazeId
local maze = GetMaze(mazeId)
maze:Enter()
XTRPGManager.UnlockSelectCard()
XLuaUiManager.Open("UiTRPGMaze", mazeId)
end
function XTRPGManager.QuitMaze()
if __CurrentMazeId == 0 then return end
__CurrentMazeId = 0
if XLuaUiManager.IsUiShow("UiTRPGMaze") then
XLuaUiManager.Close("UiTRPGMaze")
end
end
function XTRPGManager.TipQuitMaze(callBack)
local title = CSXTextManagerGetText("TRPGMazeLeaveTipTitle")
local content = CSXTextManagerGetText("TRPGMazeLeaveTipContent")
XUiManager.DialogTip(title, content, XUiManager.DialogType.Normal, nil, callBack)
end
function XTRPGManager.TipCurrentMaze()
if __CurrentMazeId == 0 then return end
local mazeId = __CurrentMazeId
local mazeName = XTRPGConfigs.GetMazeName(mazeId)
local layerId = XTRPGManager.GetMazeCurrentLayerId(mazeId)
local layerName = XTRPGConfigs.GetMazeLayerName(layerId)
local msg = CSXTextManagerGetText("TRPGMazeTipCurrentPos", mazeName, layerName)
XUiManager.TipMsg(msg)
end
local function RestartCurrentMaze()
if __CurrentMazeId == 0 then return end
local maze = GetMaze(__CurrentMazeId)
maze:RestartCurrentLayer()
end
local _ToRestartCurrentMaze
function XTRPGManager.ReqMazeRestart()
if __CurrentMazeId == 0 then return end
RestartCurrentMaze()
if XLuaUiManager.IsUiShow("UiTRPGMaze") then
CsXGameEventManager.Instance:Notify(XEventId.EVENT_TRPG_MAZE_RESTART)
else
_ToRestartCurrentMaze = true
end
end
function XTRPGManager.IsMazeNeedRestart()
return _ToRestartCurrentMaze or false
end
function XTRPGManager.ClearMazeNeedRestart()
_ToRestartCurrentMaze = nil
end
function XTRPGManager.GetMazeCurrentLayerId(mazeId)
local maze = GetMaze(mazeId)
return maze:GetCurrentLayerId()
end
function XTRPGManager.GetMazeCurrentNodeId(mazeId)
local maze = GetMaze(mazeId)
return maze:GetCurrentNodeId()
end
function XTRPGManager.GetMazeCurrentStandNodeIndex(mazeId, layerId)
local maze = GetMaze(mazeId)
return maze:GetCurrentStandNodeIndex(layerId)
end
function XTRPGManager.GetMazeProgress(mazeId)
local maze = GetMaze(mazeId)
return maze:GetProgress()
end
function XTRPGManager.GetMazeNodeIdList(mazeId, layerId, notSort)
local maze = GetMaze(mazeId)
return maze:GetLayerNodeIdList(layerId, notSort)
end
function XTRPGManager.GetMazeCardBeginEndPos(mazeId, layerId, nodeId)
local maze = GetMaze(mazeId)
return maze:GetLayerCardBeginEndPos(layerId, nodeId)
end
function XTRPGManager.GetMazeCardNum(mazeId, layerId, nodeId)
local maze = GetMaze(mazeId)
return maze:GetLayerCardNum(layerId, nodeId)
end
function XTRPGManager.GetMazeCardId(mazeId, layerId, nodeId, cardIndex)
local maze = GetMaze(mazeId)
return maze:GetLayerCardId(layerId, nodeId, cardIndex)
end
function XTRPGManager.GetMazeRecordGroupCardCount(mazeId, cardRecordGroupId)
local maze = GetMaze(mazeId)
return maze:GetRecordGroupCardCount(cardRecordGroupId)
end
function XTRPGManager.IsCurrentLayer(mazeId, layerId)
local maze = GetMaze(mazeId)
return layerId and layerId == maze:GetCurrentLayerId()
end
function XTRPGManager.IsNodeReachable(mazeId, layerId, nodeId)
local maze = GetMaze(mazeId)
return maze:IsNodeReachable(layerId, nodeId)
end
function XTRPGManager.IsCardReachable(mazeId, layerId, nodeId, cardIndex)
local maze = GetMaze(mazeId)
return maze:IsCardReachable(layerId, nodeId, cardIndex)
end
function XTRPGManager.CheckCardCurrentType(layerId, nodeId, cardId, cardType)
if __CurrentMazeId == 0 then return false end
local maze = GetMaze(__CurrentMazeId)
return maze:CheckCardCurrentType(layerId, nodeId, cardId, cardType)
end
function XTRPGManager.IsMazeCardFinished(mazeId, layerId, cardId)
local maze = GetMaze(mazeId)
if not maze then return false end
return maze:IsCardFinished(layerId, cardId)
end
function XTRPGManager.IsMazeCardDisposeableForeverFinished(mazeId, layerId, cardId)
local maze = GetMaze(mazeId)
if not maze then return false end
return maze:IsCardDisposeableForeverFinished(layerId, cardId)
end
function XTRPGManager.GetCardFinishedId(mazeId, layerId, nodeId, cardIndex)
local maze = GetMaze(mazeId)
return maze:GetCardFinishedId(layerId, nodeId, cardIndex)
end
function XTRPGManager.IsCardAfterCurrentStand(mazeId, layerId, nodeId, cardIndex)
local maze = GetMaze(mazeId)
return maze:IsCardAfterCurrentStand(layerId, nodeId, cardIndex)
end
function XTRPGManager.IsCardCurrentStand(mazeId, layerId, nodeId, cardIndex)
local maze = GetMaze(mazeId)
return maze:IsCardCurrentStand(layerId, nodeId, cardIndex)
end
function XTRPGManager.GetMazeCardMoveDelta(cardIndex)
if __CurrentMazeId == 0 then return end
local maze = GetMaze(__CurrentMazeId)
return maze:GetMoveDelta(cardIndex)
end
function XTRPGManager.CheckQuickFight(challengeLevel)
return challengeLevel and XTRPGManager.GetExploreLevel() >= challengeLevel
end
--请求进入迷宫
local EnterMazeCD = 2
local LastEnterMazeTime = 0
function XTRPGManager.TRPGEnterMazeRequest(mazeId, cb)
local nowTime = XTime.GetServerNowTimestamp()
if nowTime < LastEnterMazeTime + EnterMazeCD then
return
end
LastEnterMazeTime = nowTime
local req = { MazeId = mazeId }
XNetwork.Call("TRPGEnterMazeRequest", req, function(res)
if res.Code ~= XCode.Success then
XUiManager.TipCode(res.Code)
return
end
local currentPos = res.CurrentPos
UpdateMazeInfo(res.MazeInfo)
XTRPGManager.EnterMaze(mazeId)
if cb then cb() end
end)
end
--请求迷宫位置整体移动:数据更新需在界面动画表现执行完毕之后,否则会增加冗余计算量
local _ToMoveCardIndex, _ToPlayMovieId
function XTRPGManager.ReqMazeMoveNext(cardIndex, movieId)
if __CurrentMazeId == 0 then return end
if XLuaUiManager.IsUiShow("UiTRPGMaze") then
CsXGameEventManager.Instance:Notify(XEventId.EVENT_TRPG_MAZE_MOVE_NEXT, cardIndex)
else
_ToMoveCardIndex = cardIndex
_ToPlayMovieId = movieId
end
end
function XTRPGManager.GetMazeNeedMoveNextCardIndex()
return _ToMoveCardIndex, _ToPlayMovieId
end
function XTRPGManager.ClearMazeNeedMoveNextCardIndex()
_ToMoveCardIndex = nil
_ToPlayMovieId = nil
end
function XTRPGManager.MazeMoveNext(cardIndex)
if __CurrentMazeId == 0 then return end
local maze = GetMaze(__CurrentMazeId)
maze:MoveNext(cardIndex)
end
function XTRPGManager.MazeMoveTo(layerId, nodeId, cardIndex)
if __CurrentMazeId == 0 then return end
local maze = GetMaze(__CurrentMazeId)
maze:MoveTo(layerId, nodeId, cardIndex)
end
function XTRPGManager.SelectCard(cardIndex)
if __CurrentMazeId == 0 then return end
local maze = GetMaze(__CurrentMazeId)
maze:SelectCard(cardIndex)
end
local _CurrentSelectCardLock--本次选择结果未处理之前不允许进行下一次选择操作
function XTRPGManager.LockSelectCard()
_CurrentSelectCardLock = true
end
function XTRPGManager.UnlockSelectCard()
_CurrentSelectCardLock = nil
end
function XTRPGManager.IsSelectCardLock()
return _CurrentSelectCardLock or false
end
--请求选择卡牌
function XTRPGManager.TRPGMazeSelectCardRequest(cardIndex)
if __CurrentMazeId == 0 then return end
if XTRPGManager.IsSelectCardLock() then return end
local selectPos = {
LayerId = XTRPGManager.GetMazeCurrentLayerId(__CurrentMazeId),
NodeId = XTRPGManager.GetMazeCurrentNodeId(__CurrentMazeId),
Index = cardIndex,
}
local req = { SelectPos = selectPos }
local cardId = XTRPGManager.GetMazeCardId(__CurrentMazeId, selectPos.LayerId, selectPos.NodeId, cardIndex)
XTRPGManager.LockSelectCard()
XNetwork.Call("TRPGMazeSelectCardRequest", req, function(res)
XTRPGManager.UnlockSelectCard()
if res.Code ~= XCode.Success then
XUiManager.TipCode(res.Code)
return
end
local resultData = res.Result
local maze = GetMaze(__CurrentMazeId)
maze:OnCardResult(cardIndex, resultData)
end)
end
function XTRPGManager.NotifyTRPGMazeSelectCardResult(data)
local resultData = data.Result
if XTool.IsTableEmpty(resultData) then return end
if __CurrentMazeId == 0 then return end
local maze = GetMaze(__CurrentMazeId)
local cardIndex = resultData.CurPos.Index
maze:OnCardResult(cardIndex, resultData)
end
function XTRPGManager.NotifyMazeRecordCardId(data)
if XTool.IsTableEmpty(data) then return end
local mazeId = data.Id
local maze = GetMaze(mazeId)
local cardIds = { data.RecordCardId }
maze:UpdateRecordCards(cardIds)
end
--请求放弃挑战
function XTRPGManager.TRPGMazeGiveUpChallengeRequest(cardIndex, cardId)
if __CurrentMazeId == 0 then return end
local layerId = XTRPGManager.GetMazeCurrentLayerId(__CurrentMazeId)
local nodeId = XTRPGManager.GetMazeCurrentNodeId(__CurrentMazeId)
local cardId = XTRPGManager.GetMazeCardId(__CurrentMazeId, layerId, nodeId, cardIndex)
if not XTRPGConfigs.CheckMazeCardType(cardId, XTRPGConfigs.CardType.Fight)
and not XTRPGConfigs.CheckMazeCardType(cardId, XTRPGConfigs.CardType.Random) then--随机牌可能随出战斗牌
return
end
local selectPos = {
LayerId = layerId,
NodeId = nodeId,
Index = cardIndex,
}
local req = { Pos = selectPos }
XNetwork.Call("TRPGMazeGiveUpChallengeRequest", req, function(res)
if res.Code ~= XCode.Success then
XUiManager.TipCode(res.Code)
return
end
local resultData = res.Result
local maze = GetMaze(__CurrentMazeId)
maze:OnCardResult(cardIndex, resultData)
end)
end
--请求快速挑战
function XTRPGManager.TRPGMazeQuickChallengeRequest(cardIndex)
if __CurrentMazeId == 0 then return end
local selectPos = {
LayerId = XTRPGManager.GetMazeCurrentLayerId(__CurrentMazeId),
NodeId = XTRPGManager.GetMazeCurrentNodeId(__CurrentMazeId),
Index = cardIndex,
}
local req = { Pos = selectPos }
XNetwork.Call("TRPGMazeQuickChallengeRequest", req, function(res)
if res.Code ~= XCode.Success then
XUiManager.TipCode(res.Code)
return
end
local resultData = res.Result
local maze = GetMaze(__CurrentMazeId)
maze:OnCardResult(cardIndex, resultData)
end)
end
-----------------迷宫end------------------
-----------------主界面begin------------------
function XTRPGManager.GetAreaState(areaId)
local openLastTimestamp = XTRPGConfigs.GetAreaOpenLastTimeStamp(areaId)
if openLastTimestamp > 0 then
return XTRPGConfigs.AreaStateType.NotOpen
elseif XTRPGManager.IsAreaExplored(areaId) then
return XTRPGConfigs.AreaStateType.Over
end
return XTRPGConfigs.AreaStateType.Open
end
function XTRPGManager.IsAreaExplored(areaId)
local percent = XTRPGManager.GetMainLineTargetLinkPercentByAreaId(areaId)
return percent == 1
end
function XTRPGManager.GetAreaOpenNum()
local mainAreaTemplate = XTRPGConfigs.GetMainAreaTemplate()
local currAreaOpenNum = 0
local areaState
for id in pairs(mainAreaTemplate) do
areaState = XTRPGManager.GetAreaState(id)
if areaState == XTRPGConfigs.AreaStateType.Open then
currAreaOpenNum = currAreaOpenNum + 1
end
end
return currAreaOpenNum
end
function XTRPGManager.IsNormalPage()
return IsNormalPage
end
-----------------主界面end------------------
-----------------商店begin----------------
function XTRPGManager.GetShopItemAlreadyBuyCount(shopId, itemId)
local shopInfo = ShopInfos[shopId]
return shopInfo and shopInfo:GetItemCount(itemId) or 0
end
function XTRPGManager.GetShopItemAddBuyCount(shopId)
local shopInfo = ShopInfos[shopId]
return shopInfo and shopInfo:GetAddBuyCount() or 0
end
function XTRPGManager.GetShopItemCanBuyCount(shopId, shopItemId)
local alreadyBuyCount = XTRPGManager.GetShopItemAlreadyBuyCount(shopId, shopItemId)
local shopItemCount = XTRPGConfigs.GetShopItemCount(shopId, shopItemId)
local addBuyCount = XTRPGManager.GetShopItemAddBuyCount(shopId)
return mathMax(shopItemCount - alreadyBuyCount + addBuyCount, 0)
end
function XTRPGManager.GetShopItemConsumeCount(shopId, shopItemId)
local shopInfo = ShopInfos[shopId]
local disCount = shopInfo and shopInfo:GetDisCount()
local consumeCount = XTRPGConfigs.GetShopItemConsumeCount(shopItemId)
if disCount then
consumeCount = consumeCount * (disCount / 100)
end
return mathCeil(consumeCount)
end
function XTRPGManager.GetShopItemIdList(shopId)
local shopItemIdList = XTRPGConfigs.GetShopItemIdList(shopId)
local list = {}
local condition, ret
local itemId, itemTemplate
for _, shopItemId in ipairs(shopItemIdList) do
condition = XTRPGConfigs.GetShopItemCondition(shopItemId)
ret = XConditionManager.CheckCondition(condition)
itemId = XTRPGConfigs.GetItemIdByShopItemId(shopItemId)
itemTemplate = XDataCenter.ItemManager.GetItemTemplate(itemId)
if ret and itemTemplate then
tableInsert(list, shopItemId)
end
end
tableSort(list, function(shopItemIdA, shopItemIdB)
local shopItemLimitCountA = XTRPGConfigs.GetShopItemCount(shopId, shopItemIdA)
local shopItemLimitCountB = XTRPGConfigs.GetShopItemCount(shopId, shopItemIdB)
-- 是否卖光
if (shopItemLimitCountA and shopItemLimitCountA > 0) or (shopItemLimitCountB and shopItemLimitCountB > 0) then
local canBuyCountA = XDataCenter.TRPGManager.GetShopItemCanBuyCount(shopId, shopItemIdA)
local canBuyCountB = XDataCenter.TRPGManager.GetShopItemCanBuyCount(shopId, shopItemIdB)
-- 如果商品有次数限制并且可购买的数量为0则判断为售罄
local isSellOutA = canBuyCountA == 0 and shopItemLimitCountA > 0
local isSellOutB = canBuyCountB == 0 and shopItemLimitCountB > 0
if isSellOutA ~= isSellOutB then
return isSellOutB
end
end
return shopItemIdA < shopItemIdB
end)
return list
end
-----------------商店end------------------
-----------------探索等级 begin----------------
function XTRPGManager.GetExploreLevel()
return BaseInfo:GetLevel()
end
function XTRPGManager.GetExploreCurExp()
return BaseInfo:GetExp()
end
function XTRPGManager.GetExploreMaxExp()
return BaseInfo:GetMaxExp()
end
function XTRPGManager.GetExploreCurEndurance()
return BaseInfo:GetEndurance()
end
function XTRPGManager.GetExploreMaxEndurance()
return BaseInfo:GetMaxEndurance()
end
function XTRPGManager.GetMaxTalentPoint()
return BaseInfo:GetMaxTalentPoint()
end
function XTRPGManager.CheckSaveIsAlreadyOpenPanelLevel()
if not XTRPGManager.IsAlreadyLevelUp() then
return
end
if not XSaveTool.GetData(stringFormat("%d%s", XPlayer.Id, "IsAlreadyOpenPanelLevel")) then
XSaveTool.SaveData(stringFormat("%d%s", XPlayer.Id, "IsAlreadyOpenPanelLevel"), true)
end
end
function XTRPGManager.CheckIsAlreadyOpenPanelLevel()
return XSaveTool.GetData(stringFormat("%d%s", XPlayer.Id, "IsAlreadyOpenPanelLevel")) or false
end
function XTRPGManager.SaveExploreRedPointLevel(level)
if not XSaveTool.GetData(stringFormat("%d%s", XPlayer.Id, "ExploreRedPointLevel")) then
XSaveTool.SaveData(stringFormat("%d%s", XPlayer.Id, "ExploreRedPointLevel"), level)
end
end
function XTRPGManager.GetExploreRedPointLevel()
return XSaveTool.GetData(stringFormat("%d%s", XPlayer.Id, "ExploreRedPointLevel"))
end
function XTRPGManager.IsAlreadyLevelUp()
local redPointLevel = BaseInfo:GetRedPointLevel()
local exploreLevel = XTRPGManager.GetExploreLevel()
if exploreLevel and redPointLevel then
return exploreLevel > redPointLevel
end
return false
end
--第1次升级后显示蓝点打开说明弹窗后隐藏蓝点
function XTRPGManager.IsShowExploreRedPointLevel()
local isAlreadyLevelUp = XTRPGManager.IsAlreadyLevelUp()
local isAlreadyOpen = XTRPGManager.CheckIsAlreadyOpenPanelLevel()
return not isAlreadyOpen and isAlreadyLevelUp
end
-----------------探索等级 end------------------
-----------------调查员 begin----------------
local function GetRole(roleId)
return Roles[roleId]
end
local function UpdateRole(data, checkNew)
if not data then return end
local roleId = data.Id
local newRoleId
local role = GetRole(roleId)
if not role then
role = XTRPGRole.New(roleId)
Roles[roleId] = role
newRoleId = checkNew and roleId
end
role:UpdateData(data)
if newRoleId and XTRPGConfigs.GetRoleIsShowTip(newRoleId) then
XLuaUiManager.Open("UiTRPGNewCharacter", newRoleId)
end
end
local function UpdateRoles(datas, checkNew)
if not datas then return end
for _, data in pairs(datas) do
UpdateRole(data, checkNew)
end
CsXGameEventManager.Instance:Notify(XEventId.EVENT_TRPG_ROLES_DATA_CHANGE)
XEventManager.DispatchEvent(XEventId.EVENT_TRPG_ROLES_DATA_CHANGE)
end
function XTRPGManager.GetOwnRoleIds()
local roleIdList = {}
for roleId in pairs(Roles) do
tableInsert(roleIdList, roleId)
end
return roleIdList
end
function XTRPGManager.GetSortedAllRoleIds()
return XTRPGConfigs.GetAllRoleIds()
end
function XTRPGManager.IsRolesEmpty()
return XTool.IsTableEmpty(Roles)
end
function XTRPGManager.IsRoleOwn(roleId)
return GetRole(roleId) and true or false
end
function XTRPGManager.IsRoleHaveBuffUp(roleId)
local role = GetRole(roleId)
return role:IsHaveBuffUp()
end
function XTRPGManager.IsRoleHaveBuffDown(roleId)
local role = GetRole(roleId)
return role:IsHaveBuffDown()
end
function XTRPGManager.GetRoleBuffIds(roleId)
local role = GetRole(roleId)
return role:GetBuffIds()
end
function XTRPGManager.GetRoleAttributes(roleId)
local role = GetRole(roleId)
return role:GetAttributes()
end
function XTRPGManager.GetRoleCommonTalentIds(roleId)
local role = GetRole(roleId)
return role:GetCommonTalentIds()
end
function XTRPGManager.GetRoleTalentIds(roleId)
local role = GetRole(roleId)
return role:GetTalentIds()
end
function XTRPGManager.GetRoleUsedTalentPoints(roleId)
local role = GetRole(roleId)
if not role then return 0 end
return role:GetUsedTalentPoint()
end
function XTRPGManager.GetTotalUsedTalentPoints()
local totalPoints = 0
for _, role in pairs(Roles) do
totalPoints = totalPoints + role:GetUsedTalentPoint()
end
return totalPoints
end
function XTRPGManager.GetRoleHaveTalentPoints()
local maxPoints = XTRPGManager.GetMaxTalentPoint()
local totalUsedPoints = XTRPGManager.GetTotalUsedTalentPoints()
return maxPoints - totalUsedPoints
end
function XTRPGManager.GetActiveTalentCostPoint(roleId, talentId)
local role = GetRole(roleId)
return role:GetTalentCostPoint(talentId)
end
function XTRPGManager.IsActiveTalentCostEnough(roleId, talentId)
local havePoints = XTRPGManager.GetRoleHaveTalentPoints()
local costPoints = XTRPGManager.GetActiveTalentCostPoint(roleId, talentId)
return havePoints >= costPoints
end
function XTRPGManager.IsTalentResetCostEnough()
local costItemId = XTRPGConfigs.GetTalentResetCostItemId()
local costItemCount = XTRPGConfigs.GetTalentResetCostItemCount()
return XDataCenter.ItemManager.CheckItemCountById(costItemId, costItemCount)
end
function XTRPGManager.IsRoleAnyTalentActive(roleId)
local role = GetRole(roleId)
return role:IsAnyTalentActive()
end
function XTRPGManager.IsRoleTalentActive(roleId, talentId)
local role = GetRole(roleId)
return role:IsTalentActive(talentId)
end
function XTRPGManager.IsRoleTalentCanActive(roleId, talentId)
local role = GetRole(roleId)
return role:CanActiveTalent(talentId)
end
function XTRPGManager.CheckRoleTalentRedPoint()
if not XTRPGConfigs.CheckButtonCondition(XTRPGConfigs.ButtonConditionId.Talent) then
return false
end
for _, role in pairs(Roles) do
if role:CanActiveAnyTalent() then
return true
end
end
return false
end
function XTRPGManager.GetRoleAttributeMinRollValue(roleId, attributeType)
local role = GetRole(roleId)
return role:GetAttributeMinRollValue(attributeType)
end
function XTRPGManager.GetRoleAttributeMaxRollValue(roleId, attributeType)
local role = GetRole(roleId)
return role:GetAttributeMaxRollValue(attributeType)
end
function XTRPGManager.GetRolesTotalCanRollValue(attributeType)
local totalMinValue, totalMaxValue = 0, 0
for roleId in pairs(Roles) do
totalMinValue = totalMinValue + XTRPGManager.GetRoleAttributeMinRollValue(roleId, attributeType)
totalMaxValue = totalMaxValue + XTRPGManager.GetRoleAttributeMaxRollValue(roleId, attributeType)
end
return totalMinValue, totalMaxValue
end
--请求激活天赋
function XTRPGManager.TRPGActivateTalentRequest(roleId, talentId, cb)
local req = { CharacterId = roleId, TalentId = talentId }
XNetwork.Call("TRPGActivateTalentRequest", req, function(res)
if res.Code ~= XCode.Success then
XUiManager.TipCode(res.Code)
return
end
if cb then
cb()
end
end)
end
--请求重置天赋
function XTRPGManager.TRPGResetTalentRequest(roleId, cb)
local req = { CharacterId = roleId }
XNetwork.Call("TRPGResetTalentRequest", req, function(res)
if res.Code ~= XCode.Success then
XUiManager.TipCode(res.Code)
return
end
if cb then
cb()
end
end)
end
function XTRPGManager.GetTalentPointTipsData()
local goodsShowParams = XGoodsCommonManager.GetGoodsShowParamsByTemplateId(XDataCenter.ItemManager.ItemId.TRPGTalen)
local data = {
Name = goodsShowParams.Name,
Count = XTRPGManager.GetRoleHaveTalentPoints(),
Icon = goodsShowParams.BigIcon or goodsShowParams.Icon,
Quality = goodsShowParams.Quality,
WorldDesc = XGoodsCommonManager.GetGoodsWorldDesc(XDataCenter.ItemManager.ItemId.TRPGTalen),
Description = XGoodsCommonManager.GetGoodsDescription(XDataCenter.ItemManager.ItemId.TRPGTalen),
IsTempItemData = true
}
return data
end
-----------------调查员 end----------------
-----------------背包begin----------------
local function UpdateCapacity(capacity)
AddItemMaxCountNum = capacity or 0
end
function XTRPGManager.GetItemMaxCount(itemId)
local maxCount = XTRPGConfigs.GetItemMaxCount(itemId)
maxCount = maxCount + AddItemMaxCountNum
return maxCount
end
function XTRPGManager.IsItemMaxCount(itemId)
local haveCount = XDataCenter.ItemManager.GetCount(itemId)
local maxCount = XTRPGManager.GetItemMaxCount(itemId)
return haveCount >= maxCount
end
function XTRPGManager.GetItemListByType(itemType)
local itemList = XDataCenter.ItemManager.GetItemsByType(XItemConfigs.ItemType.TRPGItem)
local itemTypeCfg
local list = {}
for _, v in ipairs(itemList) do
if not XTRPGManager.IsBagHideItem(v.Id) then
itemTypeCfg = XTRPGConfigs.GetItemType(v.Id)
if itemType == itemTypeCfg then
table.insert(list, v)
end
end
end
tableSort(list, function(itemA, itemB)
return itemA.Id < itemB.Id
end)
return list
end
function XTRPGManager.IsBagHideItem(id)
return BagHideItemIdList[id]
end
-----------------背包end------------------
-----------------奖励begin------------------
function XTRPGManager.IsReceiveReward(id)
return RewardList[id]
end
function XTRPGManager.CheckRewardCondition(trpgRewardId, secondMainId)
local conditionList = XTRPGConfigs.GetRewardCondition(trpgRewardId)
local conditionId = secondMainId and conditionList[2] or conditionList[1] --常规模式领取条件用2探索模式用1
if not XTool.IsNumberValid(conditionId) or XConditionManager.CheckCondition(conditionId) then
return true
end
return false
end
function XTRPGManager.GetAreaRewardPercent(areaId)
local areaState = XTRPGManager.GetAreaState(areaId)
if areaState == XTRPGConfigs.AreaStateType.NotOpen then
return 0
end
local areaRewardIdList = XTRPGConfigs.GetAreaRewardIdList(areaId)
local maxNum = #areaRewardIdList
local ret
local num = 0
for _, trpgRewardId in pairs(areaRewardIdList) do
ret = XTRPGManager.CheckRewardCondition(trpgRewardId)
if ret then
num = num + 1
end
end
return maxNum > 0 and num / maxNum or 0
end
function XTRPGManager.GetSecondMainStagePercent(secondMainId)
local secondMainStageIdList = XTRPGConfigs.GetSecondMainStageId(secondMainId)
local secondMainStageFinishNum = 0
local allSecondMainStageCount = #secondMainStageIdList
local stageId
for _, secondMainStageId in ipairs(secondMainStageIdList) do
stageId = XTRPGConfigs.GetSecondMainStageStageId(secondMainStageId)
if XTRPGManager.IsStagePass(stageId) then
secondMainStageFinishNum = secondMainStageFinishNum + 1
end
end
return allSecondMainStageCount > 0 and secondMainStageFinishNum / allSecondMainStageCount or 0
end
function XTRPGManager.CheckAreaRewardByAreaId(areaId)
local areaState = XDataCenter.TRPGManager.GetAreaState(areaId)
if areaState == XTRPGConfigs.AreaStateType.NotOpen then
return false
end
local areaRewardIdList = XTRPGConfigs.GetAreaRewardIdList(areaId)
local condition, ret
local isReceiveReward
for _, trpgRewardId in pairs(areaRewardIdList) do
ret = XTRPGManager.CheckRewardCondition(trpgRewardId)
isReceiveReward = XDataCenter.TRPGManager.IsReceiveReward(trpgRewardId)
if ret and not isReceiveReward then
return true
end
end
return false
end
function XTRPGManager.CheckAllAreaReward()
local mainAreaMaxNum = XTRPGConfigs.GetMainAreaMaxNum()
for areaId = 1, mainAreaMaxNum do
if XTRPGManager.CheckAreaRewardByAreaId(areaId) then
return true
end
end
return false
end
-----------------奖励end------------------
-----------------任务目标begin-----------------
function XTRPGManager.GetCurrTargetLinkId()
return CurrTargetLinkId
end
function XTRPGManager.GetCurrTargetId()
return CurrTargetId
end
function XTRPGManager.GetCurrTargetDesc()
local currTargetId = XTRPGManager.GetCurrTargetId()
return XTRPGConfigs.GetTargetDesc(currTargetId)
end
function XTRPGManager.IsTargetFinish(target)
local notPreTargetId = XTRPGConfigs.GetNotPreTargetId()
if type(target) == "string" then --目标类型string的是前置目标
local preTargetList = string.Split(target, "|")
local preTargetId
local isFinish
for _, preTargetIdStr in ipairs(preTargetList) do
isFinish = false
preTargetId = tonumber(preTargetIdStr)
if preTargetId == notPreTargetId then
return true
end
if TargetList[preTargetId] then
isFinish = true
end
if not isFinish then
break
end
end
return isFinish
else
if target == notPreTargetId then
return true
end
return TargetList[target]
end
end
--return 目标链是否完成未完成的目标id
function XTRPGManager.GetTargetLinkIsFinish(targetLinkId)
if not targetLinkId or targetLinkId == 0 then
return true, 0
end
local targetIsFinish
local preTargetIsFinish
local preTarget
local targetIdList = XTRPGConfigs.GetTargetIdList(targetLinkId)
for _, targetId in pairs(targetIdList) do
targetIsFinish = XTRPGManager.IsTargetFinish(targetId)
preTarget = XTRPGConfigs.GetPreTargetByTargetId(targetId)
preTargetIsFinish = XTRPGManager.IsTargetFinish(preTarget)
if not targetIsFinish and preTargetIsFinish then
return false, targetId
end
end
return true, 0
end
function XTRPGManager.GetAllCanFindTargetLink()
local targetLinkTemplate = XTRPGConfigs.GetTargetLinkTemplate()
local allCanFindTarget = {
[XTRPGConfigs.MissionType.MainLine] = {},
}
local targetMissionType
local targetIsFinish
local preTargetIsFinish
for _, v in pairs(targetLinkTemplate) do
local isInsert = false
for index, targetId in ipairs(v.TargetId) do
targetIsFinish = XTRPGManager.IsTargetFinish(targetId)
preTargetIsFinish = XTRPGManager.IsTargetFinish(v.PreTarget[index])
if v.TargetMissionType == XTRPGConfigs.MissionType.SubLine and index == 1 and preTargetIsFinish then
isInsert = true
end
if not targetIsFinish and preTargetIsFinish then
local targetTable = { TargetLinkId = v.Id, TargetId = targetId }
targetMissionType = XTRPGConfigs.GetTargetLinkMissionType(v.Id)
if not allCanFindTarget[targetMissionType] then
allCanFindTarget[targetMissionType] = {}
end
tableInsert(allCanFindTarget[targetMissionType], targetTable)
isInsert = false
break
end
end
if isInsert then
if not allCanFindTarget[XTRPGConfigs.MissionType.SubLine] then
allCanFindTarget[XTRPGConfigs.MissionType.SubLine] = {}
end
tableInsert(allCanFindTarget[XTRPGConfigs.MissionType.SubLine], { TargetLinkId = v.Id, TargetId = 0 })
end
end
return allCanFindTarget
end
function XTRPGManager.GetOneCanFindTarget()
local targetLinkTemplate = XTRPGConfigs.GetTargetLinkTemplate()
local targetId
local targetLinkIsFinish
for _, v in pairs(targetLinkTemplate) do
targetLinkIsFinish, targetId = XTRPGManager.GetTargetLinkIsFinish(v.Id)
if not targetLinkIsFinish then
return v.Id, targetId
end
end
return 0, 0
end
function XTRPGManager.IsTargetAllFinish()
local targetTotalNum = XTRPGConfigs.GetTargetTotalNum()
local finishTargetNum = 0
for _ in pairs(TargetList) do
finishTargetNum = finishTargetNum + 1
end
return targetTotalNum == finishTargetNum
end
function XTRPGManager.GetTargetLinkPercent(targetLinkId)
local targetIdList = XTRPGConfigs.GetTargetIdList(targetLinkId)
local finishNum = 0
local totalNum = #targetIdList
for _, targetId in pairs(targetIdList) do
if XTRPGManager.IsTargetFinish(targetId) then
finishNum = finishNum + 1
end
end
return totalNum == 0 and 0 or finishNum / totalNum
end
function XTRPGManager.GetMainLineTargetLinkPercentByAreaId(areaId)
local targetLinkIdList = XTRPGConfigs.GetTargetLinkIdList(areaId)
for _, targetLinkId in pairs(targetLinkIdList) do
local msiionType = XTRPGConfigs.GetTargetLinkMissionType(targetLinkId)
if msiionType == XTRPGConfigs.MissionType.MainLine then
return XTRPGManager.GetTargetLinkPercent(targetLinkId)
end
end
return 0
end
function XTRPGManager.IsMovieTargetFinish(movieId)
local targetId = XTRPGConfigs.GetMovieTargetId(movieId)
if not targetId or targetId == 0 then
return false
end
return XTRPGManager.IsTargetFinish(targetId)
end
function XTRPGManager.CheckRequestTargetLink(currTargetLinkId)
local notTargetLinkDefaultId = XTRPGConfigs.NotTargetLinkDefaultId
if notTargetLinkDefaultId == currTargetLinkId and notTargetLinkDefaultId ~= CurrTargetLinkId then
XDataCenter.TRPGManager.RequestSelectTargetLinkSend(CurrTargetLinkId, true)
end
end
function XTRPGManager.CheckOpenNewMazeTips()
if not IsCanCheckOpenNewMaze then return end
SetIsCanCheckOpenNewMaze(false)
local secondAreaIdToMazeIdDic = XTRPGConfigs.GetSecondAreaIdToMazeIdDic()
local condition, ret
local name
local msg
for secondAreaId, mazeId in pairs(secondAreaIdToMazeIdDic) do
if not IsOpenMaze(mazeId) then
condition = XTRPGConfigs.GetSecondAreaCondition(secondAreaId)
ret = XConditionManager.CheckCondition(condition)
if ret then
UpdateAlreadyOpenMaze(mazeId)
name = XTRPGConfigs.GetSecondAreaName(secondAreaId)
msg = CSXTextManagerGetText("TRPGAreaAleardyOpen", name)
XUiManager.TipMsgEnqueue(msg)
end
end
end
end
function XTRPGManager.GetTaskPanelNewShowTime()
local oldCurrTargetId = GetOldCurrTargetId()
local currTargetId = XTRPGManager.GetCurrTargetId()
if oldCurrTargetId ~= currTargetId then
UpdateOldCurrTargetId()
local serverTimestamp = XTime.GetServerNowTimestamp()
local taskPanelNewShowTimeCfg = XTRPGConfigs.GetTaskPanelNewShowTime()
return serverTimestamp + taskPanelNewShowTimeCfg
end
return 0
end
function XTRPGManager.SetNewTargetTime(newTargetTime)
NewTargetTime = newTargetTime
end
function XTRPGManager.GetNewTargetTime()
return NewTargetTime
end
function XTRPGManager.ClearNewTargetTime()
NewTargetTime = 0
end
-----------------任务目标end------------------
-----------------求真之路begin------------------
function XTRPGManager.GetTruthRoadPercent(truthRoadGroupId)
local truthRoadIdList = XTRPGConfigs.GetTruthRoadIdList(truthRoadGroupId)
local truthRoadFinishNum = 0
for _, truthRoadId in pairs(truthRoadIdList) do
local condition = XTRPGConfigs.GetTruthRoadCondition(truthRoadId)
local ret = XConditionManager.CheckCondition(condition)
if ret then
truthRoadFinishNum = truthRoadFinishNum + 1
end
end
return #truthRoadIdList > 0 and truthRoadFinishNum / #truthRoadIdList or 0
end
function XTRPGManager.IsTruthRoadOpenArea(areaId)
local truthRoadGroupIdList = XTRPGConfigs.GetTruthRoadGroupIdList(areaId)
local condition
local ret
for i, truthRoadGroupId in ipairs(truthRoadGroupIdList) do
condition = XTRPGConfigs.GetTruthRoadGroupCondition(truthRoadGroupId)
ret = XConditionManager.CheckCondition(condition)
if ret then
return true, i
end
end
return false
end
function XTRPGManager.IsTruthRoadGroupConditionFinish(areaId, index)
local truthRoadGroupId = XTRPGConfigs.GetTruthRoadGroupId(areaId, index)
local condition = XTRPGConfigs.GetTruthRoadGroupCondition(truthRoadGroupId)
local ret, desc = XConditionManager.CheckCondition(condition)
return ret, desc
end
function XTRPGManager.CheckTruthRoadReward(truthRoadGroupId)
local rewardIdList = XTRPGConfigs.GetTruthRoadRewardIdList(truthRoadGroupId)
local conditionId, ret
local isReceiveReward
for _, trpgRewardId in ipairs(rewardIdList) do
ret = XTRPGManager.CheckRewardCondition(trpgRewardId)
isReceiveReward = XTRPGManager.IsReceiveReward(trpgRewardId)
if ret and not isReceiveReward then
return true
end
end
return false
end
function XTRPGManager.CheckTruthRoadAreaReward(areaId)
local truthRoadGroupIdList = XTRPGConfigs.GetTruthRoadGroupIdList(areaId)
for _, truthRoadGroupId in ipairs(truthRoadGroupIdList) do
if XTRPGManager.CheckTruthRoadReward(truthRoadGroupId) then
return true
end
end
return false
end
function XTRPGManager.CheckTruthRoadAllReward()
local mainAreaMaxNum = XTRPGConfigs.GetMainAreaMaxNum()
for i = 1, mainAreaMaxNum do
if XTRPGManager.CheckTruthRoadAreaReward(i) then
return true
end
end
return false
end
function XTRPGManager.SaveIsAlreadyOpenTruthRoad()
if not XSaveTool.GetData(stringFormat("%d%s", XPlayer.Id, "IsAlreadyOpenTruthRoad")) then
XSaveTool.SaveData(stringFormat("%d%s", XPlayer.Id, "IsAlreadyOpenTruthRoad"), true)
XEventManager.DispatchEvent("EVENT_TRPG_FIRST_OPEN_TRUTH_ROAD")
end
end
function XTRPGManager.CheckIsAlreadyOpenTruthRoad()
return XSaveTool.GetData(stringFormat("%d%s", XPlayer.Id, "IsAlreadyOpenTruthRoad")) or false
end
-----------------求真之路end--------------------
---------------------珍藏-回忆begin-------------------------
function XTRPGManager.IsPlayedMemoir(id)
return MemoirList[id]
end
function XTRPGManager.IsCanPlayMemoir(id)
local itemId = XTRPGConfigs.GetMemoireStoryUnlockItemId(id)
local ownCount = XDataCenter.ItemManager.GetCount(itemId)
local maxCount = XTRPGConfigs.GetMemoireStoryUnlockItemCount(id)
return ownCount >= maxCount
end
function XTRPGManager.CheckFirstPlayMemoirStoryById(id)
local isCanPlay = XTRPGManager.IsCanPlayMemoir(id)
local isPlayed = XTRPGManager.IsPlayedMemoir(id)
return isCanPlay and not isPlayed
end
function XTRPGManager.CheckFirstPlayMemoirStory()
local maxNum = XTRPGConfigs.GetMemoirStoryMaxNum()
for i = 1, maxNum do
if XTRPGManager.CheckFirstPlayMemoirStoryById(i) then
return true
end
end
return false
end
function XTRPGManager.SaveIsAlreadyOpenCollection()
if not XSaveTool.GetData(string.format("%d%s", XPlayer.Id, "IsAlreadyOpenCollection")) then
XSaveTool.SaveData(string.format("%d%s", XPlayer.Id, "IsAlreadyOpenCollection"), true)
XEventManager.DispatchEvent("EVENT_TRPG_FIRST_OPEN_COLLECTION")
end
end
function XTRPGManager.CheckIsAlreadyOpenCollection()
return XSaveTool.GetData(stringFormat("%d%s", XPlayer.Id, "IsAlreadyOpenCollection")) or false
end
---------------------珍藏-回忆end---------------------------
---------------------第三区域 begin-------------------------
local function SetThirdAreaFunctionFinish(thirdAreaId, functionId)
thirdAreaId = DEFUALT_thirdAreaId_FOR_STUPID_DESIGN or thirdAreaId
if not ThirdAreaInfos[thirdAreaId] then
ThirdAreaInfos[thirdAreaId] = XTRPGThirdAreaInfo.New()
end
ThirdAreaInfos[thirdAreaId]:SetFunctionFinished(functionId)
end
local function UpdateThirdAreaInfos(thirdAreaInfos)
if not thirdAreaInfos then return end
if DEFUALT_thirdAreaId_FOR_STUPID_DESIGN then
local thirdAreaId = DEFUALT_thirdAreaId_FOR_STUPID_DESIGN
for _, functionId in pairs(thirdAreaInfos) do
SetThirdAreaFunctionFinish(thirdAreaId, functionId)
end
return
end
for thirdAreaId, functionIds in pairs(thirdAreaInfos) do
for _, functionId in pairs(functionIds) do
SetThirdAreaFunctionFinish(thirdAreaId, functionId)
end
end
end
local function GetThirdAreaInfo(thirdAreaId)
thirdAreaId = DEFUALT_thirdAreaId_FOR_STUPID_DESIGN or thirdAreaId
return ThirdAreaInfos[thirdAreaId]
end
function XTRPGManager.IsFunctionGroupConditionFinish(functionGroupId)
local condition = XTRPGConfigs.GetFunctionGroupConditionId(functionGroupId)
local ret, desc = XConditionManager.CheckCondition(condition)
return ret, desc
end
function XTRPGManager.IsThirdAreaFunctionFinish(thirdAreaId, functionId)
local areaInfo = GetThirdAreaInfo(thirdAreaId)
return areaInfo and areaInfo:IsFunctionFinished(functionId)
end
function XTRPGManager.IsThirdAreaFunctionAllFinish(thirdAreaId)
return #XTRPGManager.GetUnFinishedFunctionIdList(thirdAreaId) == 0
end
function XTRPGManager.GetUnFinishedFunctionIdList(thirdAreaId)
local functionIdList = {}
local functionGroupIds = XTRPGConfigs.GetThirdAreaFunctionGroupIds(thirdAreaId)
for _, functionGroupId in ipairs(functionGroupIds) do
if XTRPGManager.IsFunctionGroupConditionFinish(functionGroupId) then
local functionIds = XTRPGConfigs.GetFunctionGroupFunctionIds(functionGroupId)
for _, functionId in ipairs(functionIds) do
if not XTRPGManager.IsThirdAreaFunctionFinish(thirdAreaId, functionId) then
tableInsert(functionIdList, functionId)
break
end
end
end
end
return functionIdList
end
local __ToFinishFightFunctionId = 0 --战斗胜利后请求完成的FunctionId
function XTRPGManager.EnterFunctionFight(functionId)
if not XTRPGConfigs.CheckFunctionType(functionId, XTRPGConfigs.TRPGFunctionType.FinishStage) then
return
end
__ToFinishFightFunctionId = functionId
local params = XTRPGConfigs.GetFunctionParams(functionId)
local stageId = tonumber(params[1])
XLuaUiManager.Open("UiNewRoomSingle", stageId)
end
function XTRPGManager.ReqFinishFunctionAfterFight(thirdAreaId)
local functionId = __ToFinishFightFunctionId
if not functionId or functionId == 0 then return end
XDataCenter.TRPGManager.RequestFunctionFinishSend(thirdAreaId, functionId)
end
--请求完成功能id
function XTRPGManager.RequestFunctionFinishSend(thirdAreaId, functionId)
if not XTRPGConfigs.CheckFunctionNeedSave(functionId) then return end
local req = { FunctionId = functionId }
XNetwork.Call("TRPGFunctionFinishRequest", req, function(res)
if res.Code ~= XCode.Success then
XUiManager.TipCode(res.Code)
return
end
if XTRPGConfigs.CheckFunctionType(functionId, XTRPGConfigs.TRPGFunctionType.CommitItem) then
local params = XTRPGConfigs.GetFunctionParams(functionId)
local itemId = tonumber(params[1])
XLuaUiManager.Open("UiTRPGCommitItem", itemId)
end
XTRPGManager.OnGetReward(res.RewardList)
SetThirdAreaFunctionFinish(thirdAreaId, functionId)
XEventManager.DispatchEvent(XEventId.EVENT_TRPG_FUNCTION_FINISH_SYN)
end)
end
function XTRPGManager.OnGetReward(rewardList, closeCb)
if XTool.IsTableEmpty(rewardList) then return end
local reward = rewardList[1]
local itemId = reward.TemplateId
local itemCount = reward.Count
XLuaUiManager.Open("UiTRPGObtain", itemId, itemCount, closeCb)
end
---------------------第三区域 end---------------------------
---------------------世界BOSS begin--------------------
function XTRPGManager.GetWorldBossLoseHp()
return BossInfo:GetLoseHp()
end
function XTRPGManager.GetWorldBossTotalHp()
return BossInfo:GetTotalHp()
end
function XTRPGManager.GetWorldBossCurHpPercer()
local loseHp = XDataCenter.TRPGManager.GetWorldBossLoseHp()
local totalHp = XDataCenter.TRPGManager.GetWorldBossTotalHp()
return totalHp > 0 and (totalHp - loseHp) / totalHp or 0
end
function XTRPGManager.IsWorldBossAleardyReceiveReward(id)
return BossInfo:IsReceiveReward(id)
end
function XTRPGManager.IsWorldBossCanReceiveReward(id)
local curPercent = XTRPGManager.GetWorldBossCurHpPercer()
local percentCfg = XTRPGConfigs.GetBossPhasesRewardPercent(id)
percentCfg = percentCfg * 0.01
return curPercent <= percentCfg
end
function XTRPGManager.GetWorldBossChallengeCount()
return BossInfo:GetChallengeCount()
end
function XTRPGManager.GetWorldBossOpenState()
local nowTime = XTime.GetServerNowTimestamp()
local timeId = XTRPGConfigs.GetBossTimeId()
local startTime, endTime = XFunctionManager.GetTimeByTimeId(timeId)
if nowTime < startTime then
return XTRPGConfigs.AreaStateType.NotOpen, startTime - nowTime
elseif nowTime >= startTime and nowTime < endTime then
return XTRPGConfigs.AreaStateType.Open, endTime - nowTime
else
return XTRPGConfigs.AreaStateType.Over, 0
end
end
function XTRPGManager.CheckWorldBossReward()
local openState = XTRPGManager.GetWorldBossOpenState()
if openState ~= XTRPGConfigs.AreaStateType.Open then
return false
end
local isAleardyReceive
local isCanReceive
local bossPhasesRewardTemplate = XTRPGConfigs.GetBossPhasesRewardTemplate()
for _, v in pairs(bossPhasesRewardTemplate) do
isCanReceive = XDataCenter.TRPGManager.IsWorldBossCanReceiveReward(v.Id)
isAleardyReceive = XDataCenter.TRPGManager.IsWorldBossAleardyReceiveReward(v.Id)
if isCanReceive and not isAleardyReceive then
return true
end
end
return false
end
---------------------世界BOSS end---------------------
---------------------检定相关 begin---------------------------
function XTRPGManager.GetExamineActionDifficult(actionId)
--道具检定无难度
if XTRPGConfigs.CheckExamineActionType(actionId, XTRPGConfigs.TRPGExamineActionType.ConsumeItem) then
return XTRPGConfigs.TRPGExamineActionDifficult.Default
end
local needValue = XTRPGConfigs.GetExamineActionNeedValue(actionId)
local _, totalMaxValue = XTRPGManager.GetExamineActionTotalCallRollValue(actionId)
local delta = totalMaxValue - needValue
return XTRPGConfigs.GetExamineActionDifficultByDelta(delta)
end
--return 所有角色单属性所有轮次可摇点最小值,最大值
function XTRPGManager.GetExamineActionTotalCallRollValue(actionId)
local attributeType = XTRPGConfigs.GetExamineActionNeedAttrType(actionId)
local totalMinValue, totalMaxValue = XTRPGManager.GetRolesTotalCanRollValue(attributeType)
local round = XTRPGConfigs.GetExamineActionRound(actionId)
return round * totalMinValue, round * totalMaxValue
end
function XTRPGManager.CheckExamineCostEnduranceEnough(examineId)
local costEndurance = XTRPGConfigs.GetExamineCostEndurance(examineId)
local curEndurance = XTRPGManager.GetExploreCurEndurance()
return curEndurance >= costEndurance
end
function XTRPGManager.EnterExamine(examineId)
local enterFunc = function()
XLuaUiManager.Open("UiTRPGTestDetailsTips", examineId)
end
local endCallBack = function()
XDataCenter.TRPGManager.CheckOpenNewMazeTips()
end
local movieId = XTRPGConfigs.GetExamineStartMovieId(examineId)
if not string.IsNilOrEmpty(movieId) then
local yieldCb = enterFunc
local hideSkipBtn = true
XDataCenter.MovieManager.PlayMovie(movieId, endCallBack, yieldCb, hideSkipBtn)
else
XLuaUiManager.Open("UiTRPGTestDetailsTips", examineId)
end
end
function XTRPGManager.StartExamine(examineId, actionId)
CurExmaine:Start(examineId, actionId)
XLuaUiManager.Open("UiTRPGTest")
end
function XTRPGManager.FinishExamine()
CurExmaine:Clear()
end
function XTRPGManager.EnterExaminePunish()
CurExmaine:EnterPunish()
end
function XTRPGManager.GetCurExamineId()
return CurExmaine:GetId()
end
function XTRPGManager.GetCurExamineActionId()
return CurExmaine:GetActionId()
end
function XTRPGManager.GetCurExamineCurAndReqScore()
return CurExmaine:GetScores()
end
function XTRPGManager.GetCurExamineCurRound()
return CurExmaine:GetCurRound()
end
function XTRPGManager.GetCurExamineRoleScore(roleId)
return CurExmaine:GetRoleScore(roleId)
end
function XTRPGManager.CheckExamineStatus(examineStatus)
return CurExmaine:CheckStatus(examineStatus)
end
function XTRPGManager.IsExaminePassed()
return CurExmaine:IsPassed()
end
function XTRPGManager.IsExamineCanEnterNextRound()
return CurExmaine:IsCanEnternNextRound()
end
function XTRPGManager.IsExamineRoleAlreadyRolled(roleId)
return CurExmaine:IsRoleAlreadyRolled(roleId)
end
function XTRPGManager.IsExamineLastRound()
return CurExmaine:IsLastRound()
end
function XTRPGManager.GetCurExaminePunishId()
return CurExmaine:GetPunishId()
end
local function UpdateCurExmaineResult(data)
if XTool.IsTableEmpty(data) then return end
CurExmaine:UpdateResult(data)
CsXGameEventManager.Instance:Notify(XEventId.EVENT_TRPG_EXAMINE_RESULT_SYN)
end
local function UpdateCurExmaineScore(data)
if XTool.IsTableEmpty(data) then return end
CurExmaine:UpdateScore(data)
CsXGameEventManager.Instance:Notify(XEventId.EVENT_TRPG_EXAMINE_DATA_CHANGE)
end
--请求检定
local ExamineAsynLock
function XTRPGManager.RequestExamineSend(examineId, actionId, cb)
if ExamineAsynLock then return end
ExamineAsynLock = true
local req = { Id = examineId, ActionId = actionId }
XNetwork.Call("TRPGExamineRequest", req, function(res)
ExamineAsynLock = nil
if res.Code ~= XCode.Success then
XUiManager.TipCode(res.Code)
return
end
if cb then cb() end
XTRPGManager.StartExamine(examineId, actionId)
end)
end
--请求检定单个角色
function XTRPGManager.RequestExamineCharacterSend(examineId, actionId, roleId, useItemId)
local curRound = XTRPGManager.GetCurExamineCurRound()
if XTRPGConfigs.CheckDefaultEffectItemId(useItemId) then
useItemId = nil
end
local req = { Id = examineId, ActionId = actionId, Round = curRound, CharacterId = roleId, UseItemId = useItemId }
XNetwork.Call("TRPGExamineCharacterRequest", req, function(res)
if res.Code ~= XCode.Success then
XUiManager.TipCode(res.Code)
return
end
local data = {
RoleId = roleId,
Score = res.Score,
}
UpdateCurExmaineScore(data)
end)
end
--确定检定结果
function XTRPGManager.RequestExamineResult(examineId)
local req = { Id = examineId }
XNetwork.Call("TRPGExamineResultRequest", req, function(res)
if res.Code ~= XCode.Success then
XUiManager.TipCode(res.Code)
return
end
UpdateCurExmaineResult(res)
end)
end
--重置检定
function XTRPGManager.TRPGExamineCharacterResetRequest(roleId)
local req = { CharacterId = roleId }
XNetwork.Call("TRPGExamineCharacterResetRequest", req, function(res)
if res.Code ~= XCode.Success then
XUiManager.TipCode(res.Code)
return
end
local data = {
RoleId = roleId,
Score = 0,
}
UpdateCurExmaineScore(data)
end)
end
--进入下一轮检定
function XTRPGManager.TRPGExamineChangeRoundRequest()
XNetwork.Call("TRPGExamineChangeRoundRequest", nil, function(res)
if res.Code ~= XCode.Success then
XUiManager.TipCode(res.Code)
return
end
CurExmaine:EnterNextRound()
CsXGameEventManager.Instance:Notify(XEventId.EVENT_TRPG_EXAMINE_ROUND_CHANGE)
end)
end
---------------------检定相关 end---------------------------
---------------------protocol begin------------------
--商店购买
function XTRPGManager.RequestShopBuyItemSend(shopId, itemId, itemCount, cb)
local req = { ShopId = shopId, ItemId = itemId, ItemCount = itemCount }
XNetwork.Call("TRPGShopBuyItemRequest", req, function(res)
if res.Code ~= XCode.Success then
XUiManager.TipCode(res.Code)
return
end
AddBuyTimes(shopId, itemId, itemCount)
XUiManager.OpenUiObtain(res.RewardList)
if cb then
cb()
end
end)
end
--更新探索员信息
function XTRPGManager.NotifyTRPGCharacterData(data)
local checkNew = true
UpdateRoles(data.Characters, checkNew)
end
--更新已完成目标(增量更新)
function XTRPGManager.NotifyTRPGTargetFinish(data)
local tempCurrTargetLinkId = CurrTargetLinkId
UpdateTargetList(data.TargetList)
UpdateCurrTargetLinkId(CurrTargetLinkId)
SetIsCanCheckOpenNewMaze(true)
if tempCurrTargetLinkId ~= CurrTargetLinkId then
XTRPGManager.CheckRequestTargetLink(XTRPGConfigs.NotTargetLinkDefaultId)
end
end
function XTRPGManager.NotifyTRPGFunctionFinish(data)
end
--更新商店打折和购买上限
function XTRPGManager.NotifyTRPGShopExtraData(data)
UpdateShopExtraData(data.ExtraDatas)
end
--更新商店信息
function XTRPGManager.NotifyTRPGClientShopInfo(data)
UpdateShopInfos(data.ShopInfos)
end
--重置数据
function XTRPGManager.NotifyTRPGDailyResetData(data)
BaseInfo:UpdateEndurance(data.Endurance)
UpdateCapacity(data.ItemCapacityAdd)
UpdateRoles(data.Characters)
UpdateWorldBossChallengeCount(data.BossChallengeCount)
UpdateShopInfos(data.ShopInfos)
end
function XTRPGManager.RequestSelectTargetLinkSend(targetLinkid, isHideTip, isNotPlayNewAnima)
local req = { Id = targetLinkid }
XNetwork.Call("TRPGSelectTargetLinkRequest", req, function(res)
if res.Code ~= XCode.Success then
XUiManager.TipCode(res.Code)
return
end
UpdateCurrTargetLinkId(targetLinkid, isNotPlayNewAnima)
if not isHideTip then
XUiManager.TipText("TRPGSwitchTargetComplete")
end
end)
end
function XTRPGManager.NotifyTRPGItemCapacityChange(data)
UpdateCapacity(data.ItemCapacityAdd)
end
function XTRPGManager.NotifyTRPGBaseInfo(data)
BaseInfo:UpdateData(data.BaseInfo)
end
function XTRPGManager.NotifyTRPGData(data)
UpdateBossInfo(data.BossInfo)
UpdateTargetList(data.TargetList)
UpdateCurrTargetLinkId(data.CurTargetLink)
UpdateRewardList(data.RewardList)
UpdateRoles(data.Characters)
UpdateShopInfos(data.ShopInfos)
UpdateMazeInfos(data.MazeInfos)
UpdateMemoirInfos(data.MemoirList)
UpdateCapacity(data.ItemCapacityAdd)
BaseInfo:UpdateData(data.BaseInfo)
-- UpdateThirdAreaInfos(data.ThirdAreaInfos)--数据预期不一致兼容
UpdateThirdAreaInfos(data.FuncList)
SetIsNormalPage(data.IsNormalPage)
UpdateStagePassDic(data.StageList)
InitAleardyOpenMazeList()
UpdateOldCurrTargetId()
XTRPGManager.CheckRequestTargetLink(data.CurTargetLink)
XTRPGManager.RequestTRPGBossDetailSend()
end
--使用道具
function XTRPGManager.RequestUseItemRequestSend(itemId, itemCount, characterId, cb)
local req = { ItemId = itemId, ItemCount = itemCount, CharacterId = characterId }
XNetwork.Call("TRPGUseItemRequest", req, function(res)
if res.Code ~= XCode.Success then
XUiManager.TipCode(res.Code)
return
end
XUiManager.TipText("TRPGUseItemComplete")
if cb then
cb()
end
end)
end
--请求领取奖励
function XTRPGManager.RequestRewardSend(id, cb)
local req = { Id = id }
XNetwork.Call("TRPGRewardRequest", req, function(res)
if res.Code ~= XCode.Success then
XUiManager.TipCode(res.Code)
return
end
UpdateRewardList({ id })
XUiManager.OpenUiObtain(res.RewardList)
if cb then
cb()
end
XEventManager.DispatchEvent("EVENT_TRPG_GET_REWARD")
end)
end
--请求播放记忆剧情
function XTRPGManager.RequestTRPGOpenMemoirSend(id, cb)
local req = { Id = id }
XNetwork.Call("TRPGOpenMemoirRequest", req, function(res)
if res.Code ~= XCode.Success then
XUiManager.TipCode(res.Code)
return
end
UpdateMemoirInfos({ req.Id })
if cb then
cb()
end
XEventManager.DispatchEvent("EVENT_TRPG_GET_MEMOIR_REWARD")
end)
end
--请求boss血量
function XTRPGManager.RequestTRPGBossDetailSend(cb)
local openState = XTRPGManager.GetWorldBossOpenState()
if openState ~= XTRPGConfigs.AreaStateType.Open then
return
end
XNetwork.Call("TRPGBossDetailRequest", nil, function(res)
if res.Code ~= XCode.Success then
XUiManager.TipCode(res.Code)
return
end
UpdateBossHpInfo(res)
if cb then
cb()
end
end)
end
--请求boss阶段奖励
function XTRPGManager.RequestTRPGBossPhasesRewardSend(id, cb)
local req = { Id = id }
XNetwork.Call("TRPGBossPhasesRewardRequest", req, function(res)
if res.Code ~= XCode.Success then
XUiManager.TipCode(res.Code)
return
end
UpdateBossPhasesRewardListInfo({ req.Id })
XUiManager.OpenUiObtain(res.RewardList)
if cb then
cb()
end
end)
end
--世界BOSS信息发生改变
function XTRPGManager.NotifyTRPGClientBossData(data)
UpdateBossInfo(data.BaseInfo)
end
--请求改变模式
function XTRPGManager.RequestTRPGChangePageStatus(status)
local req = {Status = status}
XNetwork.Call("TRPGChangePageStatusRequest", req, function(res)
if res.Code ~= XCode.Success then
XUiManager.TipCode(res.Code)
return
end
SetIsNormalPage(status)
end)
end
---------------------protocol end------------------
---------------------FubenManager begin------------------
local function InitStageType(stageId)
stageId = tonumber(stageId)
local stageInfo = XDataCenter.FubenManager.GetStageInfo(stageId)
if stageInfo then
stageInfo.Type = XDataCenter.FubenManager.StageType.TRPG
end
end
function XTRPGManager.InitStageInfo()
local stageId = XTRPGConfigs.GetBossStageId()
InitStageType(stageId)
local stageIds = XTRPGConfigs.GetFunctionStageIds()
for _, stageId in pairs(stageIds) do
InitStageType(stageId)
end
local secondMainIdList = XTRPGConfigs.GetSecondMainIdList()
for _, secondMainId in ipairs(secondMainIdList) do
local secondMainStageIdList = XTRPGConfigs.GetSecondMainStageId(secondMainId)
for _, secondMainStageId in ipairs(secondMainStageIdList) do
local stageId = XTRPGConfigs.GetSecondMainStageStageId(secondMainStageId)
InitStageType(stageId)
end
end
end
function XTRPGManager.ShowReward(winData)
if XTRPGConfigs.IsBossStage(winData.StageId) then
XLuaUiManager.Open("UiTRPGWinWorldBoss", winData)
else
XTRPGManager.ReqFinishFunctionAfterFight()
XDataCenter.FubenManager.ShowReward(winData)
end
XTRPGManager.SetStagePass(winData.StageId)
end
---------------------FubenManager end------------------
function XTRPGManager.Init()
InitMazes()
XEventManager.AddEventListener(XEventId.EVENT_LOGIN_DATA_LOAD_COMPLETE, function()
XDataCenter.TRPGManager.InitCurrAreaOpenNum()
end)
end
--------------------首次播放剧情 begin------------------------
function XTRPGManager.MarkStoryID(Id, key)
if not XSaveTool.GetData(string.format("%d%s%s", XPlayer.Id, key, Id)) then
XSaveTool.SaveData(string.format("%d%s%s", XPlayer.Id, key, Id), Id)
end
end
function XTRPGManager.CheckIsNewStoryID(Id, key)
if XSaveTool.GetData(string.format("%d%s%s", XPlayer.Id, key, Id)) then
return false
end
return true
end
--------------------首次播放剧情 end--------------------------
--------------------跳转 start--------------------------
function XTRPGManager.SkipTRPGMain()
if XDataCenter.FubenMainLineManager.IsMainLineActivityOpen() then
local chapterId = XDataCenter.FubenMainLineManager.TRPGChapterId
local ret, desc = XDataCenter.FubenMainLineManager.CheckActivityCondition(chapterId)
if ret then
XTRPGManager.PlayStartStory(XTRPGManager.UpdateCurrAreaOpenNum)
else
XUiManager.TipError(desc)
end
elseif XFunctionManager.DetectionFunction(XFunctionManager.FunctionName.MainLineTRPG) then
XTRPGManager.PlayStartStory(XTRPGManager.UpdateCurrAreaOpenNum)
end
end
function XTRPGManager.GetMainName()
local isNormalPage = XTRPGManager.IsNormalPage()
return isNormalPage and "UiTRPGSecondMain" or "UiTRPGMain"
end
--------------------跳转 end--------------------------
--------------------抢先体验 begin---------------------
function XTRPGManager.CheckActivityEnd()
if not XDataCenter.FubenMainLineManager.IsMainLineActivityOpen() and not XFunctionManager.JudgeCanOpen(XFunctionManager.FunctionName.MainLineTRPG) then
XTRPGManager.OnActivityEnd()
end
end
function XTRPGManager.OnActivityMainLineStateChange(chapterIds)
if not chapterIds then
return
end
for _, chapterId in pairs(chapterIds) do
if chapterId == XDataCenter.FubenMainLineManager.TRPGChapterId then
XTRPGManager.OnActivityEnd()
return
end
end
end
function XTRPGManager.OnActivityEnd()
if CS.XFight.IsRunning or XLuaUiManager.IsUiLoad("UiLoading") then
return
end
XUiManager.TipText("ActivityMainLineEnd")
XLuaUiManager.RunMain()
end
--------------------抢先体验 end---------------------
--------------------区域(城市和迷宫)地图 start---------------------
function XTRPGManager.SaveIsAlreadyOpenExploreChapter(secondAreaId, mainAreaId)
if not XSaveTool.GetData(stringFormat("%d%s%s%s", XPlayer.Id, "IsAlreadyOpenExploreChapter", secondAreaId, mainAreaId)) then
XSaveTool.SaveData(stringFormat("%d%s%s%s", XPlayer.Id, "IsAlreadyOpenExploreChapter", secondAreaId, mainAreaId), true)
end
end
function XTRPGManager.CheckIsAlreadyOpenExploreChapter(secondAreaId, mainAreaId)
return XSaveTool.GetData(stringFormat("%d%s%s%s", XPlayer.Id, "IsAlreadyOpenExploreChapter", secondAreaId, mainAreaId)) or false
end
function XTRPGManager.SaveIsAlreadyEnterMaze(mazeId)
if not XSaveTool.GetData(stringFormat("%d%s%s", XPlayer.Id, "IsAlreadyEnterMaze", mazeId)) then
XSaveTool.SaveData(stringFormat("%d%s%s", XPlayer.Id, "IsAlreadyEnterMaze", mazeId), true)
end
end
function XTRPGManager.CheckIsAlreadyEnterMaze(mazeId)
local mazeProgress = XTRPGManager.GetMazeProgress(mazeId)
if mazeProgress > 0 or XSaveTool.GetData(stringFormat("%d%s%s", XPlayer.Id, "IsAlreadyEnterMaze", mazeId)) then
return true
end
return false
end
--------------------区域(城市和迷宫)地图 end---------------------
--------------------常规主线 start---------------------
--是否有可领取的奖励
function XTRPGManager.IsSecondMainCanReward(secondMainId)
local ret = XTRPGManager.CheckSecondMainCondition(secondMainId)
if not ret then
return false
end
local secondMainStageIdList = XTRPGConfigs.GetSecondMainStageId(secondMainId)
local trpgRewardId
local isReceiveReward
for _, secondMainStageId in ipairs(secondMainStageIdList) do
trpgRewardId = XTRPGConfigs.GetSecondMainStageRewardId(secondMainStageId)
if not XTool.IsNumberValid(trpgRewardId) then
goto continue
end
ret = XTRPGManager.CheckRewardCondition(trpgRewardId, secondMainId)
isReceiveReward = XDataCenter.TRPGManager.IsReceiveReward(trpgRewardId)
if ret and not isReceiveReward then
return true
end
:: continue ::
end
return false
end
function XTRPGManager.CheckSecondMainCondition(secondMainId)
local conditionList = XTRPGConfigs.GetSecondMainCondition(secondMainId)
local ret
local desc = ""
for i, condition in ipairs(conditionList) do
ret, desc = XConditionManager.CheckCondition(condition)
if ret then
return true
end
end
return false, desc
end
function XTRPGManager.CheckSecondMainStageCondition(secondMainStageId)
local conditionList = XTRPGConfigs.GetSecondMainStageCondition(secondMainStageId)
local ret
local desc = ""
for i, condition in ipairs(conditionList) do
ret, desc = XConditionManager.CheckCondition(condition)
if ret then
return true
end
end
return false, desc
end
function XTRPGManager.SetStagePass(stageId)
StagePassDic[stageId] = true
end
function XTRPGManager.IsStagePass(stageId)
return StagePassDic[stageId] or false
end
function XTRPGManager.IsSecondMainReward()
local secondMainIdList = XTRPGConfigs.GetSecondMainIdList()
for i, secondMainId in ipairs(secondMainIdList) do
if XDataCenter.TRPGManager.IsSecondMainCanReward(secondMainId) then
return true
end
end
return false
end
-- 首次进入播放剧情
function XTRPGManager.PlayStartStory(callback)
local OpenMainUi = function(uiName)
if uiName == nil then
uiName = XTRPGManager.GetMainName()
end
XLuaUiManager.OpenWithCallback(uiName, callback)
end
local TRPGFirstOpenFunctionGroupId = CS.XGame.ClientConfig:GetInt("TRPGFirstOpenFunctionGroupId")
if not XTRPGManager.IsFunctionGroupConditionFinish(TRPGFirstOpenFunctionGroupId) then
OpenMainUi()
return
end
local functionIds = XTRPGConfigs.GetFunctionGroupFunctionIds(TRPGFirstOpenFunctionGroupId)
for _, functionId in ipairs(functionIds) do
if not XTRPGManager.IsThirdAreaFunctionFinish(nil, functionId) then
if XTRPGConfigs.CheckFunctionType(functionId, XTRPGConfigs.TRPGFunctionType.Story) then
local params = XTRPGConfigs.GetFunctionParams(functionId)
local movieId = params[1]
local cb = function()
XTRPGManager.RequestFunctionFinishSend(nil, functionId)
-- 第一次打开常规模式
if not XTRPGManager.IsNormalPage() then
XTRPGManager.RequestTRPGChangePageStatus(true)
end
OpenMainUi("UiTRPGSecondMain")
end
XDataCenter.MovieManager.PlayMovie(movieId, cb, nil, nil, false)
return
end
end
end
OpenMainUi()
end
--------------------常规主线 start---------------------
XTRPGManager.Init()
return XTRPGManager
end
---------------------(服务器推送)begin------------------
XRpc.NotifyTRPGCharacterData = function(data)
XDataCenter.TRPGManager.NotifyTRPGCharacterData(data)
end
XRpc.NotifyTRPGTargetFinish = function(data)
XDataCenter.TRPGManager.NotifyTRPGTargetFinish(data)
end
XRpc.NotifyTRPGData = function(data)
XDataCenter.TRPGManager.NotifyTRPGData(data)
end
XRpc.NotifyTRPGFunctionFinish = function(data)
XDataCenter.TRPGManager.NotifyTRPGFunctionFinish(data)
end
XRpc.NotifyTRPGShopExtraData = function(data)
XDataCenter.TRPGManager.NotifyTRPGShopExtraData(data)
end
XRpc.NotifyTRPGItemCapacityChange = function(data)
XDataCenter.TRPGManager.NotifyTRPGItemCapacityChange(data)
end
XRpc.NotifyTRPGClientShopInfo = function(data)
XDataCenter.TRPGManager.NotifyTRPGClientShopInfo(data)
end
XRpc.NotifyTRPGDailyResetData = function(data)
XDataCenter.TRPGManager.NotifyTRPGDailyResetData(data)
end
XRpc.NotifyTRPGBaseInfo = function(data)
XDataCenter.TRPGManager.NotifyTRPGBaseInfo(data)
end
XRpc.NotifyTRPGMazeSelectCardResult = function(data)
XDataCenter.TRPGManager.NotifyTRPGMazeSelectCardResult(data)
end
XRpc.NotifyMazeRecordCardId = function(data)
XDataCenter.TRPGManager.NotifyMazeRecordCardId(data)
end
XRpc.NotifyTRPGClientBossData = function(data)
XDataCenter.TRPGManager.NotifyTRPGClientBossData(data)
end
---------------------(服务器推送)end------------------