1
0
mirror of https://codeberg.org/tenplus1/mobs_redo.git synced 2025-01-26 00:50:21 +01:00

fix jumping when on need to

This commit is contained in:
tenplus1 2023-05-24 07:22:36 +01:00
parent 992d6319de
commit 267ee57837

16
api.lua
View File

@ -25,7 +25,7 @@ local use_cmi = minetest.global_exists("cmi")
mobs = { mobs = {
mod = "redo", mod = "redo",
version = "20230519", version = "20230524",
intllib = S, intllib = S,
invis = minetest.global_exists("invisibility") and invisibility or {} invis = minetest.global_exists("invisibility") and invisibility or {}
} }
@ -1208,6 +1208,9 @@ function mob_class:do_env_damage()
pos = pos, node = self.standing_in}) then pos = pos, node = self.standing_in}) then
return true return true
end end
-- try to jump out of block
self.object:set_velocity({x = 0, y = self.jump_height, z = 0})
end end
return self:check_for_death({type = "unknown"}) return self:check_for_death({type = "unknown"})
@ -1219,9 +1222,8 @@ function mob_class:do_jump()
local vel = self.object:get_velocity() ; if not vel then return false end local vel = self.object:get_velocity() ; if not vel then return false end
-- can't jump if already moving in air -- don't jump if ordered to stand or already in mid-air or moving forwards
if self.state ~= "stand" if self.state == "stand" or vel.y ~= 0 or self:get_velocity() > 0.2 then
and vel.y ~= 0 and self:get_velocity() > 0.5 then
return false return false
end end
@ -3392,12 +3394,6 @@ function mob_class:on_step(dtime, moveresult)
self.node_timer = 0 self.node_timer = 0
-- if standing inside solid block then jump to escape
if minetest.registered_nodes[self.standing_in].walkable
and minetest.registered_nodes[self.standing_in].drawtype == "normal" then
self.object:set_velocity({x = 0, y = self.jump_height, z = 0 })
end
-- check and stop if standing at cliff and fear of heights -- check and stop if standing at cliff and fear of heights
self.at_cliff = self:is_at_cliff() self.at_cliff = self:is_at_cliff()