Compare commits
No commits in common. "8b24793e829f46297238a9052179eda986f7e5c6" and "3d125f5cbc3a2e84692cd5162304afe76966cb21" have entirely different histories.
8b24793e82
...
3d125f5cbc
@ -9,10 +9,8 @@ local easing = require "lib.utils.easing"
|
||||
---
|
||||
--- Наносит `intensity` урона перед началом каждого хода.
|
||||
local bleeding = effect.new({
|
||||
tag = "bleeding"
|
||||
})
|
||||
|
||||
function bleeding:afterBirth(owner, intensity)
|
||||
tag = "bleeding",
|
||||
afterBirth = function(owner, intensity)
|
||||
local light = require "lib/character/character".spawn("Bleeding Light Effect")
|
||||
light:addBehavior {
|
||||
Tree.behaviors.light.new { color = Vec3 { 1, 0., 0. }, intensity = 4 },
|
||||
@ -24,7 +22,8 @@ function bleeding:afterBirth(owner, intensity)
|
||||
light:die()
|
||||
return task.fromValue()
|
||||
end) })
|
||||
end
|
||||
end
|
||||
})
|
||||
|
||||
function bleeding:beforeTurn(owner, intensity)
|
||||
local stats = owner:has(Tree.behaviors.stats)
|
||||
|
||||
@ -19,7 +19,7 @@ effect.__index = effect
|
||||
--- @alias EffectStatementFunc fun(owner: Character, intensity: integer): Task<nil>, boolean
|
||||
--- @alias EffectDamageFunc fun(owner: Character, intensity: integer, damage: integer): Task<nil>, integer
|
||||
--- @alias EffectRegenFunc fun(owner: Character, intensity: integer, amountHp: integer): Task<nil>, integer
|
||||
--- @alias EffectData { tag: string }
|
||||
--- @alias EffectData { tag: string, [string]: EffectFunc|EffectStatementFunc|EffectDamageFunc|EffectRegenFunc }
|
||||
|
||||
--- Срабатывает перед применением эффекта
|
||||
---
|
||||
@ -131,12 +131,12 @@ function effect:onBirth(owner, stacks, intensity)
|
||||
if not effects then return end
|
||||
-- проверяем на наличие такого же эффекта
|
||||
if effects.effectsProperties[self.tag] then
|
||||
local i = 1
|
||||
while i < #effects.effectsPriority and effects.effectsPriority[i] ~= self.tag do
|
||||
i = i + 1
|
||||
for i, ef in ipairs(effects.effectsPriority) do
|
||||
if ef == self.tag then
|
||||
table.remove(effects.effectsProperties, i)
|
||||
effects.effectsProperties[#effects.effectsProperties + 1] = ef
|
||||
end
|
||||
end
|
||||
local ef = table.remove(effects.effectsPriority, i)
|
||||
effects.effectsPriority[#effects.effectsPriority + 1] = ef
|
||||
else
|
||||
effects.effectsPriority[#effects.effectsPriority + 1] = self.tag
|
||||
end
|
||||
@ -161,9 +161,16 @@ end
|
||||
--- @return Effect
|
||||
local function new(data)
|
||||
local newEffect = setmetatable({
|
||||
tag = data.tag,
|
||||
tag = data.tag
|
||||
}, effect)
|
||||
|
||||
--- дип сравнение эффектов
|
||||
--- @param other Effect
|
||||
--- @return boolean
|
||||
function newEffect:__eq(other)
|
||||
return utils.deepComparison(self, other)
|
||||
end
|
||||
|
||||
return newEffect
|
||||
end
|
||||
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user