tweak velocity changes, merge from upstream

* Merge branch 'master' of https://notabug.org/TenPlus1/mobs_redo into main
This commit is contained in:
mckaygerhard 2023-08-05 22:47:20 -04:00
commit 49a5d903d4

19
api.lua
View File

@ -27,7 +27,7 @@ local use_cmi = minetest.global_exists("cmi")
mobs = { mobs = {
mod = "redo", mod = "redo",
version = "20230726", version = "20230805",
intllib = S, intllib = S,
invis = minetest.global_exists("invisibility") and invisibility or {}, invis = minetest.global_exists("invisibility") and invisibility or {},
node_ice = "default:ice", node_ice = "default:ice",
@ -279,7 +279,6 @@ function mob_class:collision()
local pos = self.object:get_pos() ; if not pos then return {0, 0} end local pos = self.object:get_pos() ; if not pos then return {0, 0} end
local x, z = 0, 0 local x, z = 0, 0
local vel = self.object:get_velocity()
local width = -self.collisionbox[1] + self.collisionbox[4] + 0.5 local width = -self.collisionbox[1] + self.collisionbox[4] + 0.5
for _,object in ipairs(minetest.get_objects_inside_radius(pos, width)) do for _,object in ipairs(minetest.get_objects_inside_radius(pos, width)) do
@ -372,7 +371,7 @@ function mob_class:set_velocity(v)
end end
-- set velocity -- set velocity
local vel = self.object:get_velocity() or 0 local vel = self.object:get_velocity() or {x = 0, y = 0, z = 0}
local new_vel = { local new_vel = {
x = (sin(yaw) * -v) + c_x, x = (sin(yaw) * -v) + c_x,
@ -1323,26 +1322,24 @@ function mob_class:do_jump()
and not self.facing_fence and not self.facing_fence
and self.looking_at ~= mobs.node_snow then and self.looking_at ~= mobs.node_snow then
local v = self.object:get_velocity() vel.y = self.jump_height
v.y = self.jump_height
self:set_animation("jump") -- only if defined self:set_animation("jump") -- only if defined
self.object:set_velocity(v) self.object:set_velocity(vel)
-- when in air move forward -- when in air move forward
minetest.after(0.3, function(self, v) minetest.after(0.3, function(self, vel)
if self.object:get_luaentity() then if self.object:get_luaentity() then
self.object:set_acceleration({ self.object:set_acceleration({
x = v.x * 2, x = vel.x * 2,
y = 0, y = 0,
z = v.z * 2 z = vel.z * 2
}) })
end end
end, self, v) end, self, vel)
if self:get_velocity() > 0 then if self:get_velocity() > 0 then
self:mob_sound(self.sounds.jump) self:mob_sound(self.sounds.jump)