PGRData/Script/matrix/xmanager/XFightEquipManager.lua

848 lines
25 KiB
Lua
Raw Permalink Normal View History

local pairs = pairs
local type = type
local table = table
local tableInsert = table.insert
local mathMin = math.min
XFightEquipManager = XFightEquipManager or {}
local function Awake()
end
local function GetEquipTemplate(equipTemplateId)
local template = XEquipConfig.GetEquipCfg(equipTemplateId)
if not template then
return XCode.EquipTemplateNotFound, nil
end
return XCode.Success, template
end
local function GetBreakthroughTemplate(equipTemplateId, times)
local template = XEquipConfig.GetEquipBreakthroughCfg(equipTemplateId, times)
if not template then
return XCode.EquipBreakthroughTemplateNotFound, nil
end
return XCode.Success, template
end
local function GetWeaponSkillTemplate(templateId)
local template = XEquipConfig.GetWeaponSkillTemplate(templateId)
if not template then
return XCode.EquipWeaponSkillTemplateNotFound, nil
end
return XCode.Success, template
end
local function GetSuitTemplate(suitId)
local template = XEquipConfig.GetEquipSuitCfg(suitId)
if not template then
return XCode.EquipSuitTemplateNotFound, nil
end
return XCode.Success, template
end
local function GetSuitEffectTemplate(templateId)
local template = XEquipConfig.GetEquipSuitEffectCfg(templateId)
if not template then
return XCode.EquipSuitEffectTemplateNotFound, nil
end
return XCode.Success, template
end
local function GetEquipAwakeTemplate(templateId)
local template = XEquipConfig.GetEquipAwakeCfg(templateId)
if not template then
return XCode.EquipAwakeTemplateNotFound, nil
end
return XCode.Success, template
end
2024-09-01 22:49:41 +02:00
local function GetWeaponOverrunTemplate(templateId)
local cfg = XEquipConfig.GetWeaponOverrunSuitCfgByTemplateId(templateId)
if cfg then
return XCode.Success, cfg
else
return XCode.EquipWeaponOverrunCfgNotFound
end
end
local function GetCharacterTemplate(templateId)
local cfg = XCharacterConfigs.GetCharacterTemplate(templateId)
if cfg then
return XCode.Success, cfg
else
return XCode.CharacterManagerGetCharacterTemplateNotFound
end
end
local function GetSuitCharacterType(suitId)
local suitCharType = XEquipConfig.GetSuitCharacterType(suitId)
return suitCharType
end
local function GetOverrunCfgs(templateId)
local cfgs = XEquipConfig.GetWeaponOverrunCfgsByTemplateId(templateId)
if cfgs then
return XCode.Success, cfgs
else
return XCode.EquipWeaponOverrunCfgNotFound
end
end
----获取套装数量
local function GetEquipSuitCount(equips, equipSuitCountDict)
for _, equip in pairs(equips) do
local code, template = GetEquipTemplate(equip.TemplateId)
if code ~= XCode.Success then
return code
end
-- 武器超限选择的套装
local choseOverrunSuit = equip.WeaponOverrunData and equip.WeaponOverrunData.ChoseSuit or 0
if choseOverrunSuit > 0 then
local overrunTemplate
code, overrunTemplate = GetWeaponOverrunTemplate(equip.TemplateId)
if code ~= XCode.Success then
return code
end
local characterTemplate
code, characterTemplate = GetCharacterTemplate(equip.CharacterId)
if code ~= XCode.Success then
return code
end
-- 意识套装与当前角色匹配才生效
local suitCharType = GetSuitCharacterType(choseOverrunSuit)
if suitCharType == characterTemplate.Type then
if not equipSuitCountDict[choseOverrunSuit] then
equipSuitCountDict[choseOverrunSuit] = 2
else
equipSuitCountDict[choseOverrunSuit] = equipSuitCountDict[choseOverrunSuit] + 2
end
end
end
if template.SuitId > 0 then
if not equipSuitCountDict[template.SuitId] then
equipSuitCountDict[template.SuitId] = 1
else
equipSuitCountDict[template.SuitId] = equipSuitCountDict[template.SuitId] + 1
end
end
end
return XCode.Success
end
-----------------------------------------Attribs Begin---------------------------------------
---突破属性成长加成
---@param equipData userdata 装备数据
---@param attribIds table 属性id列表
---@param trainedLevels table 培养等级列表
---@return XCode 状态码
local function DoAddBreakthroughPromotedAttribId(equipData, attribIds, trainedLevels)
local code, template = GetBreakthroughTemplate(equipData.TemplateId, equipData.Breakthrough)
if code ~= XCode.Success then
return code
end
local trainedLevel = equipData.Level - 1
if trainedLevel > 0 and template.AttribPromotedId > 0 then
tableInsert(attribIds, template.AttribPromotedId)
tableInsert(trainedLevels, trainedLevel)
end
return XCode.Success
end
2024-09-01 22:49:41 +02:00
local function DoAddBreakthroughAttribId(equipData, characterId, attribIds)
local code, template = GetBreakthroughTemplate(equipData.TemplateId, equipData.Breakthrough)
if code ~= XCode.Success then
return code
end
if template.AttribId > 0 then
tableInsert(attribIds, template.AttribId)
end
return XCode.Success
end
---共鸣属性叠加id
local function DoAddResonanceAttribId(equipData, characterId, attribIds)
local resonanceInfo = equipData.ResonanceInfo
if type(resonanceInfo) == "userdata" then
resonanceInfo = XTool.CsList2LuaTable(resonanceInfo)
end
for _, resonanceData in pairs(resonanceInfo) do
if resonanceData.Type == XEquipConfig.EquipResonanceType.Attrib or
resonanceData.Type == CS.EquipResonanceType.Attrib then
if resonanceData.CharacterId == 0 or resonanceData.CharacterId == characterId then
local code, template = XAttribManager.GetAttribGroupTemplate(resonanceData.TemplateId)
if code ~= XCode.Success then
return code
end
if template.AttribId > 0 then
tableInsert(attribIds, template.AttribId)
end
end
end
end
return XCode.Success
end
---共鸣属性加成id
local function DoAddResonanceGrowRateAttribId(equipData, characterId, attribIds)
local resonanceInfo = equipData.ResonanceInfo
if type(resonanceInfo) == "userdata" then
resonanceInfo = XTool.CsList2LuaTable(resonanceInfo)
end
for _, resonanceData in pairs(resonanceInfo) do
if resonanceData.Type == XEquipConfig.EquipResonanceType.Attrib or
resonanceData.Type == CS.EquipResonanceType.Attrib then
if resonanceData.CharacterId == 0 or resonanceData.CharacterId == characterId then
local code, template = XAttribManager.GetAttribGroupTemplate(resonanceData.TemplateId)
if code ~= XCode.Success then
return code
end
if template.AttribGrowRateId > 0 then
tableInsert(attribIds, template.AttribGrowRateId)
end
end
end
end
return XCode.Success
end
--- 觉醒属性叠加id
local function DoAddAwakeAttribId(equipData, characterId, attribIds)
local awakeSlotList = equipData.AwakeSlotList
if type(awakeSlotList) == "userdata" then
awakeSlotList = XTool.CsList2LuaTable(awakeSlotList)
end
if not awakeSlotList or not next(awakeSlotList) then
return XCode.Success
end
local code, template = GetEquipAwakeTemplate(equipData.TemplateId)
if code ~= XCode.Success then
return code
end
local resonanceInfo = equipData.ResonanceInfo
if type(resonanceInfo) == "userdata" then
resonanceInfo = XTool.CsList2LuaTable(resonanceInfo)
end
for _, slot in pairs(awakeSlotList) do
for _, resonanceData in pairs(resonanceInfo) do
if resonanceData.Slot == slot then
if resonanceData.CharacterId == 0 or resonanceData.CharacterId == characterId then
local attribId = template.AttribId[slot]
if not attribId then
return XCode.EquipAwakeSlotAttribConfigNotFound
end
tableInsert(attribIds, attribId)
end
end
end
end
return XCode.Success
end
2024-09-01 22:49:41 +02:00
--- 属性计算, 所有装备
--- 1、突破提供基础属性
--- 2、共鸣属性计算
--- 3、觉醒提供属性
local function AddNumericAttribId(npcData, attribIds)
local equips = npcData.Equips
if not equips then
return XCode.Success
end
if type(equips) == "userdata" then
equips = XTool.CsList2LuaTable(equips)
end
if #equips <= 0 then
return XCode.Success
end
for _, equipData in pairs(equips) do
2024-09-01 22:49:41 +02:00
local code = DoAddBreakthroughAttribId(equipData, npcData.Character.Id, attribIds)
if code ~= XCode.Success then
return code
end
if equipData.ResonanceInfo then
code = DoAddResonanceAttribId(equipData, npcData.Character.Id, attribIds)
if code ~= XCode.Success then
return code
end
end
if equipData.AwakeSlotList then
code = DoAddAwakeAttribId(equipData, npcData.Character.Id, attribIds)
if code ~= XCode.Success then
return code
end
end
end
return XCode.Success
end
2024-09-01 22:49:41 +02:00
local function GetEquipDataFromFightNpcDataByEquipSite(npcData, equipSite)
local equips = npcData.Equips
if equips.Count == 0 then
return
end
if type(equips) == "userdata" then
equips = XTool.CsList2LuaTable(equips)
end
for _, equipData in pairs(equips) do
local code, template = GetEquipTemplate(equipData.TemplateId)
if code == XCode.Success and template.Site == equipSite then
return equipData
end
end
end
function XFightEquipManager.AddBreakthroughAttribIdByEquipSite(npcData, equipSite, attribIds)
local equipData = GetEquipDataFromFightNpcDataByEquipSite(npcData, equipSite)
if equipData == nil then
return XCode.Success
end
return DoAddBreakthroughAttribId(equipData, npcData.Character.Id, attribIds)
end
function XFightEquipManager.AddNumericAttribIdByEquipSite(npcData, equipSite, attribIds)
local equipData = GetEquipDataFromFightNpcDataByEquipSite(npcData, equipSite)
if equipData == nil then
return XCode.Success
end
return AddNumericAttribIdByEquip(npcData, equipData, attribIds)
end
--- 属性百分比加成
--- 1、共鸣提供加成
local function AddGrowRateAttribId(npcData, attribIds)
local equips = npcData.Equips
if not equips then
return XCode.Success
end
if type(equips) == "userdata" then
equips = XTool.CsList2LuaTable(equips)
end
if #equips < 0 then
return XCode.Success
end
for _, equipData in pairs(equips) do
if equipData.ResonanceInfo then
local code = DoAddResonanceGrowRateAttribId(equipData, npcData.Character.Id, attribIds)
if code ~= XCode.Success then
return code
end
end
end
return XCode.Success
end
--- 属性成长加成
--- 1、突破提供加成
local function AddPromotedAttribId(npcData, attribIds, trainedLevels)
local equips = npcData.Equips
if not equips then
return XCode.Success
end
if type(equips) == "userdata" then
equips = XTool.CsList2LuaTable(equips)
end
if #equips <= 0 then
return XCode.Success
end
for _, equipData in pairs(equips) do
local code = DoAddBreakthroughPromotedAttribId(equipData, attribIds, trainedLevels)
if code ~= XCode.Success then
return code
end
end
return XCode.Success
end
2024-09-01 22:49:41 +02:00
function XFightEquipManager.AddPromotedAttribIdByEquipSite(npcData, equipSite, attribIds, trainedLevels)
local equipData = GetEquipDataFromFightNpcDataByEquipSite(npcData, equipSite)
if not equipData then
return XCode.Success
end
local code = DoAddBreakthroughPromotedAttribId(equipData, attribIds, trainedLevels)
return code
end
-----------------------------------------Attribs End-----------------------------------------
-----------------------------------------Skill Begin-----------------------------------------
---武器技能等级集合
---武器技能都为1级
---@param equipData userdata 装备数据
---@param levelMap table 技能等级集合
---@return XCode 状态码
local function DoGetWeaponSkillLevel(equipData, levelMap)
local code, template = GetEquipTemplate(equipData.TemplateId)
if code ~= XCode.Success then
return code
end
if template.Site ~= XEquipConfig.EquipSite.Weapon then
return XCode.Success
end
if template.WeaponSkillId <= 0 then
return XCode.Success
end
local skillTemplate
code, skillTemplate = GetWeaponSkillTemplate(template.WeaponSkillId)
if code ~= XCode.Success then
return code
end
for _, subSkillId in pairs(skillTemplate.SubSkillId) do
levelMap[subSkillId] = 1
end
return XCode.Success
end
---武器共鸣技能集合
---共鸣技能等级都为1级
---@param equipData userdata 装备数据
---@param characterId number 角色id
---@param levelMap table 技能等级集合
---@return XCode 状态码
local function DoGetResonanceSkillLevel(equipData, characterId, levelMap)
local resonanceInfo = equipData.ResonanceInfo
if type(resonanceInfo) == "userdata" then
resonanceInfo = XTool.CsList2LuaTable(resonanceInfo)
end
for _, resonanceData in pairs(resonanceInfo) do
if resonanceData.Type == CS.EquipResonanceType.WeaponSkill then
if resonanceData.CharacterId == 0 or resonanceData.CharacterId == characterId then
local code, skillTemplate = GetWeaponSkillTemplate(resonanceData.TemplateId)
if code ~= XCode.Success then
return code
end
for _, subSkillId in pairs(skillTemplate.SubSkillId) do
levelMap[subSkillId] = 1
end
end
end
end
return XCode.Success
end
---套装技能等级集合
---套装技能等级都为1级
---@param equips userdata 装备数据
---@param levelMap table 技能等级集合
---@return XCode 状态码
local function DoGetSuitSkillLevel(equips, levelMap)
local suitCount = {}
if type(equips) == "userdata" then
equips = XTool.CsList2LuaTable(equips)
end
2024-09-01 22:49:41 +02:00
local code = GetEquipSuitCount(equips, suitCount)
if code ~= XCode.Success then
return code
end
for suitId, count in pairs(suitCount) do
local code, template = GetSuitTemplate(suitId)
if code ~= XCode.Success then
return code
end
for i = 1, mathMin(count, XEquipConfig.MAX_SUIT_COUNT) do
local effectId = template.SkillEffect[i]
if effectId and effectId > 0 then
local effectTemplate
code, effectTemplate = GetSuitEffectTemplate(effectId)
if code ~= XCode.Success then
return code
end
if #effectTemplate.SkillId > 0 then
for _, skillId in pairs(effectTemplate.SkillId) do
levelMap[skillId] = 1
end
end
end
end
end
return XCode.Success
end
---武器额外技能加成
---额外技能等级都为1级
---@param plusSkillList userdata 额外加成技能列表
---@param levelMap table 技能等级集合
---@return XCode 状态码
local function DoGetPlusSkillLevel(plusSkillList, levelMap)
if not plusSkillList then
return XCode.Success
end
if type(plusSkillList) == "userdata" then
plusSkillList = XTool.CsList2LuaTable(plusSkillList)
end
for _, skillId in pairs(plusSkillList) do
local code, skillTemplate = GetWeaponSkillTemplate(skillId)
if code ~= XCode.Success then
return code
end
for _, subSkillId in pairs(skillTemplate.SubSkillId) do
levelMap[subSkillId] = 1
end
end
return XCode.Success
end
--- 技能等级
--- 1、武器技能加成
--- 2、共鸣提供加成
--- 3、套装技能加成
--- 4、武器额外技能加成
local function GetSkillLevel(npcData, levelMap)
local code
local equips = npcData.Equips
if type(equips) == "userdata" then
equips = XTool.CsList2LuaTable(equips)
end
for _, equipData in pairs(equips) do
code = DoGetWeaponSkillLevel(equipData, levelMap)
if code ~= XCode.Success then
return code
end
code = DoGetResonanceSkillLevel(equipData, npcData.Character.Id, levelMap)
if code ~= XCode.Success then
return code
end
end
code = DoGetSuitSkillLevel(equips, levelMap)
if code ~= XCode.Success then
return code
end
code = DoGetPlusSkillLevel(npcData.EquipSkillPlus, levelMap)
if code ~= XCode.Success then
return code
end
return XCode.Success
end
-----------------------------------------Skill End-----------------------------------------
-----------------------------------------Magic Begin-----------------------------------------
---武器出生魔法等级集合
---武器出生魔法等级都为1级
---@param equipData userdata 装备数据
---@param levelMap table 出生魔法等级集合
---@return XCode 状态码
local function DoGetWeaponBornMagicLevel(equipData, levelMap)
local code, template = GetEquipTemplate(equipData.TemplateId)
if code ~= XCode.Success then
return code
end
if template.Site ~= XEquipConfig.EquipSite.Weapon then
return XCode.Success
end
if template.WeaponSkillId <= 0 then
return XCode.Success
end
local skillTemplate
code, skillTemplate = GetWeaponSkillTemplate(template.WeaponSkillId)
if code ~= XCode.Success then
return code
end
for _, magic in pairs(skillTemplate.BornMagic) do
levelMap[magic] = 1
end
return XCode.Success
end
---武器共鸣出生魔法等级集合
---共鸣出生魔法等级都为1级
---@param equipData userdata 装备数据
---@param characterId number 角色id
---@param levelMap table 技能等级集合
---@return XCode 状态码
local function DoGetResonanceBornMagicLevel(equipData, characterId, levelMap)
local resonanceInfo = equipData.ResonanceInfo
if type(resonanceInfo) == "userdata" then
resonanceInfo = XTool.CsList2LuaTable(resonanceInfo)
end
for _, resonanceData in pairs(resonanceInfo) do
if resonanceData.Type == CS.EquipResonanceType.WeaponSkill then
if resonanceData.CharacterId == 0 or resonanceData.CharacterId == characterId then
local code, skillTemplate = GetWeaponSkillTemplate(resonanceData.TemplateId)
if code ~= XCode.Success then
return code
end
for _, magic in pairs(skillTemplate.BornMagic) do
levelMap[magic] = 1
end
end
end
end
return XCode.Success
end
2024-09-01 22:49:41 +02:00
----武器超限魔法属性
----@param equipData userdata 装备数据
----@param levelMap table 技能等级集合
local function DoGetOverrunBornMagicLevel(equipData, levelMap)
if equipData.WeaponOverrunData == nil or equipData.WeaponOverrunData.Level <= 0 then
return XCode.Success
end
local code, overrunCfgs = GetOverrunCfgs(equipData.TemplateId)
if code ~= XCode.Success then
return code
end
for i = 1, equipData.WeaponOverrunData.Level do
for _, overrunCfg in ipairs(overrunCfgs) do
if overrunCfg.Level == i and overrunCfg.MagicIds then
for _, magicId in ipairs(overrunCfg.MagicIds) do
local magicCnt = levelMap[magicId] or 0
magicCnt = magicCnt + 1
levelMap[magicId] = magicCnt
end
end
end
end
return XCode.Success
end
---套装出生魔法等级集合
---套装出生魔法等级都为1级
---@param equips userdata 装备数据
---@param levelMap table 出生魔法等级集合
---@return XCode 状态码
local function DoGetSuitBornMagicLevel(equips, levelMap)
local suitCount = {}
if type(equips) == "userdata" then
equips = XTool.CsList2LuaTable(equips)
end
2024-09-01 22:49:41 +02:00
local code = GetEquipSuitCount(equips, suitCount)
if code ~= XCode.Success then
return code
end
for suitId, count in pairs(suitCount) do
2024-09-01 22:49:41 +02:00
local template
code, template = GetSuitTemplate(suitId)
if code ~= XCode.Success then
return code
end
for i = 1, mathMin(count, XEquipConfig.MAX_SUIT_COUNT) do
local effectId = template.SkillEffect[i]
if effectId and effectId > 0 then
local effectTemplate
code, effectTemplate = GetSuitEffectTemplate(effectId)
if code ~= XCode.Success then
return code
end
if #effectTemplate.BornMagic > 0 then
for _, bornMagic in pairs(effectTemplate.BornMagic) do
levelMap[bornMagic] = 1
end
end
end
end
end
return XCode.Success
end
---武器额外出生魔法等级加成
---额外出生魔法等级都为1级
---@param plusSkillList userdata 额外加成技能列表
---@param levelMap table 出生魔法等级集合
---@return XCode 状态码
local function DoGetPlusBornMagicLevel(plusSkillList, levelMap)
if not plusSkillList then
return XCode.Success
end
if type(plusSkillList) == "userdata" then
plusSkillList = XTool.CsList2LuaTable(plusSkillList)
end
for _, skillId in pairs(plusSkillList) do
local code, skillTemplate = GetWeaponSkillTemplate(skillId)
if code ~= XCode.Success then
return code
end
for _, magic in pairs(skillTemplate.BornMagic) do
levelMap[magic] = 1
end
end
return XCode.Success
end
--- 出生魔法属性等级
--- 1、武器技能加成
--- 2、共鸣提供加成
2024-09-01 22:49:41 +02:00
--- 3、武器超限加成
--- 4、套装技能加成
--- 5、武器额外技能加成
local function GetBornMagicLevel(npcData, levelMap)
local code
local equips = npcData.Equips
if type(equips) == "userdata" then
equips = XTool.CsList2LuaTable(equips)
end
for _, equipData in pairs(equips) do
code = DoGetWeaponBornMagicLevel(equipData, levelMap)
if code ~= XCode.Success then
return code
end
code = DoGetResonanceBornMagicLevel(equipData, npcData.Character.Id, levelMap)
if code ~= XCode.Success then
return code
end
2024-09-01 22:49:41 +02:00
code = DoGetOverrunBornMagicLevel(equipData, levelMap)
if code ~= XCode.Success then
return code
end
end
code = DoGetSuitBornMagicLevel(npcData.Equips, levelMap)
if code ~= XCode.Success then
return code
end
code = DoGetPlusBornMagicLevel(npcData.EquipSkillPlus, levelMap)
if code ~= XCode.Success then
return code
end
return XCode.Success
end
-----------------------------------------Magic End-----------------------------------------
local function RegisterInterfaces()
XAttribManager.RegisterGrowRateIdInterface(AddGrowRateAttribId)
XAttribManager.RegisterNumericIdInterface(AddNumericAttribId)
XAttribManager.RegisterPromotedIdInterface(AddPromotedAttribId)
XMagicSkillManager.RegisterSkillLevelInterface(GetSkillLevel)
XMagicSkillManager.RegisterBornMagicLevelInterface(GetBornMagicLevel)
end
function XFightEquipManager.Init()
Awake()
RegisterInterfaces()
end
---------------------------------------客户端特有方法---------------------------------------
local function DoGetEquipAttribIds(equipData, numericIds, promotedIds, trainedLevels)
local code, template = GetBreakthroughTemplate(equipData.TemplateId, equipData.Breakthrough)
if code ~= XCode.Success then
return
end
tableInsert(numericIds, template.AttribId)
DoAddBreakthroughPromotedAttribId(equipData, promotedIds, trainedLevels)
end
2024-09-01 22:49:41 +02:00
function XFightEquipManager.GetEquipAttribs(equipData, preBreakthrough, preLevel)
local numericIds = {}
local trainedLevels = {}
local promotedIds = {}
2024-09-01 22:49:41 +02:00
local breakthrough = preBreakthrough or equipData.Breakthrough
local equipLevel = preLevel or equipData.Level
DoGetEquipAttribIds({
TemplateId = equipData.TemplateId,
2024-09-01 22:49:41 +02:00
Breakthrough = breakthrough,
Level = equipLevel
}, numericIds, promotedIds, trainedLevels)
return XAttribManager.GetMergeAttribs(numericIds, promotedIds, trainedLevels)
end
function XFightEquipManager.GetEquipListAttribs(equipDatas)
local numericIds = {}
local trainedLevels = {}
local promotedIds = {}
XTool.LoopCollection(equipDatas, function(equipData)
DoGetEquipAttribIds(equipData, numericIds, promotedIds, trainedLevels)
end)
return XAttribManager.GetMergeAttribs(numericIds, promotedIds, trainedLevels)
end