Fix bobber colliding with doors,trapdoors, rework vl_projectile collides_with handling to affect all entities physical or not

This commit is contained in:
teknomunk 2025-01-03 16:02:12 -06:00
parent 0385abc277
commit 70d05a6720
2 changed files with 21 additions and 20 deletions

View file

@ -313,11 +313,12 @@ bobber_ENTITY.on_step = bobber_on_step
core.register_entity("mcl_fishing:bobber_entity", bobber_ENTITY) core.register_entity("mcl_fishing:bobber_entity", bobber_ENTITY)
vl_projectile.register("mcl_fishing:flying_bobber_entity", { vl_projectile.register("mcl_fishing:flying_bobber_entity", {
physical = false, physical = true,
collide_with_objects = false,
timer=0, timer=0,
textures = {"mcl_fishing_bobber.png"}, --FIXME: Replace with correct texture. textures = {"mcl_fishing_bobber.png"}, --FIXME: Replace with correct texture.
visual_size = {x=0.5, y=0.5}, visual_size = {x=0.5, y=0.5},
collisionbox = {0,0,0,0,0,0}, collisionbox = {-0.1,-0.1,-0.1,0.1,0.1,0.1},
pointable = false, pointable = false,
get_staticdata = mcl_throwing.get_staticdata, get_staticdata = mcl_throwing.get_staticdata,

View file

@ -359,24 +359,24 @@ function mod.collides_with_solids(self, dtime, entity_def, projectile_def)
local node_def = core.registered_nodes[node.name] local node_def = core.registered_nodes[node.name]
local collides_with = projectile_def.collides_with local collides_with = projectile_def.collides_with
if entity_def.physical then if not collides_with or not mcl_util.match_node_to_filter(node.name, collides_with) then
-- Projectile has stopped in one axis, so it probably hit something. if entity_def.physical then
-- This detection is a bit clunky, but sadly, MT does not offer a direct collision detection for us. :-( -- Projectile has stopped in one axis, so it probably hit something.
local vel = self.object:get_velocity() -- This detection is a bit clunky, but sadly, MT does not offer a direct collision detection for us. :-(
if not self._last_velocity then local vel = self.object:get_velocity()
self._last_velocity = vel if not self._last_velocity then
return self._last_velocity = vel
end return
end
local delta_v = (vel - self._last_velocity) local delta_v = (vel - self._last_velocity)
local vel_length = vector.length(vel) local vel_length = vector.length(vel)
if vel_length > 1 then delta_v = delta_v / vel_length end if vel_length > 1 then delta_v = delta_v / vel_length end
self._last_velocity = vel self._last_velocity = vel
if math.abs(delta_v.x) <= 0.1 and math.abs(delta_v.z) <= 0.1 and math.abs(delta_v.y) <= 0.2 then if math.abs(delta_v.x) <= 0.1 and math.abs(delta_v.z) <= 0.1 and math.abs(delta_v.y) <= 0.2 then
return return
end end
else elseif node_def and not node_def.walkable then
if node_def and not node_def.walkable and (not collides_with or not mcl_util.match_node_to_filter(node.name, collides_with)) then
return return
end end
end end
@ -430,7 +430,7 @@ function mod.collides_with_solids(self, dtime, entity_def, projectile_def)
if hook then hook(self, self._stuckin, snode, sdef) end if hook then hook(self, self._stuckin, snode, sdef) end
end end
-- Call entity collied hook -- Call entity collided hook
local hook = projectile_def.on_collide_with_solid local hook = projectile_def.on_collide_with_solid
if hook then hook(self, pos, node, node_def) end if hook then hook(self, pos, node, node_def) end