PGRData/Script/matrix/xmanager/XConditionManager.lua

2365 lines
90 KiB
Lua
Raw Normal View History

local tableUnpack = table.unpack
XConditionManager = XConditionManager or {}
local TABLE_CONDITION_PATH = "Share/Condition/Condition.tab"
local ConditionTemplate = {}
local DefaultRet = true
XConditionManager.ConditionType = {
Unknown = 0,
Player = 1,
Character = 13,
Team = 18,
2024-09-01 22:49:41 +02:00
MixedTeam = 24, -- 角色机器人混编队伍
Kill = 30,
Equip = 31,
Activity = 40,
Formula = 41
}
2024-09-01 22:49:41 +02:00
---@return XCharacterAgency
local GetCharAgency = function ()
local ag = XMVCA:GetAgency(ModuleId.XCharacter)
return ag
end
local PlayerCondition
PlayerCondition = {
2024-09-01 22:49:41 +02:00
[10101] = function(condition)
-- 查询玩家等级是否达标
return XPlayer.Level >= condition.Params[1], condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10102] = function(condition)
-- 查询玩家是否拥有指定角色
return GetCharAgency():IsOwnCharacter(condition.Params[1]), condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10103] = function(condition)
-- 查询玩家是否拥有指定数量的角色
return #GetCharAgency():GetOwnCharacterList() >= condition.Params[1], condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10104] = function(condition)
-- 查询玩家背包是否有容量
local ret, desc = PlayerCondition[12101](condition)
if not ret then
return ret, desc
end
return PlayerCondition[12102](condition)
end,
2024-09-01 22:49:41 +02:00
[10105] = function(condition)
-- 查询玩家是否通过指定得关卡
local stageId = condition.Params[1]
-- local stageInfo = XDataCenter.FubenManager.GetStageInfo(stageId)
-- if stageInfo then
-- return stageInfo.Passed, condition.Desc
-- else
-- return true, condition.Desc
-- end
local flag = XDataCenter.FubenManager.CheckStageIsPass(stageId)
return flag, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10106] = function(condition)
--至少拥有其中一个角色
if condition.Params and #condition.Params > 0 then
for i = 1, #condition.Params do
2024-09-01 22:49:41 +02:00
local isOwnCharacter = GetCharAgency():IsOwnCharacter(condition.Params[i])
if isOwnCharacter then
return true, condition.Desc
end
end
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10107] = function(condition)
-- 查询玩家等级是否小于等于n
return XPlayer.Level <= condition.Params[1], condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10108] = function(condition)
-- 查询玩家是否通过指定得关卡
local stageId = condition.Params[1]
local stageInfo = XDataCenter.FubenManager.GetStageInfo(stageId)
if stageInfo then
return (not stageInfo.Passed), condition.Desc
else
return false, condition.Desc
end
end,
2024-09-01 22:49:41 +02:00
[10109] = function(condition)
--查询玩家是否拥有战力X的角色数量
local needCount = condition.Params[1]
local needAbility = condition.Params[2]
2024-09-01 22:49:41 +02:00
local curCount = GetCharAgency():GetCharacterCountByAbility(needAbility)
if (curCount >= needCount) then
return true, condition.Desc
else
return false, condition.Desc
end
end,
2024-09-01 22:49:41 +02:00
[10110] = function(condition)
-- 查询玩家是否有某个勋章
return XPlayer.IsMedalUnlock(condition.Params[1]), condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10111] = function(condition)
-- 查询玩家是否完成过某个任务
local task = XDataCenter.TaskManager.GetTaskDataById(condition.Params[1])
return task and task.State == XDataCenter.TaskManager.TaskState.Finish or false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10112] = function(condition)
-- 单挑Boss奖励是否领取活动是否开启
local isCurActivity = XDataCenter.FubenActivityBossSingleManager.GetCurActivityId() == condition.Params[1]
local isFinish = XDataCenter.FubenActivityBossSingleManager.CheckRewardIsFinish(condition.Params[2])
if
2024-09-01 22:49:41 +02:00
XFunctionManager.JudgeCanOpen(XFunctionManager.FunctionName.FubenActivitySingleBoss) and isFinish and
isCurActivity
2024-09-01 22:49:41 +02:00
then
return true, condition.Desc
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10114] = function(condition)
-- 世界boss属性关完成数量
local worldBossActivity = XDataCenter.WorldBossManager.GetCurWorldBossActivity()
if worldBossActivity then
local finishStageCount = worldBossActivity:GetFinishStageCount()
if finishStageCount >= condition.Params[1] then
return true, condition.Desc
end
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10115] = function(condition)
-- 世界boss血量低于xx(百分比)
local bossArea = XDataCenter.WorldBossManager.GetBossAreaById(condition.Params[1])
if bossArea then
local hpPercent = bossArea:GetHpPercent()
if hpPercent * 100 <= condition.Params[2] then
return true, condition.Desc
end
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10118] = function(condition)
-- 判断玩家是否完成预热关拼图
local puzzleId = condition.Params[1]
if
2024-09-01 22:49:41 +02:00
XDataCenter.FubenActivityPuzzleManager.GetPuzzleStateById(puzzleId) ==
XFubenActivityPuzzleConfigs.PuzzleState.Complete
2024-09-01 22:49:41 +02:00
then
return true, condition.Desc
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10119] = function(condition)
-- 判断是否完成跑团TRPG某个目标
local targetId = condition.Params[1]
if XDataCenter.TRPGManager.IsTargetFinish(targetId) then
return true, condition.Desc
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10120] = function(condition)
-- 判断尼尔角色等级是否达标
local characterId = condition.Params[1]
local nieRCharacter = XDataCenter.NieRManager.GetNieRCharacterByCharacterId(characterId)
if nieRCharacter and (nieRCharacter:GetNieRCharacterLevel() >= condition.Params[2]) then
return true, condition.Desc
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10121] = function(condition)
-- 判断尼尔辅助机等级是否达标
local targetLevel = condition.Params[1]
local nieRPOd = XDataCenter.NieRManager.GetNieRPODData()
if nieRPOd and (nieRPOd:GetNieRPODLevel() >= targetLevel) then
return true, condition.Desc
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10122] = function(condition)
-- 判断尼尔辅助机技能等级是否达标
local skillId = condition.Params[1]
local skillLevel = condition.Params[2]
local nieRPOd = XDataCenter.NieRManager.GetNieRPODData()
if nieRPOd and (nieRPOd:GetNieRPODSkillLevelById(skillId) >= skillLevel) then
return true, condition.Desc
end
return false, condition.Desc
end,
[10123] = function(condition)
local result = XDataCenter.RegressionManager.IsRegressionActivityOpen(XRegressionConfigs.ActivityType.Task)
return result, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10126] = function(condition)
--玩家是否完成跑团TRPG某迷宫卡牌
local mazeId = condition.Params[1]
local layerId = condition.Params[2]
local cardId = condition.Params[3]
if XDataCenter.TRPGManager.IsMazeCardFinished(mazeId, layerId, cardId) then
return true, condition.Desc
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10127] = function(condition)
--判断玩家合成小游戏活动进度是否达标
local schedule = condition.Params[1]
local gameId = condition.Params[2]
local game = XDataCenter.ComposeGameManager.GetGameById(gameId)
if game then
local currentSchedule = game:GetCurrentSchedule()
return currentSchedule >= schedule, condition.Desc
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10128] = function(condition)
--超级据点拥有矿工数量
local requireCount = condition.Params[1] or 0
local haveCount = XDataCenter.StrongholdManager.GetMinerCount()
return haveCount >= requireCount, condition.Desc, haveCount, requireCount
end,
2024-09-01 22:49:41 +02:00
[10129] = function(condition)
--超级据点拥有矿石数量
local requireCount = condition.Params[1]
local haveCount = XDataCenter.StrongholdManager.GetTotalMineralCount()
return haveCount >= requireCount, condition.Desc, haveCount, requireCount
end,
2024-09-01 22:49:41 +02:00
[10130] = function(condition)
--超级据点完成据点数量
local requireCount = condition.Params[1]
local haveCount = XDataCenter.StrongholdManager.GetFinishGroupCount(XStrongholdConfigs.ChapterType.Normal)
return haveCount >= requireCount, condition.Desc, haveCount, requireCount
end,
2024-09-01 22:49:41 +02:00
[10131] = function(condition)
--超级据点完成某个据点
local groupId = condition.Params[1]
local isfinished = XDataCenter.StrongholdManager.IsGroupFinished(groupId)
return isfinished, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10132] = function(condition)
--超级据点矿石预计产出
local requireCount = condition.Params[1]
local haveCount = XDataCenter.StrongholdManager.GetPredictTotalMineralCount()
return haveCount >= requireCount, condition.Desc, haveCount, requireCount
end,
2024-09-01 22:49:41 +02:00
[10133] = function(condition, ...)
--超级据点队伍是否满员
local args = { ... }
local teamList = args and args[1]
local isfinished = XDataCenter.StrongholdManager.CheckCurGroupTeamFull(teamList)
return isfinished, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10134] = function(condition, ...)
--超级据点队伍列表平均战力是否符合要求
local requireCount = condition.Params[1]
2024-09-01 22:49:41 +02:00
local args = { ... }
local teamList = args and args[1]
2024-09-01 22:49:41 +02:00
local isfinished, averageAbility = XDataCenter.StrongholdManager.CheckTeamListAverageAbility(requireCount, teamList)
return isfinished, condition.Desc .. "/" .. math.floor(averageAbility)
end,
2024-09-01 22:49:41 +02:00
[10135] = function(condition)
--超级据点未完成某个据点
local groupId = condition.Params[1]
local isfinished = XDataCenter.StrongholdManager.IsGroupFinished(groupId)
return not isfinished, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10139] = function(condition)
--玩家是否未完成跑团TRPG某迷宫卡牌
local mazeId = condition.Params[1]
local layerId = condition.Params[2]
local cardId = condition.Params[3]
if XDataCenter.TRPGManager.IsMazeCardFinished(mazeId, layerId, cardId) then
return false, condition.Desc
end
return true, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10140] = function(condition)
--超级据点当前活动阶段是否满足任一参数1, --开启中2, --战斗开启3, --战斗结束4, --已结束)
local isfinished = false
for _, status in pairs(condition.Params) do
if status > 0 and XDataCenter.StrongholdManager.CheckActivityStatus(status) then
isfinished = true
break
end
end
return isfinished, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10141] = function(condition)
--Rpg爬塔玩法是否当前队伍等级高于参照值
local needLevel = condition.Params[1]
local reachLevel = XDataCenter.RpgTowerManager.GetCurrentLevel() >= needLevel
return reachLevel, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10142] = function(condition)
--是否拥有某个伙伴
local templateId = condition.Params[1]
local IsUnLock = XDataCenter.ArchiveManager.GetPartnerUnLockById(templateId)
return IsUnLock, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10143] = function(condition)
--是否完成翻牌小游戏某个关卡
local activityId = condition.Params[1]
local stageId = condition.Params[2]
return XDataCenter.InvertCardGameManager.CheckActivityStageFinished(activityId, stageId), condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10144] = function(condition)
-- 判断杀戮无双难度星数
local diff = condition.Params[1]
local star = condition.Params[2]
local curStar = XDataCenter.KillZoneManager.GetTotalStageStarByDiff(diff)
return curStar >= star, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10145] = function(condition)
-- 判断超级爬塔通关目标关卡进度
local targetStageId = condition.Params[1]
local progress = condition.Params[2]
local stageManager = XDataCenter.SuperTowerManager.GetStageManager()
if not stageManager then
return false
end
local stStage = stageManager:GetTargetStageByStStageId(targetStageId)
if not stStage then
return false
end
return stStage:GetCurrentProgress() >= progress, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10146] = function(condition, ...)
-- 或条件判断通过特定13章探索模型XX节点或通关指定id副本
local tempCondition1 = { Params = { [1] = condition.Params[1] } }
local tempCondition2 = { Params = { [1] = condition.Params[2] } }
local ret1 = PlayerCondition[10105](tempCondition1)
local ret2 = PlayerCondition[10119](tempCondition2)
local ret = ret1 or ret2
return ret, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10150] = function(condition)
-- 查询当前的生日剧情是否解锁
return XPlayer.CheckStoryIsUnlock(condition.Params[1]), condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10152] = function(condition)
-- 查询当前邮件图鉴是否解锁
return XDataCenter.ArchiveManager.CheckArchiveMailUnlock(condition.Params[1]), condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10153] = function(condition)
-- 判断角色创建时间与参数的关系
local createTime = XPlayer.CreateTime
local parmCreateTime = tonumber(condition.Params[1])
local compare = tonumber(condition.Params[2])
local temp = parmCreateTime >= createTime and 1 or 0
return temp == compare, condition.Desc
end,
[10154] = function(condition)
-- 判断行星环游记是否通过该关卡
if not condition.Params then
return false, condition.Desc
end
local stageId = condition.Params[1]
local viewModel = XDataCenter.PlanetManager.GetViewModel()
if viewModel then
return viewModel:CheckStageIsPass(stageId), condition.Desc
end
return false, condition.Desc
end,
[10155] = function(condition)
-- 判断行星环游记是否处于某个关卡
if not condition.Params then
return false, condition.Desc
end
local stageId = condition.Params[1]
local stageData = XDataCenter.PlanetManager.GetStageData()
if XDataCenter.PlanetManager.IsInGame() then
return stageData:GetStageId() == stageId, condition.Desc
end
return false, condition.Desc
end,
[10156] = function(condition)
-- 判断行星环游记特殊触发条件
if not condition.Params then
return false, condition.Desc
end
---@type number XPlanetConfigs.GuideTriggerType
local triggerType = condition.Params[1]
local triggerGuideId = condition.Params[2]
if triggerGuideId and XDataCenter.PlanetManager.GetGuideEnd(triggerGuideId) then
return false, condition.Desc
end
if triggerType == XPlanetConfigs.GuideTriggerType.FirstGetMoney then
return XDataCenter.PlanetManager.GetGuideFirstGetMoney(), condition.Desc
elseif triggerType == XPlanetConfigs.GuideTriggerType.FirstFight then
return XDataCenter.PlanetManager.GetGuideFirstFight(), condition.Desc
elseif triggerType == XPlanetConfigs.GuideTriggerType.FirstHunt then
return XDataCenter.PlanetManager.GetGuideFirstHunt(), condition.Desc
elseif triggerType == XPlanetConfigs.GuideTriggerType.EnterMovie then
return XDataCenter.PlanetManager.GetGuideEnterMovie(), condition.Desc
end
return false, condition.Desc
end,
[10157] = function(condition)
-- 判断行星环游记标记引导已经触发
if not condition.Params then
return false, condition.Desc
end
local triggerGuideId = condition.Params[1]
if triggerGuideId and XDataCenter.PlanetManager.GetGuideEnd(triggerGuideId) then
return false, condition.Desc
end
return true, condition.Desc
end,
[10200] = function(condition)
-- 三头犬玩法关卡是否达到星级目标
if not condition.Params then
return false, condition.Desc
end
local stageId = condition.Params[1]
local needStar = condition.Params[2]
local xStage = XDataCenter.CerberusGameManager.GetXStageById(stageId)
local starCount = xStage and xStage:GetStarCount()
return starCount >= needStar, condition.Desc
end,
[10201] = function(condition)
-- 三头犬玩法关卡是否包含指定参数
if not condition.Params or #condition.Params < 2 then
return false, condition.Desc
end
local stageId = condition.Params[1]
local xStage = XDataCenter.CerberusGameManager.GetXStageById(stageId)
for i = 2, #condition.Params, 1 do
local param = condition.Params[i]
if not table.contains(xStage:GetStageParams(), param) then
return false, condition.Desc
end
end
return true, condition.Desc
end,
[11101] = function(condition)
-- 查询指定道具数量是否达标
return XDataCenter.ItemManager.CheckItemCountById(condition.Params[1], condition.Params[2]), condition.Desc
end,
2024-09-01 22:49:41 +02:00
[11102] = function(condition)
--查询玩家角色解放阶段是否达到
return XDataCenter.ExhibitionManager.IsAchieveLiberation(condition.Params[1], condition.Params[2]), condition.Desc
end,
2024-09-01 22:49:41 +02:00
[11103] = function(condition)
-- 查询玩家是否领取首充奖励
return XDataCenter.PayManager.GetFirstRechargeReward(), condition.Desc
end,
2024-09-01 22:49:41 +02:00
[11104] = function(condition)
-- 查询玩家是否拥有某个时装
return XDataCenter.FashionManager.CheckHasFashion(condition.Params[1]), condition.Desc
end,
2024-09-01 22:49:41 +02:00
[11105] = function(condition)
-- 查询玩家是否不拥有某个时装
return not XDataCenter.FashionManager.CheckHasFashion(condition.Params[1]), condition.Desc
end,
2024-09-01 22:49:41 +02:00
[11106] = function(condition)
-- 查询玩家是否通过某个试验区关卡填试验区ID
return XDataCenter.FubenExperimentManager.CheckExperimentIsFinish(condition.Params[1]), condition.Desc
end,
2024-09-01 22:49:41 +02:00
[11108] = function(condition)
-- 查询玩家复刷关等级是否达到
return XDataCenter.FubenRepeatChallengeManager.IsLevelReach(condition.Params[1]), condition.Desc
end,
2024-09-01 22:49:41 +02:00
[11109] = function(condition)
-- 查询玩家在指定时间内通过某个关卡
if not condition.Params or #condition.Params < 2 then
return false, condition.Desc
end
local stageId = condition.Params[1]
local stageData = XDataCenter.FubenManager.GetStageData(stageId)
if not stageData then
return false, condition.Desc
end
if stageData.BestRecordTime <= 0 or stageData.BestRecordTime > condition.Params[2] then
return false, condition.Desc
end
return true, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[11110] = function(condition)
-- 查询玩家在本期巴别塔活动中的分数是否超过某个值
local count = condition.Params[1]
local _, maxLevel = XDataCenter.FubenBabelTowerManager.GetCurrentActivityScores()
if maxLevel >= count then
return true, condition.Desc
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[11111] = function(condition)
--查询当前爬塔达到的最高层数
local curMaxTier = XDataCenter.FubenRogueLikeManager.GetHistoryMaxTier()
if condition and condition.Params[1] then
return curMaxTier >= condition.Params[1], condition.Desc
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[11112] = function(condition)
--查询玩家是否拥有某个永久武器时装
local id = condition.Params[1]
2024-09-01 22:49:41 +02:00
local ret = XDataCenter.WeaponFashionManager.CheckHasFashion(id) and
not XDataCenter.WeaponFashionManager.IsFashionTimeLimit(id)
return ret, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[11113] = function(condition)
--查询玩家是否不拥有某个永久武器时装
local id = condition.Params[1]
2024-09-01 22:49:41 +02:00
local ret = not XDataCenter.WeaponFashionManager.CheckHasFashion(id) or
XDataCenter.WeaponFashionManager.IsFashionTimeLimit(id)
return ret, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[11114] = function(condition)
--查询玩家是否拥有一堆时装中的某一个
local ret = false
for _, fashionId in pairs(condition.Params) do
2024-09-01 22:49:41 +02:00
ret = XDataCenter.WeaponFashionManager.CheckHasFashion(fashionId) and
not XDataCenter.WeaponFashionManager.IsFashionTimeLimit(fashionId)
if ret then
break
end
end
return ret, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[11117] = function(condition)
--查询玩家是否拥指定ID的场景
local ret = true
for _, id in ipairs(condition.Params) do
if not XDataCenter.PhotographManager.CheckSceneIsHaveById(id) then
ret = false
break
end
end
return ret, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[11118] = function(condition, soundStageId)
--查询玩家是否通关消消乐
local stageId = condition.Params[1]
if
2024-09-01 22:49:41 +02:00
XTool.IsNumberValid(stageId) and XTool.IsNumberValid(soundStageId) and
XDataCenter.LivWarmSoundsActivityManager.IsStageUnlock(soundStageId) and
XDataCenter.LivWarmActivityManager.IsStageWin(stageId)
2024-09-01 22:49:41 +02:00
then
return true, condition.Desc
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[11119] = function(condition)
--超级据点作战期开启时长是否达标
local targetTime = tonumber(condition.Params[1])
local passingTime = XDataCenter.StrongholdManager.GetFightPassingTime()
return passingTime >= targetTime, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[11120] = function(condition)
--查询玩家是否通关音频
local stageId = condition.Params[1]
if XTool.IsNumberValid(stageId) and XDataCenter.LivWarmSoundsActivityManager.IsStageFinished(stageId) then
return true, condition.Desc
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[11121] = function(condition)
--查询玩家是否 未拥有 某个场景
local ret = true
for _, id in ipairs(condition.Params) do
if XDataCenter.PhotographManager.CheckSceneIsHaveById(id) then
ret = false
break
end
end
return ret, condition.Desc
end,
[12101] = function(condition)
-- 查询武器库是否有容量
return XDataCenter.EquipManager.CheckMaxCount(XEquipConfig.Classify.Weapon), condition.Desc
end,
2024-09-01 22:49:41 +02:00
[12102] = function(condition)
-- 查询意识库是否有容量
return XDataCenter.EquipManager.CheckMaxCount(XEquipConfig.Classify.Awareness), condition.Desc
end,
2024-09-01 22:49:41 +02:00
[12103] = function(condition)
--超级据点通过据点使用的电力 / 是否开启扫荡
local groupId = tonumber(condition.Params[1])
local requireUseElectric = tonumber(condition.Params[2])
2024-09-01 22:49:41 +02:00
local elType = tonumber(condition.Params[3])
local isHistory = XTool.IsNumberValid(tonumber(condition.Params[4]))
return XDataCenter.StrongholdManager.CheckGroupPassUseElectric(groupId, requireUseElectric, elType, isHistory), condition.Desc
end,
2024-09-01 22:49:41 +02:00
[12200] = function(condition)
local activityId = tonumber(condition.Params[1] or 0)
local state = tonumber(condition.Params[2] or 0)
local activityState = XDataCenter.Regression3rdManager.ActivityState(activityId)
return activityState == state, condition.Desc
end,
[12201] = function(condition)
--回归3期-累积代币数量
if not XDataCenter.Regression3rdManager.IsOpen() then
return false, condition.Desc
end
local viewModel = XDataCenter.Regression3rdManager.GetViewModel():GetProperty("_PassportViewModel")
local accumulated = viewModel:GetProperty("_Accumulated")
local count = tonumber(condition.Params[1])
return accumulated >= count, condition.Desc
end,
[21101] = function(condition)
-- 查询玩家是否购买月卡
local isGot = true
local uiType = condition.Params[1]
local id = condition.Params[2]
if XDataCenter.PurchaseManager.IsYkBuyed(uiType, id) then
local data = XDataCenter.PurchaseManager.GetYKInfoData(uiType, id)
if data then
isGot = data.IsDailyRewardGet
end
end
return not isGot, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[21102] = function(condition)
-- 查询玩家是否未领取首充奖励
return not XDataCenter.PayManager.GetFirstRechargeReward(), condition.Desc
end,
2024-09-01 22:49:41 +02:00
[22001] = function(condition)
-- 红包活动ID下指定NPC累计获得的物品数量
local count = condition.Params[1]
local itemId = condition.Params[2]
local activityId = condition.Params[3]
local npcId = condition.Params[4]
local total = XDataCenter.ItemManager.GetRedEnvelopeCertainNpcItemCount(activityId, npcId, itemId)
return total >= count, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[23001] = function(condition)
-- 判断服务器时间是否达到某个开始时间
local timeId = condition.Params[1]
return XFunctionManager.CheckInTimeByTimeId(timeId), condition.Desc
end,
[15101] = function(condition)
local nodeId = condition.Params[1]
local cfg = XFubenExploreConfigs.GetLevel(nodeId)
if not cfg then
return false, condition.Desc
end
return XDataCenter.FubenExploreManager.IsNodeFinish(cfg.ChapterId, nodeId), condition.Desc
end,
[15102] = function(condition)
local chapterId = condition.Params[1]
local chapterData = XDataCenter.FubenAssignManager.GetChapterDataById(chapterId)
return (chapterData and chapterData:IsPass()), condition.Desc
end,
[15106] = function(condition)
local count = condition.Params[1]
local myCount = XDataCenter.ArenaOnlineManager.GetFirstPassCount()
return myCount >= count, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[15108] = function(condition)
-- 完成意识公约章节列表指定数量
local needCount = condition.Params[1]
local total = 0
for i = 2, #condition.Params, 1 do
local chapterId = condition.Params[i]
local chapterData = XDataCenter.FubenAwarenessManager.GetChapterDataById(chapterId)
if chapterData:IsPass() then
total = total + 1
end
end
return total >= needCount
end,
[15110] = function(condition)
--查询纷争战区是否开启
return XDataCenter.ArenaManager.IsPlayerCanEnterFight(), condition.Desc
end,
2024-09-01 22:49:41 +02:00
[15111] = function(condition)
--幻痛囚笼是否开启
return XDataCenter.FubenBossSingleManager.IsBossSingleOpen(), condition.Desc
end,
2024-09-01 22:49:41 +02:00
[15200] = function(condition)
-- 主线普通与隐藏模式的收集进度是否均达到100%
local chapterMainId = condition.Params[1]
local chapterMain = XDataCenter.FubenMainLineManager.GetChapterMainTemplate(chapterMainId)
local NorProgress = XDataCenter.FubenMainLineManager.GetProgressByChapterId(chapterMain.ChapterId[1])
local DiffProgress = XDataCenter.FubenMainLineManager.GetProgressByChapterId(chapterMain.ChapterId[2])
if NorProgress >= condition.Params[2] and DiffProgress >= condition.Params[2] then
return true, condition.Desc
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[15201] = function(condition)
-- 外篇普通与隐藏模式的收集进度是否均达到100%
local chapterMainId = condition.Params[1]
local chapterMain = XDataCenter.ExtraChapterManager.GetChapterCfg(chapterMainId)
local NorProgress = XDataCenter.ExtraChapterManager.GetProgressByChapterId(chapterMain.ChapterId[1])
local DiffProgress = XDataCenter.ExtraChapterManager.GetProgressByChapterId(chapterMain.ChapterId[2])
if NorProgress >= condition.Params[2] and DiffProgress >= condition.Params[2] then
return true, condition.Desc
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[15202] = function(condition)
-- 是否通关周目章节
local lastStage = XFubenZhouMuConfigs.GetZhouMuChapterLastStage(condition.Params[1])
local flag = XDataCenter.FubenManager.CheckStageIsPass(lastStage)
return flag, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[15203] = function(condition)
-- 故事集普通与隐藏模式的收集进度是否均达到100%
local chapterMainId = condition.Params[1]
local chapterIds = XFubenShortStoryChapterConfigs.GetShortStoryChapterIds(chapterMainId)
local NorProgress = XDataCenter.ShortStoryChapterManager.GetProgressByChapterId(chapterIds[1])
if not chapterIds[2] then
if NorProgress >= condition.Params[2] then
return true, condition.Desc
end
else
local DiffProgress = XDataCenter.ShortStoryChapterManager.GetProgressByChapterId(chapterIds[2])
if NorProgress >= condition.Params[2] and DiffProgress >= condition.Params[2] then
return true, condition.Desc
end
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[16100] = function(condition)
--查询公会等级是否达到(服务端未实现)
if not XDataCenter.GuildManager.IsJoinGuild() then
return false, condition.Desc
end
local guildLevel = XDataCenter.GuildManager.GetGuildLevel()
if condition.Params and condition.Params[1] > 0 and guildLevel >= condition.Params[1] then
return true, condition.Desc
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[22002] = function(condition)
--查询公会职务是否与参数中任一值匹配
if not XDataCenter.GuildManager.IsJoinGuild() then
return false, condition.Desc
end
local rankLevel = XDataCenter.GuildManager.GetCurRankLevel()
for i = 1, #condition.Params do
if rankLevel == condition.Params[i] then
return true, condition.Desc
end
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[22004] = function(condition)
--查询工会拥有某个头像
if not XDataCenter.GuildManager.IsJoinGuild() then
return false, condition.Desc
end
local iconId = condition.Params[1] or 0
return XDataCenter.GuildManager.HasPortrait(iconId), condition.Desc
end,
[10117] = function(condition)
-- 查询玩家荣耀勋阶是否达标
return XPlayer.GetHonorLevel() >= condition.Params[1], condition.Desc
end,
[10125] = function(condition)
local recruitLevel = XDataCenter.ExpeditionManager.GetRecruitLevel()
return recruitLevel and recruitLevel >= condition.Params[1]
end,
2024-09-01 22:49:41 +02:00
[15301] = function(condition)
--追击玩法
local mapId = condition.Params[1]
local mapDb = XDataCenter.ChessPursuitManager.GetChessPursuitMapDb(mapId)
if mapDb and mapDb:IsKill() then
return true
else
return false, condition.Desc
end
end,
2024-09-01 22:49:41 +02:00
[15302] = function(condition)
--追击玩法
local mapId = condition.Params[1]
local killBossCount = condition.Params[2]
local mapDb = XDataCenter.ChessPursuitManager.GetChessPursuitMapDb(mapId)
if mapDb and mapDb:IsKill() then
return mapDb:GetWinForBattleCount() <= killBossCount
else
return false, condition.Desc
end
end,
2024-09-01 22:49:41 +02:00
[15303] = function(condition)
--追击玩法:是否布过阵
for i, mapId in ipairs(condition.Params) do
local mapDb = XDataCenter.ChessPursuitManager.GetChessPursuitMapDb(mapId)
if mapDb and not mapDb:NeedBuZhen() then
return true
end
end
end,
2024-09-01 22:49:41 +02:00
[15304] = function(condition)
--骇入玩法:查询研发等级是否达到
if XDataCenter.FubenHackManager.GetIsActivityEnd() then
return false
end
return condition.Params[1] >= XDataCenter.FubenHackManager.GetLevel()
end,
2024-09-01 22:49:41 +02:00
[15305] = function(condition)
--分光双星(双人成行):检测已锁定角色的关卡数
local target = condition.Params[1]
local chapterId = condition.Params[2]
local passCount = XDataCenter.FubenCoupleCombatManager.GetStageSchedule(chapterId)
return passCount >= target, condition.Desc
end,
--全服决战 begin
2024-09-01 22:49:41 +02:00
[16001] = function(condition)
--净化区块数量达到N
local requireCount = condition.Params[1]
local clearCount = XDataCenter.AreaWarManager.GetBlockProgress()
return clearCount >= requireCount, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[16002] = function(condition)
--指定区块Id被净化
local blockId = condition.Params[1]
local ret = XDataCenter.AreaWarManager.IsBlockClear(blockId)
return ret, condition.Desc
end,
--全服决战 end
-- 肉鸽 begin
2024-09-01 22:49:41 +02:00
[17000] = function(condition)
-- 检查已经完全通过的章节是否达到条件
local chapterId = condition.Params[1]
return XDataCenter.TheatreManager.CheckIsGlobalFinishChapter(chapterId), condition.Desc
end,
2024-09-01 22:49:41 +02:00
[17001] = function(condition)
-- 检查是否已经完成某事件的某步骤
local eventId = condition.Params[1]
local stepId = condition.Params[2]
return XDataCenter.TheatreManager.CheckIsGlobalFinishEvent(eventId, stepId), condition.Desc
end,
2024-09-01 22:49:41 +02:00
[17002] = function(condition)
--肉鸽玩法检查是否成功将特定DecorationId升级至X级
local manager = XDataCenter.TheatreManager.GetDecorationManager()
local decorationId = condition.Params[1]
local lv = condition.Params[2]
local curLv = manager:GetDecorationLv(decorationId)
return curLv >= lv, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[17003] = function(condition)
-- 检查冒险是否达成结局
local endingId = condition.Params[1]
return XDataCenter.TheatreManager.CheckIsFinishEnding(endingId), condition.Desc
end,
[10151] = function(condition)
2024-09-01 22:49:41 +02:00
local haveDormCharacter = XDataCenter.DormManager.CheckHaveDormCharacter(condition.Params[1])
if not XTool.IsNumberValid(condition.Params[2]) then
haveDormCharacter = not haveDormCharacter
end
2024-09-01 22:49:41 +02:00
return haveDormCharacter, condition.Desc
end,
-- 肉鸽 end
-- 大逃杀 begin
2024-09-01 22:49:41 +02:00
[10160] = function(condition)
--检查章节是否通关
local chapterId = condition.Params[1]
if XDataCenter.EscapeManager.IsChapterClear(chapterId) then
return true
end
return false, condition.Desc
end,
-- 大逃杀 end
2024-09-01 22:49:41 +02:00
--region GoldenMiner
[10148] = function(condition)
--检查黄金矿工角色是否解锁
local redEnvelopeNpcId = condition.Params[1]
local count = condition.Params[2]
if XDataCenter.GoldenMinerManager.IsCharacterUnLock(redEnvelopeNpcId) then
return true
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[10149] = function(condition, characterId)
--检查黄金矿工角色是否解锁
if XDataCenter.GoldenMinerManager.IsCharacterUnLock(characterId) then
return true
end
return false, condition.Desc
end,
[10153] = function(condition)
-- 判断角色创建时间与参数的关系
local createTime = XPlayer.CreateTime
local parmCreateTime = tonumber(condition.Params[1])
local compare = tonumber(condition.Params[2])
local temp = parmCreateTime >= createTime and 1 or 0
return temp == compare, condition.Desc
end,
[10300] = function(condition)
local characterId = condition.Params[1]
--检查黄金矿工是否使用某角色
if XDataCenter.GoldenMinerManager.CheckIsUseCharacter(characterId) then
return true
end
return false, condition.Desc
end,
[10301] = function(condition)
local characterId = condition.Params[1]
--检查黄金矿工是否没使用某角色
if not XDataCenter.GoldenMinerManager.CheckIsUseCharacter(characterId) then
return true
end
return false, condition.Desc
end,
--endregion
--region ------------------肉鸽2.0 start-------------------
[17100] = function(condition)
--判断章节是否通关
local chapterId = condition.Params[1]
return XDataCenter.BiancaTheatreManager.CheckChapterPassed(chapterId), condition.Desc
end,
[17107] = function(condition)
--判断结局是否达成
local endId = condition.Params[1]
return XDataCenter.BiancaTheatreManager.CheckEndPassed(endId), condition.Desc
end,
-- 玩家在单局冒险中是否经历过Id = X的事件步骤(这里是事件步骤Id)
[17111] = function(condition)
local isUnlock = XDataCenter.BiancaTheatreManager.CheckPassedEventRecord(condition.Params[1])
return isUnlock, condition.Desc
end,
-- 灵视阶段达到或超过XX阶段
[17122] = function(condition)
local isVisionOpen = XDataCenter.BiancaTheatreManager.CheckVisionIsOpen()
local visionValue = XDataCenter.BiancaTheatreManager.GetCurrentAdventureManager():GetVisionValue()
local visionId = XBiancaTheatreConfigs.GetVisionIdByValue(visionValue)
local isUnlock = isVisionOpen and visionId >= condition.Params[1]
return isUnlock, condition.Desc
end,
-- 肉鸽成就是否已经解锁
[17123] = function(condition)
local isAchievement = XDataCenter.BiancaTheatreManager.GetAchievemenetContidion()
local isUnlock = isAchievement == XTool.IsNumberValid(condition.Params[1])
return isUnlock, condition.Desc
end,
--endregion------------------肉鸽2.0 finish------------------
[17117] = function(condition)
--特定总星数通关指定若干关卡
local stars = 0
for i = 2, #condition.Params do
local stageId = condition.Params[i]
local stageInfo = XDataCenter.FubenManager.GetStageInfo(stageId)
stars = stars + stageInfo.Stars
end
if stars >= condition.Params[1] then
return true, condition.Desc
end
return false, condition.Desc
end,
-- 战双大秘境
[10170] = function(condition)
local layerId = condition.Params[2]
local maxPassFightLayerId = XDataCenter.RiftManager.GetMaxPassFightLayerId() or 0
local isPass = maxPassFightLayerId >= layerId
return isPass, condition.Desc
end,
-- 调色板战争是否达到累积代币数量
[17118] = function(condition)
local obtainCoinCnt = XDataCenter.ColorTableManager.GetObtainCoinCnt()
local isUnlock = obtainCoinCnt >= condition.Params[1]
return isUnlock, condition.Desc
end,
-- 调色板战争是否通关某关卡
[17119] = function(condition)
local stageId = condition.Params[1]
local isPass = XDataCenter.ColorTableManager.IsStagePassed(stageId)
return isPass, condition.Desc
end,
-- 调色板战争是否处于某关卡中
[17120] = function(condition)
local stageId = condition.Params[1]
local gameData = XDataCenter.ColorTableManager.GetGameManager():GetGameData()
local curStageId = gameData:GetStageId()
if XTool.IsNumberValid(curStageId) then
return curStageId == stageId, condition.Desc
else
return false, condition.Desc
end
end,
-- 调色板战争打开的玩法介绍是否是某类型
[17121] = function(condition)
local tatgetType = condition.Params[1]
local type = XDataCenter.ColorTableManager.GetGameManager():GetCurMainInfoTipType()
if XTool.IsNumberValid(type) then
return type == tatgetType, condition.Desc
else
return false, condition.Desc
end
end,
[20108] = function(condition)
-- xx数量角色达到指定解放等级
local tagetLibLevel = condition.Params[1]
local needNum = condition.Params[2]
local total = 0
for k, char in pairs(GetCharAgency():GetOwnCharacterList()) do
local currLevel = XDataCenter.ExhibitionManager.GetCharacterGrowUpLevel(char.Id, true)
local isPass = currLevel >= tagetLibLevel
if isPass then
total = total + 1
end
end
return total >= needNum, condition.Desc
end,
[20109] = function(condition)
-- 所有角色小于指定解放等级
local tagetLibLevel = condition.Params[1]
for k, char in pairs(GetCharAgency():GetOwnCharacterList()) do
local currLevel = XDataCenter.ExhibitionManager.GetCharacterGrowUpLevel(char.Id, true)
if currLevel >= tagetLibLevel then
return false
end
end
return true
end,
[20110] = function(condition)
-- 分包下载是否开启
return XDataCenter.DlcManager.CheckIsOpen()
end,
-- 战双餐厅相关
[10180] = function(condition)
-- 餐厅等级达到X级
local tagetRestaurantLevel = condition.Params[1]
local viewModel = XDataCenter.RestaurantManager.GetViewModel()
if not viewModel then
return false, condition.Desc
end
return viewModel:GetProperty("_Level") >= tagetRestaurantLevel, condition.Desc
end,
[10181] = function(condition)
-- 餐厅N个成员达到X级
local tagetCharacterLevel = condition.Params[1]
local tagetCount = condition.Params[2]
local viewModel = XDataCenter.RestaurantManager.GetViewModel()
if not viewModel then
return false, condition.Desc
end
local staffs = viewModel:GetRecruitStaffList()
local count = 0
for _, staff in ipairs(staffs) do
if staff:GetProperty("_Level") > tagetCharacterLevel then
count = count + 1
end
end
return count >= tagetCount, condition.Desc
end,
[10182] = function(condition)
-- 当前是否在使用指定的主界面场景
local targetBgId = condition.Params[1]
local curBgId = XDataCenter.PhotographManager.GetCurSceneId()
return curBgId == targetBgId
end,
[10183] = function(condition)
-- 判定玩家是否拥有任意主控芯片
return XDataCenter.DlcHuntChipManager.GetChipAmountMain() > 0
end,
[10184] = function(condition)
-- 判定玩家未升级过任意芯片
return XDataCenter.DlcHuntChipManager.IsAllChipLevelZero()
end,
[10185] = function(condition)
-- 玩家所有芯片组为空
return XDataCenter.DlcHuntChipManager.IsAllChipGroupEmpty()
end,
[10186] = function(condition)
-- 超限乱斗模式解锁
local modeId = condition.Params[1]
---@type XSmashBMode
local mode = XDataCenter.SuperSmashBrosManager.GetModeByModeType(modeId)
if mode then
return mode:CheckUnlock()
end
return false
end,
[10187] = function(condition)
--玩家是否完成某个新手引导
--参数1 判断标记位1:已经完成引导;0:未完成引导
local flag, guideId = condition.Params[1], condition.Params[2]
local isGuide = XDataCenter.GuideManager.CheckIsGuide(guideId)
local tmpFlag = isGuide and 1 or 0
return flag == tmpFlag, condition.Desc
end,
[10188] = function(condition)
-- 超限乱斗进行中的模式
local modeId = condition.Params[1]
---@type XSmashBMode
local mode = XDataCenter.SuperSmashBrosManager.GetPlayingMode()
if mode and mode:GetId() == modeId then
return true
end
return false
end,
[59001] = function(condition)
--查询猜拳小游戏对应关卡是否通关
local stageId = condition.Params[1]
local stage = XDataCenter.FingerGuessingManager.GetStageByStageId(stageId)
if stage then
return stage:GetIsClear(), condition.Desc
end
return false, condition.Desc
end,
[59002] = function(condition)
--查询工会战3.0 是否开启了隐藏节点
if not XDataCenter.GuildWarManager.CheckActivityCanGoTo() then
--不在活动时间内
return false
end
if not XDataCenter.GuildWarManager.CheckCanEnterMain() then
--无法进入地图界面
return false
end
if not GuildWarManager.CheckRoundIsInTime() then
--在休战期
return false
end
if XDataCenter.GuildWarManager.GetBattleManager():CheckActionPlaying() then
--是否在播放工会动画
return false
end
--返回地图BOSS
return XDataCenter.GuildWarManager.GetCurrentRound():GetBossIsDead(), condition.Desc
end,
[88003] = function(condition)
--颠倒塔2.0%s章节是否超过%s分
local chapterId = condition.Params[1]
local needScore = condition.Params[2]
local isReach = false
local chapter = XDataCenter.TwoSideTowerManager.GetChapter(chapterId)
if chapter then
local maxScore = chapter:GetMaxChapterScore()
isReach = maxScore >= needScore
end
return isReach, condition.Desc
end,
[88004] = function(condition)
--库街区 渠道是否允许显示
local isAllow = XDataCenter.KujiequManager.IsChannelAllow()
return isAllow
end,
[88005] = function(condition)
--三消 boss是否解锁
local bossId = condition.Params[1]
local bossManager = XDataCenter.SameColorActivityManager.GetBossManager()
local boss = bossManager:GetBoss(bossId)
local isOpen = boss and boss:GetIsOpen()
return isOpen
end,
[10210] = function(condition, time)
local params = condition.Params
local limitTime = params[2]
if time then
return time < limitTime
end
local stageId = params[1]
local stageGroup = XDataCenter.TransfiniteManager.GetStageGroupByStageId(stageId)
if not stageGroup then
return false
end
local stage = stageGroup:GetStage(stageId)
time = stage:GetPassedTime()
return time < limitTime
end,
--肉鸽3.0 type = 17200 - 17217
[17200] = function(condition) -- 任意冒险中玩家首次进入某个章节
---@type XTheatre3Agency
local agency = XMVCA:GetAgency(ModuleId.XTheatre3)
local chapterId = condition.Params[1]
local result = agency:CheckFirstOpenChapterId(chapterId)
return result, condition.Desc
end,
[17202] = function(condition) -- 玩家首次完成任意结局
XLog.Error("当前冒险结局数据未同步!")
local result = false
return result, condition.Desc
end,
[17208] = function(condition) -- 玩家是否已达成XX结局
---@type XTheatre3Agency
local agency = XMVCA:GetAgency(ModuleId.XTheatre3)
local nodeId = condition.Params[1]
local result = agency:CheckEndingIsPass(nodeId)
return result, condition.Desc
end,
[17211] = function(condition) -- XXID的天赋树点位是否为激活状态
---@type XTheatre3Agency
local agency = XMVCA:GetAgency(ModuleId.XTheatre3)
local nodeId = condition.Params[1]
local result = agency:CheckStrengthTreeUnlock(nodeId)
return result, condition.Desc
end,
[17212] = function(condition) -- 玩家在单局冒险中是否经历过ID为X的事件步骤注意这里是步骤ID
---@type XTheatre3Agency
local agency = XMVCA:GetAgency(ModuleId.XTheatre3)
local eventStepId = condition.Params[1]
local result = agency:CheckAdventureHasPassEventStep(eventStepId)
return result, condition.Desc
end,
[17213] = function(condition) -- 玩家XX难度下通关某个结局失败结局不算
---@type XTheatre3Agency
local agency = XMVCA:GetAgency(ModuleId.XTheatre3)
local difficultyId = condition.Params[1]
local endingId = condition.Params[2]
local result = agency:CheckAdventureHasPassNode(difficultyId, endingId)
return result, condition.Desc
end,
[17214] = function(condition) -- 玩家在所有冒险中累计获取过X个品质为X的道具
XLog.Error("当前冒险累积数据未同步!")
local result = false
return result, condition.Desc
end,
[17215] = function(condition) -- 玩家在所有冒险中累计激活X套装
XLog.Error("当前冒险累积数据未同步!")
local result = false
return result, condition.Desc
end,
[17216] = function(condition) -- 当局冒险中玩家完成某个章节
---@type XTheatre3Agency
local agency = XMVCA:GetAgency(ModuleId.XTheatre3)
local chapterId = condition.Params[1]
local result = agency:CheckAdventureHasPassChapter(chapterId)
return result, condition.Desc
end,
[17217] = function(condition) -- 当局冒险中玩家完成某个节点
---@type XTheatre3Agency
local agency = XMVCA:GetAgency(ModuleId.XTheatre3)
local nodeId = condition.Params[1]
local result = agency:CheckAdventureHasPassNode(nodeId)
return result, condition.Desc
end,
[17218] = function(condition)
local battleManager = XDataCenter.GuildWarManager.GetBattleManager()
if not battleManager then
return false
end
return battleManager:CheckIsCanGuide()
end,
}
local CharacterCondition = {
2024-09-01 22:49:41 +02:00
[13101] = function(condition, characterId)
-- 查询角色性别是否符合
if type(characterId) ~= "number" then
characterId = characterId.Id
end
local characterTemplate = XCharacterConfigs.GetCharacterTemplate(characterId)
return characterTemplate.Sex == condition.Params[1], condition.Desc
end,
2024-09-01 22:49:41 +02:00
[13102] = function(condition, characterId)
-- 查询角色类型是否符合
local character = characterId
if type(characterId) == "number" then
2024-09-01 22:49:41 +02:00
character = GetCharAgency():GetCharacter(characterId)
end
local npcId = XCharacterConfigs.GetCharNpcId(character.Id, character.Quality)
local npcTemplate = CS.XNpcManager.GetNpcTemplate(npcId)
for i = 1, #condition.Params do
if npcTemplate.Type == condition.Params[i] then
return true
end
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[13103] = function(condition, characterId)
-- 查询角色是否符合等级
local character = GetCharAgency():GetCharacter(characterId)
if not character then
return false, condition.Desc
end
return character.Level >= condition.Params[1], condition.Desc
end,
2024-09-01 22:49:41 +02:00
[13104] = function(condition, characterId)
-- 查询单个角色类型是否符合
local character = characterId
if type(characterId) == "number" then
2024-09-01 22:49:41 +02:00
character = GetCharAgency():GetCharacter(characterId)
end
local npcId = XCharacterConfigs.GetCharNpcId(character.Id, character.Quality)
local npcTemplate = CS.XNpcManager.GetNpcTemplate(npcId)
if npcTemplate.Type == condition.Params[1] then
return true
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[13105] = function(condition, characterId)
-- 查询单个角色品质是否符合
local character = characterId
if type(characterId) == "number" then
2024-09-01 22:49:41 +02:00
character = GetCharAgency():GetCharacter(characterId)
end
-- 查询单个角色品质和星级是否符合
if XTool.IsNumberValid(condition.Params[3]) then
2024-09-01 22:49:41 +02:00
if character.Quality > condition.Params[1] or
character.Quality == condition.Params[1] and character.Star >= condition.Params[3] then
return true
end
elseif character.Quality >= condition.Params[1] then
return true
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[13106] = function(condition, characterId)
-- 查询拥有构造体
if characterId == condition.Params[1] then
return true
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[13107] = function(condition, characterId)
--查询角色是否符合Grade等级要求
local character = nil
if type(characterId) == "number" then
2024-09-01 22:49:41 +02:00
character = GetCharAgency():GetCharacter(characterId)
end
if not character then
return false, condition.Desc
end
if character.Grade >= condition.Params[1] then
return true
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[13108] = function(condition, characterId)
--查询角色战力是否满足
local character = GetCharAgency():GetCharacter(characterId)
if not character then
return false, condition.Desc
end
if character.Ability >= condition.Params[1] then
return true, condition.Desc
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[13109] = function(condition, characterId)
--查询角色是否佩戴共鸣技能
local starLimit = condition.Params[1]
local limitSkillNum = condition.Params[2]
local allSkillNum = 0
local weaponData = XDataCenter.EquipManager.GetCharacterWearingWeaponId(characterId)
local equipInfo = XDataCenter.EquipManager.GetEquip(weaponData)
local star = XDataCenter.EquipManager.GetEquipStar(equipInfo.TemplateId)
if star >= starLimit then
if equipInfo.ResonanceInfo ~= nil then
for _, info in pairs(equipInfo.ResonanceInfo) do
if info.CharacterId == characterId then
allSkillNum = allSkillNum + 1
end
end
end
end
local awarenessData = XDataCenter.EquipManager.GetCharacterWearingAwarenessIds(characterId)
for _, equipId in pairs(awarenessData) do
local equipInfo2 = XDataCenter.EquipManager.GetEquip(equipId)
local star2 = XDataCenter.EquipManager.GetEquipStar(equipInfo2.TemplateId)
if star2 >= starLimit then
if equipInfo2.ResonanceInfo ~= nil then
for _, info in pairs(equipInfo2.ResonanceInfo) do
if info.CharacterId == characterId then
allSkillNum = allSkillNum + 1
end
end
end
end
end
if allSkillNum >= limitSkillNum then
return true, condition.Desc
end
2024-09-01 22:49:41 +02:00
return false, condition.Desc .. CS.XTextManager.GetText("RedColorValue", allSkillNum, limitSkillNum)
end,
2024-09-01 22:49:41 +02:00
[13110] = function(condition, characterId)
--角色武器共鸣技能数
if not condition.Params or #condition.Params ~= 2 then
return false, condition.Desc
end
local resonanceCount = 0
local weaponData = XDataCenter.EquipManager.GetCharacterWearingWeaponId(characterId)
local equipInfo = XDataCenter.EquipManager.GetEquip(weaponData)
if equipInfo.ResonanceInfo ~= nil then
for _, info in pairs(equipInfo.ResonanceInfo) do
local quality = XDataCenter.EquipManager.GetEquipQuality(equipInfo.TemplateId)
if info.CharacterId == characterId and quality >= condition.Params[1] then
resonanceCount = resonanceCount + 1
end
if resonanceCount > condition.Params[2] then
return true, condition.Desc
end
end
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[13111] = function(condition, characterId)
--角色意识共鸣技能数
if not condition.Params or #condition.Params ~= 2 then
return false, condition.Desc
end
local weaponData = XDataCenter.EquipManager.GetCharacterWearingAwarenessIds(characterId)
local resonanceCount = 0
for _, equipId in pairs(weaponData) do
local equipInfo = XDataCenter.EquipManager.GetEquip(equipId)
if equipInfo.ResonanceInfo ~= nil then
for _, info in pairs(equipInfo.ResonanceInfo) do
local quality = XDataCenter.EquipManager.GetEquipQuality(equipInfo.TemplateId)
if info.CharacterId == characterId and quality >= condition.Params[1] then
resonanceCount = resonanceCount + 1
end
if resonanceCount > condition.Params[2] then
return true, condition.Desc
end
end
end
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[13112] = function(condition, characterId)
--角色指定id武器共鸣技能数
if not condition.Params or #condition.Params ~= 2 then
return false, condition.Desc
end
local weaponData = XDataCenter.EquipManager.GetCanUseWeaponIds(characterId)
local resonanceCount = 0
local equipInfo = nil
for _, equipId in pairs(weaponData) do
if equipId == condition.Params[1] then
equipInfo = XDataCenter.EquipManager.GetEquip(equipId)
end
if equipInfo then
if equipInfo.ResonanceInfo ~= nil then
for _, info in pairs(equipInfo.ResonanceInfo) do
if info.CharacterId == characterId then
resonanceCount = resonanceCount + 1
end
if resonanceCount > condition.Params[2] then
return true, condition.Desc
end
end
end
end
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[13113] = function(condition)
--判断是否是好感度最高的构造体
if not condition.Params or #condition.Params < 1 then
return false, condition.Desc
end
local id = XDataCenter.FavorabilityManager.GetHighestTrustExpCharacter()
for _, roleId in pairs(condition.Params) do
if id == roleId then
return true
end
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[13114] = function(condition, characterId)
-- 构造体是否达到指定解放阶段
local character = GetCharAgency():GetCharacter(characterId)
if not character then
return false, condition.Desc
end
local growUpLevel = XDataCenter.ExhibitionManager.GetCharacterGrowUpLevel(character.Id)
2024-09-01 22:49:41 +02:00
return growUpLevel >= condition.Params[1], condition.Desc
end,
2024-09-01 22:49:41 +02:00
[13115] = function(condition, characterId)
-- 构造体是否类型相符(构造体,感染体)
local character = characterId
if type(characterId) == "number" then
2024-09-01 22:49:41 +02:00
character = GetCharAgency():GetCharacter(characterId)
end
local charType = XCharacterConfigs.GetCharacterType(character.Id)
if charType == condition.Params[1] then
return true
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[13116] = function(condition, characterId)
-- 检查角色Sp技能等级
local character = characterId
if type(characterId) == "number" then
2024-09-01 22:49:41 +02:00
character = GetCharAgency():GetCharacter(characterId)
end
local groupId = character:EnhanceSkillIdToGroupId(condition.Params[1])
local groupEntity = character:GetEnhanceSkillGroupData(groupId)
local skillLevel = groupEntity:GetLevel()
if skillLevel >= condition.Params[2] then
return true, condition.Desc
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[13117] = function(condition, characterId)
-- 检查角色好感度达到指定等级
if not condition.Params or #condition.Params < 1 then
return false, condition.Desc
end
local trustLv = XDataCenter.FavorabilityManager.GetCurrCharacterFavorabilityLevel(characterId)
if trustLv >= condition.Params[1] then
return true, condition.Desc
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[13118] = function(condition, characterId)
-- 查询角色绑定意识技能超频数量
if not characterId or not condition.Params or #condition.Params < 1 then
return false, condition.Desc
end
local count = 0
for _, equipSite in pairs(XEquipConfig.EquipSite.Awareness) do
local equipId = XDataCenter.EquipManager.GetWearingEquipIdBySite(characterId, equipSite)
if XTool.IsNumberValid(equipId) then
for i = 1, XEquipConfig.MAX_RESONANCE_SKILL_COUNT do
local awaken = XDataCenter.EquipManager.IsEquipPosAwaken(equipId, i)
local bindCharId = XDataCenter.EquipManager.GetResonanceBindCharacterId(equipId, i)
if awaken and bindCharId == characterId then
count = count + 1
end
end
end
end
if count >= condition.Params[1] then
return true, condition.Desc
end
return false, condition.Desc .. CS.XTextManager.GetText("RedColorValue", count, condition.Params[1])
end,
-- 判断角色是否穿着指定fashion
-- 该判断可以兼容试穿角色,传入试穿时装优先检测试穿的时装
[13119] = function(condition, characterId, tryFashionId)
local targetFashionId = condition.Params[1] or 1
local char = GetCharAgency():GetCharacter(characterId)
if not char then
return false
end
return (tryFashionId or char.FashionId) == targetFashionId
end,
[13120] = function(condition, characterId, tryFashionId, trySceneId)
local targetFashionId = condition.Params[1] or 1
local char = GetCharAgency():GetCharacter(characterId)
if not char then
return false
end
local targetBgId = condition.Params[2]
local curBgId = trySceneId or XDataCenter.PhotographManager.GetCurSceneId()
return ((tryFashionId or char.FashionId) == targetFashionId) and curBgId == targetBgId
end,
}
local TeamCondition = {
2024-09-01 22:49:41 +02:00
[18101] = function(condition, characterIds)
-- 查询队伍角色性别是否符合
local ret, desc = true, nil
if type(characterIds) == "table" then
for _, id in pairs(characterIds) do
if id > 0 then
ret, desc = CharacterCondition[13101](condition, id)
if not ret then
break
end
end
end
else
XTool.LoopCollection(
2024-09-01 22:49:41 +02:00
characterIds,
function(id)
if id > 0 then
if ret then
ret, desc = CharacterCondition[13101](condition, id)
end
end
end
)
end
return ret, desc
end,
2024-09-01 22:49:41 +02:00
[18102] = function(condition, characterIds)
-- 查询队伍角色类型是否符合
local ret, desc = true, nil
if type(characterIds) == "table" then
for _, id in pairs(characterIds) do
if id > 0 then
ret, desc = CharacterCondition[13102](condition, id)
if not ret then
break
end
end
end
else
XTool.LoopCollection(
2024-09-01 22:49:41 +02:00
characterIds,
function(id)
if id > 0 then
ret, desc = CharacterCondition[13102](condition, id)
if ret then
ret, desc = CharacterCondition[13101](condition, id)
end
end
end
)
end
return ret, desc
end,
2024-09-01 22:49:41 +02:00
[18103] = function(condition, characterIds)
-- 查询队伍是否拥有指定角色数量
local chechCount = condition.Params[1] or 1
local total = 0
if type(characterIds) == "table" then
for i = 2, #condition.Params do
for _, id in pairs(characterIds) do
if id > 0 then
if id == condition.Params[i] then
total = total + 1
break
end
end
end
if total >= chechCount then
break
end
end
else
for i = 2, #condition.Params do
XTool.LoopCollection(
2024-09-01 22:49:41 +02:00
characterIds,
function(id)
if id > 0 then
if id == condition.Params[i] then
total = total + 1
end
end
end
)
if total >= chechCount then
break
end
end
end
return total >= chechCount, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[18104] = function(condition, characterIds)
-- 查询队伍是否已拥有指定角色数量
if type(characterIds) == "table" then
for i = 1, #condition.Params do
for _, id in pairs(characterIds) do
if id > 0 then
if id == condition.Params[i] then
return false, condition.Desc
end
end
end
end
else
for i = 2, #condition.Params do
XTool.LoopCollection(
2024-09-01 22:49:41 +02:00
characterIds,
function(id)
if id > 0 then
if id == condition.Params[i] then
return false, condition.Desc
end
end
end
)
end
end
return true, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[18105] = function(condition, characterIds)
-- 派遣中拥有指定数量指定兵种构造
local ret = true
local chechCount = condition.Params[2] or 1
local total = 0
if type(characterIds) == "table" then
for _, id in pairs(characterIds) do
if id > 0 then
ret = CharacterCondition[13104](condition, id)
if ret then
total = total + 1
end
end
if total >= chechCount then
break
end
end
else
XTool.LoopCollection(
2024-09-01 22:49:41 +02:00
characterIds,
function(id)
if id > 0 then
ret = CharacterCondition[13104](condition, id)
if ret then
total = total + 1
end
end
2024-09-01 22:49:41 +02:00
if total >= chechCount then
return
end
end
)
end
return total >= chechCount, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[18106] = function(condition, characterIds)
-- 派遣中拥有指定数量达到指定战斗力的构造体
local chechCount = condition.Params[2] or 1
local total = 0
if type(characterIds) == "table" then
for _, id in pairs(characterIds) do
2024-09-01 22:49:41 +02:00
local character = GetCharAgency():GetCharacter(id)
if character.Ability >= condition.Params[1] then
total = total + 1
end
end
end
return total >= chechCount, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[18107] = function(condition, characterIds)
-- 派遣中拥有指定数量达到指定品质的构造体
local ret = true
local chechCount = condition.Params[2] or 1
local total = 0
if type(characterIds) == "table" then
for _, id in pairs(characterIds) do
if id > 0 then
ret = CharacterCondition[13105](condition, id)
if ret then
total = total + 1
end
end
if total >= chechCount then
break
end
end
else
XTool.LoopCollection(
2024-09-01 22:49:41 +02:00
characterIds,
function(id)
if id > 0 then
ret = CharacterCondition[13105](condition, id)
if ret then
total = total + 1
end
end
2024-09-01 22:49:41 +02:00
if total >= chechCount then
return
end
end
)
end
return total >= chechCount, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[18108] = function(condition, characterIds)
-- 派遣中拥有指定数量达到指定等级的构造体
local ret = true
local chechCount = condition.Params[2] or 1
local total = 0
if type(characterIds) == "table" then
for _, id in pairs(characterIds) do
if id > 0 then
ret = CharacterCondition[13103](condition, id)
if ret then
total = total + 1
end
end
if total >= chechCount then
break
end
end
else
XTool.LoopCollection(
2024-09-01 22:49:41 +02:00
characterIds,
function(id)
if id > 0 then
ret = CharacterCondition[13103](condition, id)
if ret then
total = total + 1
end
end
2024-09-01 22:49:41 +02:00
if total >= chechCount then
return
end
end
)
end
return total >= chechCount, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[18109] = function(condition, characterIds)
-- 派遣中拥有指定数量指定性别的构造体
local ret = true
local chechCount = condition.Params[2] or 1
local total = 0
if type(characterIds) == "table" then
for _, id in pairs(characterIds) do
if id > 0 then
ret = CharacterCondition[13101](condition, id)
if ret then
total = total + 1
end
end
if total >= chechCount then
break
end
end
else
XTool.LoopCollection(
2024-09-01 22:49:41 +02:00
characterIds,
function(id)
if id > 0 then
ret = CharacterCondition[13101](condition, id)
if ret then
total = total + 1
end
end
2024-09-01 22:49:41 +02:00
if total >= chechCount then
return
end
end
)
end
return total >= chechCount, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[18110] = function(condition, characterIds)
-- 派遣中拥有构造体
local ret = true
local chechCount = condition.Params[2] or 1
local total = 0
if type(characterIds) == "table" then
for _, id in pairs(characterIds) do
if id > 0 then
ret = CharacterCondition[13106](condition, id)
if ret then
total = total + 1
end
end
if total >= chechCount then
break
end
end
else
XTool.LoopCollection(
2024-09-01 22:49:41 +02:00
characterIds,
function(id)
if id > 0 then
ret = CharacterCondition[13106](condition, id)
if ret then
total = total + 1
end
end
2024-09-01 22:49:41 +02:00
if total >= chechCount then
return
end
end
)
end
return total >= chechCount, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[18111] = function(condition, characterIds)
-- 仅可上阵N个人
local count = condition.Params[1]
local compareType = condition.Params[2]
local total = 0
for _, v in pairs(characterIds) do
if v > 0 then
total = total + 1
end
end
2024-09-01 22:49:41 +02:00
if compareType == XUiCompareType.Equal then
--等于
return total == count, condition.Desc
end
2024-09-01 22:49:41 +02:00
if compareType == XUiCompareType.NoLess then
--大于等于
return total >= count, condition.Desc
end
return false, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[18112] = function(condition, characterIds)
-- 要求队伍中有N个类型构造体
local ret = true
local chechCount = condition.Params[2] or 1
local total = 0
if type(characterIds) == "table" then
for _, id in pairs(characterIds) do
if id > 0 then
ret = CharacterCondition[13115](condition, id)
if ret then
total = total + 1
end
end
if total >= chechCount then
break
end
end
else
XTool.LoopCollection(
2024-09-01 22:49:41 +02:00
characterIds,
function(id)
if id > 0 then
ret = CharacterCondition[13115](condition, id)
if ret then
total = total + 1
end
end
if total >= chechCount then
return
end
end
)
end
return total >= chechCount, condition.Desc
end,
}
local MixedTeamCondition = {
[24103] = function(condition, characterIds)
-- 查询队伍是否拥有指定角色数量
local chechCount = condition.Params[1] or 1
local total = 0
if type(characterIds) == "table" then
for i = 2, #condition.Params do
for _, id in pairs(characterIds) do
local viewModel = XEntityHelper.GetCharacterViewModelByEntityId(id)
if viewModel then
if viewModel:GetId() == condition.Params[i] then
total = total + 1
break
end
end
end
if total >= chechCount then
break
end
end
else
for i = 2, #condition.Params do
XTool.LoopCollection(characterIds, function(id)
local viewModel = XEntityHelper.GetCharacterViewModelByEntityId(id)
if viewModel then
if viewModel:GetId() == condition.Params[i] then
total = total + 1
end
end
2024-09-01 22:49:41 +02:00
end)
if total >= chechCount then
break
end
end
end
2024-09-01 22:49:41 +02:00
return total >= chechCount, condition.Desc
end,
[24105] = function(condition, characterIds)
-- 派遣中拥有指定数量指定兵种构造
local ret = true
local chechCount = condition.Params[2] or 1
local total = 0
if type(characterIds) == "table" then
for _, id in pairs(characterIds) do
local viewModel = XEntityHelper.GetCharacterViewModelByEntityId(id)
if viewModel then
ret = viewModel:GetProfessionType() == condition.Params[1]
if ret then
total = total + 1
end
end
2024-09-01 22:49:41 +02:00
if total >= chechCount then
break
end
end
else
XTool.LoopCollection(characterIds, function(id)
local viewModel = XEntityHelper.GetCharacterViewModelByEntityId(id)
if viewModel then
ret = viewModel:GetProfessionType() == condition.Params[1]
if ret then
total = total + 1
end
end
if total >= chechCount then
return
end
end)
end
return total >= chechCount, condition.Desc
2024-09-01 22:49:41 +02:00
end,
[24106] = function(condition, characterIds)
-- 派遣中拥有指定数量达到指定战斗力的构造体
local chechCount = condition.Params[2] or 1
local total = 0
if type(characterIds) == "table" then
for _, id in pairs(characterIds) do
local viewModel = XEntityHelper.GetCharacterViewModelByEntityId(id)
if viewModel then
if viewModel:GetAbility() >= condition.Params[1] then
total = total + 1
end
end
end
end
return total >= chechCount, condition.Desc
end,
[24111] = function(condition, characterIds)
-- 仅可上阵N个人
local count = condition.Params[1]
local compareType = condition.Params[2]
local total = 0
for _, id in pairs(characterIds) do
local viewModel = XEntityHelper.GetCharacterViewModelByEntityId(id)
if viewModel then
total = total + 1
end
end
if compareType == XUiCompareType.Equal then
--等于
return total == count, condition.Desc
end
if compareType == XUiCompareType.NoLess then
--大于等于
return total >= count, condition.Desc
end
return false, condition.Desc
end,
[24112] = function(condition, characterIds)
-- 要求队伍中有N个类型构造体
local ret = true
local chechCount = condition.Params[2] or 1
local total = 0
if type(characterIds) == "table" then
for _, id in pairs(characterIds) do
local viewModel = XEntityHelper.GetCharacterViewModelByEntityId(id)
if viewModel then
ret = viewModel:GetCharacterType() == condition.Params[1]
if ret then
total = total + 1
end
end
if total >= chechCount then
break
end
end
else
XTool.LoopCollection(characterIds, function(id)
local viewModel = XEntityHelper.GetCharacterViewModelByEntityId(id)
if viewModel then
ret = viewModel:GetCharacterType() == condition.Params[1]
if ret then
total = total + 1
end
end
if total >= chechCount then
return
end
end)
end
return total >= chechCount, condition.Desc
end,
}
local KillCondition = {
2024-09-01 22:49:41 +02:00
[30101] = function(condition, npcId)
-- 查询怪物击杀数是否达到
return XDataCenter.ArchiveManager.GetMonsterKillCount(npcId) >= condition.Params[1], condition.Desc
end
}
local EquipCondition = {
2024-09-01 22:49:41 +02:00
[31101] = function(condition, equipId)
-- 是否拥有某个装备
return XDataCenter.ArchiveManager.IsEquipGet(equipId), condition.Desc
end,
2024-09-01 22:49:41 +02:00
[31102] = function(condition, equipId)
-- 装备是否达到目标等级
return XDataCenter.ArchiveManager.GetEquipLv(equipId) >= condition.Params[1], condition.Desc
end,
2024-09-01 22:49:41 +02:00
[31103] = function(condition, equipId)
-- 武器的突破次数是否达到目标次数
return XDataCenter.ArchiveManager.GetEquipBreakThroughTimes(equipId) >= condition.Params[1], condition.Desc
end,
2024-09-01 22:49:41 +02:00
[31104] = function(condition, suitId)
-- 套装中某一个意识的等级是否达到目标等级
local idList = XEquipConfig.GetEquipTemplateIdsBySuitId(suitId)
local targetNum = condition.Params[1]
local isOpen = false
for _, id in ipairs(idList) do
if XDataCenter.ArchiveManager.GetEquipLv(id) >= targetNum then
isOpen = true
break
end
end
return isOpen, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[31105] = function(condition, suitId)
-- 套装中某一个意识的突破次数是否达到目标次数
local idList = XEquipConfig.GetEquipTemplateIdsBySuitId(suitId)
local targetNum = condition.Params[1]
local isOpen = false
for _, id in ipairs(idList) do
if XDataCenter.ArchiveManager.GetEquipBreakThroughTimes(id) >= targetNum then
isOpen = true
break
end
end
return isOpen, condition.Desc
end,
2024-09-01 22:49:41 +02:00
[31106] = function(condition, suitId)
-- 套装中不同的意识的数量达到目标数量
return XDataCenter.ArchiveManager.GetAwarenessCountBySuitId(suitId) >= condition.Params[1], condition.Desc
end
}
function XConditionManager.GetConditionType(id)
local template = ConditionTemplate[id]
if not template then
XLog.Error("XConditionManager.GetConditionType error: can not found template, id is " .. id)
return XConditionManager.ConditionType.Unknown
end
-- 0代表公式专用没有范围设置主要是要与服务器逻辑同步
if template.Type == 0 then
return XConditionManager.ConditionType.Formula
elseif template.Type >= 13000 and template.Type < 14000 then
return XConditionManager.ConditionType.Character
elseif template.Type >= 18000 and template.Type < 19000 then
return XConditionManager.ConditionType.Team
2024-09-01 22:49:41 +02:00
elseif template.Type >= 24000 and template.Type < 25000 then
return XConditionManager.ConditionType.MixedTeam
elseif template.Type >= 30000 and template.Type < 31000 then
return XConditionManager.ConditionType.Kill
elseif template.Type >= 31000 and template.Type < 32000 then
return XConditionManager.ConditionType.Equip
else
return XConditionManager.ConditionType.Player
end
end
function XConditionManager.Init()
ConditionTemplate = XTableManager.ReadByIntKey(TABLE_CONDITION_PATH, XTable.XTableCondition, "Id")
end
function XConditionManager.GetConditionTemplate(id)
if not ConditionTemplate[id] then
XLog.Error("XConditionManager.GetConditionTemplate config is null " .. id)
return
end
return ConditionTemplate[id]
end
2024-09-01 22:49:41 +02:00
function XConditionManager.CheckCharacterCondition(id, ...)
local template = ConditionTemplate[id]
if not template then
XLog.Error("XConditionManager.CheckCharacterCondition error: can not found template, id is " .. id)
return DefaultRet
end
local func = CharacterCondition[template.Type]
if not func then
XLog.Error(
2024-09-01 22:49:41 +02:00
"XConditionManager.CheckCharacterCondition error: can not found condition, id is " ..
id .. " type is " .. template.Type
)
return DefaultRet
end
2024-09-01 22:49:41 +02:00
return func(template, ...)
end
function XConditionManager.CheckPlayerCondition(id, ...)
local template = ConditionTemplate[id]
if not template then
XLog.Error("XConditionManager.CheckPlayerCondition error: can not found template, id is " .. id)
return DefaultRet
end
local func = PlayerCondition[template.Type]
if not func then
XLog.Error(
2024-09-01 22:49:41 +02:00
"XConditionManager.CheckPlayerCondition error: can not found condition, id is " ..
id .. " type is " .. template.Type
)
return DefaultRet
end
return func(template, ...)
end
function XConditionManager.CheckTeamCondition(id, characterIds)
local template = ConditionTemplate[id]
if not template then
XLog.Error("XConditionManager.CheckTeamCondition error: can not found template, id is " .. id)
return DefaultRet
end
local func = TeamCondition[template.Type]
if not func then
XLog.Error(
2024-09-01 22:49:41 +02:00
"XConditionManager.CheckTeamCondition error: can not found condition, id is " ..
id .. " type is " .. template.Type
)
return DefaultRet
end
return func(template, characterIds)
end
function XConditionManager.CheckMixedTeamCondition(id, characterIds)
local template = ConditionTemplate[id]
if not template then
XLog.Error("XConditionManager.CheckMixedTeamCondition error: can not found template, id is " .. id)
return DefaultRet
end
local func = MixedTeamCondition[template.Type]
if not func then
XLog.Error(
"XConditionManager.CheckMixedTeamCondition error: can not found condition, id is " ..
id .. " type is " .. template.Type
)
return DefaultRet
end
return func(template, characterIds)
end
function XConditionManager.CheckKillCondition(id, NpcId)
local template = ConditionTemplate[id]
if not template then
XLog.Error("XConditionManager.CheckKillCondition error: can not found template, id is " .. id)
return DefaultRet
end
local func = KillCondition[template.Type]
if not func then
XLog.Error(
2024-09-01 22:49:41 +02:00
"XConditionManager.CheckKillCondition error: can not found condition, id is " ..
id .. " type is " .. template.Type
)
return DefaultRet
end
return func(template, NpcId)
end
-- checkedId can be suitId or equipId
function XConditionManager.CheckEquipCondition(conditionId, checkedId)
local template = ConditionTemplate[conditionId]
if not template then
XLog.Error("XConditionManager.CheckEquipCondition error: can not found template, id is " .. conditionId)
return DefaultRet
end
local func = EquipCondition[template.Type]
if not func then
XLog.Error(
2024-09-01 22:49:41 +02:00
"XConditionManager.CheckEquipCondition error: can not found condition, id is " ..
conditionId .. " type is " .. template.Type
)
return DefaultRet
end
return func(template, checkedId)
end
function XConditionManager.CheckCondition(id, ...)
local type = XConditionManager.GetConditionType(id)
if type == XConditionManager.ConditionType.Character then
return XConditionManager.CheckCharacterCondition(id, ...)
elseif type == XConditionManager.ConditionType.Team then
return XConditionManager.CheckTeamCondition(id, ...)
2024-09-01 22:49:41 +02:00
elseif type == XConditionManager.ConditionType.MixedTeam then
return XConditionManager.CheckMixedTeamCondition(id, ...)
elseif type == XConditionManager.ConditionType.Kill then
return XConditionManager.CheckKillCondition(id, ...)
elseif type == XConditionManager.ConditionType.Equip then
return XConditionManager.CheckEquipCondition(id, ...)
elseif type == XConditionManager.ConditionType.Formula then
return XConditionManager.CheckComplexCondition(id, ...)
else
return XConditionManager.CheckPlayerCondition(id, ...)
end
end
--[[
& | ()
1.1001 & (1002 | 1003)
2.1001 & 1002 | 1003 id201000
3.1001 & 1002 | 1003 1001 1002id5020
]]
function XConditionManager.CheckComplexCondition(id, ...)
2024-09-01 22:49:41 +02:00
local args = { ... }
local conditionFormula = XConditionManager.ConditionFormula
if conditionFormula == nil then
local XConditionFormula = require("XFormula/XConditionFormula")
conditionFormula = XConditionFormula.New()
XConditionManager.ConditionFormula = conditionFormula
end
local config = XConditionManager.GetConditionTemplate(id)
-- 便于在内部提示配置错误
conditionFormula:SetConfig(config)
local result, desc = conditionFormula:GetResult(config.Formula, args)
if config.Desc then
desc = config.Desc
end
return result, desc
end
function XConditionManager.GetConditionDescById(id)
if (ConditionTemplate[id] or {}).Desc then
return ConditionTemplate[id].Desc
end
end
function XConditionManager.GetConditionParams(id)
if (ConditionTemplate[id] or {}).Params then
return tableUnpack(ConditionTemplate[id].Params)
end
end