initial commit
This commit is contained in:
135
scripts/vscripts/modifiers/power/modifier_ability_power_junko.lua
Executable file
135
scripts/vscripts/modifiers/power/modifier_ability_power_junko.lua
Executable file
@@ -0,0 +1,135 @@
|
||||
modifier_ability_power_junko = class({})
|
||||
|
||||
local public = modifier_ability_power_junko
|
||||
|
||||
local m_modifier_funcs=
|
||||
{
|
||||
MODIFIER_PROPERTY_OVERRIDE_ABILITY_SPECIAL,
|
||||
MODIFIER_PROPERTY_OVERRIDE_ABILITY_SPECIAL_VALUE,
|
||||
}
|
||||
|
||||
local power_bonus = {
|
||||
["thtd_junko_02"] = {
|
||||
[1] = {
|
||||
["power_damage"] = 5,
|
||||
},
|
||||
[2] = {
|
||||
["power_damage"] = 10,
|
||||
},
|
||||
[3] = {
|
||||
["power_damage"] = 15,
|
||||
},
|
||||
},
|
||||
["thtd_junko_04"] = {
|
||||
[1] = {
|
||||
["power_damage1"] = 10,
|
||||
["power_damage2"] = 2,
|
||||
},
|
||||
[2] = {
|
||||
["power_damage1"] = 20,
|
||||
["power_damage2"] = 4,
|
||||
},
|
||||
[3] = {
|
||||
["power_damage1"] = 30,
|
||||
["power_damage2"] = 6,
|
||||
},
|
||||
},
|
||||
}
|
||||
local power666_bonus = 4
|
||||
local power999_bonus = 400
|
||||
|
||||
function public:IsHidden()
|
||||
return true
|
||||
end
|
||||
|
||||
function public:IsPermanent()
|
||||
return true
|
||||
end
|
||||
|
||||
function public:RemoveOnDeath()
|
||||
return false
|
||||
end
|
||||
|
||||
function public:IsDebuff()
|
||||
return false
|
||||
end
|
||||
|
||||
function public:IsPurgable()
|
||||
return false
|
||||
end
|
||||
|
||||
function public:DeclareFunctions()
|
||||
return m_modifier_funcs
|
||||
end
|
||||
|
||||
-- function public:OnCreated( kv )
|
||||
-- if not IsServer() then return end
|
||||
-- self:OnRefresh( kv )
|
||||
-- end
|
||||
|
||||
-- function public:OnRefresh( kv )
|
||||
-- if not IsServer() then return end
|
||||
-- end
|
||||
|
||||
function public:OnDestroy(kv)
|
||||
if not IsServer() then return end
|
||||
|
||||
local caster = self:GetParent()
|
||||
caster:THTD_AddPowerPercentage("thtd_junko_power_999")
|
||||
caster:THTD_AddAttackPercentage("thtd_junko_power_999")
|
||||
end
|
||||
|
||||
function public:OnStackCountChanged( iStackCount )
|
||||
-- 双端触发,iStackCount为改变前的层数
|
||||
if not IsServer() then return end
|
||||
|
||||
local caster = self:GetParent()
|
||||
if self:GetStackCount() == 5 then
|
||||
caster:THTD_AddPowerPercentage(power999_bonus, "thtd_junko_power_999")
|
||||
caster:THTD_AddAttackPercentage(power999_bonus, "thtd_junko_power_999")
|
||||
end
|
||||
end
|
||||
|
||||
function public:GetModifierOverrideAbilitySpecial( params )
|
||||
if self:GetParent() == nil or params.ability == nil then
|
||||
return 0
|
||||
end
|
||||
|
||||
local abilityName = params.ability:GetAbilityName()
|
||||
local level = self:GetStackCount()
|
||||
local valueName = params.ability_special_value
|
||||
|
||||
if power_bonus[abilityName] == nil then
|
||||
return 0
|
||||
end
|
||||
|
||||
if power_bonus[abilityName][level] == nil then
|
||||
level = 3
|
||||
end
|
||||
if power_bonus[abilityName][level] == nil then
|
||||
return 0
|
||||
end
|
||||
|
||||
if power_bonus[abilityName][level][valueName] == nil then
|
||||
return 0
|
||||
end
|
||||
|
||||
return 1
|
||||
end
|
||||
|
||||
function public:GetModifierOverrideAbilitySpecialValue( params )
|
||||
local abilityName = params.ability:GetAbilityName()
|
||||
local level = self:GetStackCount()
|
||||
local valueName = params.ability_special_value
|
||||
local specialLevel = params.ability_special_level
|
||||
|
||||
if power_bonus[abilityName][level] == nil then
|
||||
level = 3
|
||||
end
|
||||
|
||||
if self:GetStackCount() >= 4 then
|
||||
return (params.ability:GetLevelSpecialValueNoOverride(valueName, specialLevel) + power_bonus[abilityName][level][valueName]) * power666_bonus
|
||||
else
|
||||
return params.ability:GetLevelSpecialValueNoOverride(valueName, specialLevel) + power_bonus[abilityName][level][valueName]
|
||||
end
|
||||
end
|
||||
Reference in New Issue
Block a user