1
0
mirror of https://github.com/sys4-fr/server-nalc.git synced 2025-01-27 02:00:29 +01:00

improve throwing mod, arrows don't touch sign:text entity

arrows more accurate shooting
This commit is contained in:
crabman77 2015-08-20 20:26:01 +02:00
parent 5e8a22fc9d
commit 2da8ce1c1a
3 changed files with 38 additions and 29 deletions

View File

@ -41,22 +41,26 @@ local THROWING_ARROW_ENTITY={
THROWING_ARROW_ENTITY.on_step = function(self, dtime) THROWING_ARROW_ENTITY.on_step = function(self, dtime)
local newpos = self.object:getpos() local newpos = self.object:getpos()
if self.lastpos.x~=nil then if self.lastpos.x ~= nil then
for _, pos in pairs(throwing_get_trajectoire(self, newpos)) do for _, pos in pairs(throwing_get_trajectoire(self, newpos)) do
local node = minetest.get_node(pos) local node = minetest.get_node(pos)
local objs = minetest.get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, 2) local objs = minetest.get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, 2)
for k, obj in pairs(objs) do for k, obj in pairs(objs) do
local objpos = obj:getpos()
if throwing_is_player(self.player, obj) or throwing_is_entity(obj) then if throwing_is_player(self.player, obj) or throwing_is_entity(obj) then
local damage = 4 if (pos.x - objpos.x < 0.5 and pos.x - objpos.x > -0.5) and (pos.z - objpos.z < 0.5 and pos.z - objpos.z > -0.5) then
obj:punch(self.object, 1.0, {
full_punch_interval=1.0, local damage = 4
damage_groups={fleshy=damage}, obj:punch(self.object, 1.0, {
}, nil) full_punch_interval=1.0,
if math.random(0,100) % 2 == 0 then -- 50% of chance to drop //MFF (Mg|07/27/15) damage_groups={fleshy=damage},
minetest.add_item(pos, 'default:stick') }, nil)
if math.random(0,100) % 2 == 0 then -- 50% of chance to drop //MFF (Mg|07/27/15)
minetest.add_item(pos, 'default:stick')
end
self.object:remove()
return
end end
self.object:remove()
return
end end
end end
@ -67,19 +71,20 @@ THROWING_ARROW_ENTITY.on_step = function(self, dtime)
self.object:remove() self.object:remove()
return return
end end
if math.floor(self.lastpos.x+0.5) ~= math.floor(pos.x+0.5) or math.floor(self.lastpos.y+0.5) ~= math.floor(pos.y+0.5) or math.floor(self.lastpos.z+0.5) ~= math.floor(pos.z+0.5) then
if minetest.get_node(self.lastpos).name == "throwing:light" then if minetest.get_node(pos).name == "air" then
minetest.remove_node(self.lastpos) minetest.set_node(pos, {name="throwing:light"})
end
if minetest.get_node(pos).name == "air" then
minetest.set_node(pos, {name="throwing:light"})
end
end end
if minetest.get_node(self.lastpos).name == "throwing:light" then
minetest.remove_node(self.lastpos)
end
self.lastpos={x=pos.x, y=pos.y, z=pos.z}
end end
end end
self.lastpos={x=newpos.x, y=newpos.y, z=newpos.z} self.lastpos={x=newpos.x, y=newpos.y, z=newpos.z}
end end
minetest.register_entity("throwing:arrow_fire_entity", THROWING_ARROW_ENTITY) minetest.register_entity("throwing:arrow_fire_entity", THROWING_ARROW_ENTITY)
minetest.register_node("throwing:light", { minetest.register_node("throwing:light", {

View File

@ -24,7 +24,8 @@ function throwing_is_entity(obj)
return (obj:get_luaentity() ~= nil return (obj:get_luaentity() ~= nil
and not string.find(obj:get_luaentity().name, "throwing:arrow_") and not string.find(obj:get_luaentity().name, "throwing:arrow_")
and obj:get_luaentity().name ~= "__builtin:item" and obj:get_luaentity().name ~= "__builtin:item"
and obj:get_luaentity().name ~= "gauges:hp_bar") and obj:get_luaentity().name ~= "gauges:hp_bar"
and obj:get_luaentity().name ~= "signs:text")
end end
function throwing_get_trajectoire(self, newpos) function throwing_get_trajectoire(self, newpos)
if self.lastpos.x == nil then if self.lastpos.x == nil then

View File

@ -48,20 +48,23 @@ function throwing_register_arrow_standard (kind, desc, eq, toughness, craft)
local node = minetest.get_node(pos) local node = minetest.get_node(pos)
local objs = minetest.get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, 2) local objs = minetest.get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, 2)
for k, obj in pairs(objs) do for k, obj in pairs(objs) do
local objpos = obj:getpos()
if throwing_is_player(self.player, obj) or throwing_is_entity(obj) then if throwing_is_player(self.player, obj) or throwing_is_entity(obj) then
obj:punch(self.object, 1.0, { if (pos.x - objpos.x < 0.5 and pos.x - objpos.x > -0.5) and (pos.z - objpos.z < 0.5 and pos.z - objpos.z > -0.5) then
full_punch_interval=1.0, obj:punch(self.object, 1.0, {
damage_groups={fleshy=eq}, full_punch_interval=1.0,
}, nil) damage_groups={fleshy=eq},
if math.random() < toughness then }, nil)
if math.random(0,100) % 2 == 0 then if math.random() < toughness then
minetest.add_item(self.lastpos, 'throwing:arrow_' .. kind) if math.random(0,100) % 2 == 0 then
minetest.add_item(self.lastpos, 'throwing:arrow_' .. kind)
end
else
minetest.add_item(self.lastpos, 'default:stick')
end end
else self.object:remove()
minetest.add_item(self.lastpos, 'default:stick') return
end end
self.object:remove()
return
end end
end end
if node.name ~= "air" and not string.find(node.name, 'water_') and not string.find(node.name, 'default:grass') and not string.find(node.name, 'default:junglegrass') and not string.find(node.name, 'flowers:') and not string.find(node.name, 'farming:') then if node.name ~= "air" and not string.find(node.name, 'water_') and not string.find(node.name, 'default:grass') and not string.find(node.name, 'default:junglegrass') and not string.find(node.name, 'flowers:') and not string.find(node.name, 'farming:') then