when attacking dont call unecessary functions every step
This commit is contained in:
parent
14a3dc83e5
commit
ce53afcfdb
51
api.lua
51
api.lua
@ -25,7 +25,7 @@ local use_cmi = minetest.global_exists("cmi")
|
|||||||
|
|
||||||
mobs = {
|
mobs = {
|
||||||
mod = "redo",
|
mod = "redo",
|
||||||
version = "20230514",
|
version = "20230517",
|
||||||
intllib = S,
|
intllib = S,
|
||||||
invis = minetest.global_exists("invisibility") and invisibility or {}
|
invis = minetest.global_exists("invisibility") and invisibility or {}
|
||||||
}
|
}
|
||||||
@ -911,9 +911,8 @@ function mob_class:check_for_death(cmi_cause)
|
|||||||
|
|
||||||
self.cause_of_death = cmi_cause
|
self.cause_of_death = cmi_cause
|
||||||
|
|
||||||
-- drop items
|
-- drop items and play death sound
|
||||||
self:item_drop()
|
self:item_drop()
|
||||||
|
|
||||||
self:mob_sound(self.sounds.death)
|
self:mob_sound(self.sounds.death)
|
||||||
|
|
||||||
local pos = self.object:get_pos()
|
local pos = self.object:get_pos()
|
||||||
@ -932,6 +931,16 @@ function mob_class:check_for_death(cmi_cause)
|
|||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- reset vars and set state
|
||||||
|
self.attack = nil
|
||||||
|
self.following = nil
|
||||||
|
self.v_start = false
|
||||||
|
self.timer = 0
|
||||||
|
self.blinktimer = 0
|
||||||
|
self.passive = true
|
||||||
|
self.state = "die"
|
||||||
|
self.fly = false
|
||||||
|
|
||||||
-- check for custom death function and die animation
|
-- check for custom death function and die animation
|
||||||
if self.animation
|
if self.animation
|
||||||
and self.animation.die_start
|
and self.animation.die_start
|
||||||
@ -942,13 +951,6 @@ function mob_class:check_for_death(cmi_cause)
|
|||||||
local length = max((frames / speed), 0)
|
local length = max((frames / speed), 0)
|
||||||
local rot = self.animation.die_rotate and 5
|
local rot = self.animation.die_rotate and 5
|
||||||
|
|
||||||
self.attack = nil
|
|
||||||
self.following = nil
|
|
||||||
self.v_start = false
|
|
||||||
self.timer = 0
|
|
||||||
self.blinktimer = 0
|
|
||||||
self.passive = true
|
|
||||||
self.state = "die"
|
|
||||||
self.object:set_properties({
|
self.object:set_properties({
|
||||||
pointable = false, collide_with_objects = false,
|
pointable = false, collide_with_objects = false,
|
||||||
automatic_rotate = rot, static_save = false
|
automatic_rotate = rot, static_save = false
|
||||||
@ -970,7 +972,7 @@ function mob_class:check_for_death(cmi_cause)
|
|||||||
|
|
||||||
return true
|
return true
|
||||||
|
|
||||||
elseif pos then -- otherwise remove mod and show particle effect
|
elseif pos then -- otherwise remove mob and show particle effect
|
||||||
|
|
||||||
if use_cmi then
|
if use_cmi then
|
||||||
cmi.notify_die(self.object, cmi_cause)
|
cmi.notify_die(self.object, cmi_cause)
|
||||||
@ -3478,20 +3480,21 @@ function mob_class:on_step(dtime, moveresult)
|
|||||||
-- attack timer
|
-- attack timer
|
||||||
self.timer = self.timer + dtime
|
self.timer = self.timer + dtime
|
||||||
|
|
||||||
if self.state ~= "attack" then
|
|
||||||
|
|
||||||
if self.timer < 1 then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
self.timer = 0
|
|
||||||
end
|
|
||||||
|
|
||||||
-- never go over 100
|
-- never go over 100
|
||||||
if self.timer > 100 then
|
if self.timer > 100 then
|
||||||
self.timer = 1
|
self.timer = 1
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- when attacking call do_states live
|
||||||
|
if self.state == "attack" then
|
||||||
|
self:do_states(dtime)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- one second timed calls
|
||||||
|
self.timer1 = (self.timer1 or 0) + dtime
|
||||||
|
|
||||||
|
if self.timer1 >= 1 then
|
||||||
|
|
||||||
-- mob plays random sound at times
|
-- mob plays random sound at times
|
||||||
if random(100) == 1 then
|
if random(100) == 1 then
|
||||||
self:mob_sound(self.sounds.random)
|
self:mob_sound(self.sounds.random)
|
||||||
@ -3503,13 +3506,19 @@ function mob_class:on_step(dtime, moveresult)
|
|||||||
|
|
||||||
self:follow_flop()
|
self:follow_flop()
|
||||||
|
|
||||||
if self:do_states(dtime) then return end
|
-- when not attacking call do_states every second
|
||||||
|
if self.state ~= "attack" then
|
||||||
|
self:do_states(dtime)
|
||||||
|
end
|
||||||
|
|
||||||
self:do_jump()
|
self:do_jump()
|
||||||
|
|
||||||
self:do_runaway_from(self)
|
self:do_runaway_from(self)
|
||||||
|
|
||||||
self:do_stay_near()
|
self:do_stay_near()
|
||||||
|
|
||||||
|
self.timer1 = 0
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user