mirror of
https://github.com/sys4-fr/server-nalc.git
synced 2025-01-26 01:30:29 +01:00
improve throwing mod, arrows don't touch sign:text entity
arrows more accurate shooting
This commit is contained in:
parent
5e8a22fc9d
commit
2da8ce1c1a
@ -46,7 +46,10 @@ THROWING_ARROW_ENTITY.on_step = function(self, dtime)
|
|||||||
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
|
||||||
|
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
|
||||||
|
|
||||||
local damage = 4
|
local damage = 4
|
||||||
obj:punch(self.object, 1.0, {
|
obj:punch(self.object, 1.0, {
|
||||||
full_punch_interval=1.0,
|
full_punch_interval=1.0,
|
||||||
@ -59,6 +62,7 @@ THROWING_ARROW_ENTITY.on_step = function(self, dtime)
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
if node.name ~= "air" and node.name ~= "throwing:light" then
|
if node.name ~= "air" and node.name ~= "throwing:light" then
|
||||||
if node.name ~= "ignore" then
|
if node.name ~= "ignore" then
|
||||||
@ -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
|
|
||||||
minetest.remove_node(self.lastpos)
|
|
||||||
end
|
|
||||||
if minetest.get_node(pos).name == "air" then
|
if minetest.get_node(pos).name == "air" then
|
||||||
minetest.set_node(pos, {name="throwing:light"})
|
minetest.set_node(pos, {name="throwing:light"})
|
||||||
end
|
end
|
||||||
|
if minetest.get_node(self.lastpos).name == "throwing:light" then
|
||||||
|
minetest.remove_node(self.lastpos)
|
||||||
end
|
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", {
|
||||||
|
@ -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
|
||||||
|
@ -48,7 +48,9 @@ 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
|
||||||
|
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, {
|
obj:punch(self.object, 1.0, {
|
||||||
full_punch_interval=1.0,
|
full_punch_interval=1.0,
|
||||||
damage_groups={fleshy=eq},
|
damage_groups={fleshy=eq},
|
||||||
@ -64,6 +66,7 @@ function throwing_register_arrow_standard (kind, desc, eq, toughness, craft)
|
|||||||
return
|
return
|
||||||
end
|
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
|
||||||
if math.random() < toughness then
|
if math.random() < toughness then
|
||||||
minetest.add_item(self.lastpos, 'throwing:arrow_' .. kind)
|
minetest.add_item(self.lastpos, 'throwing:arrow_' .. kind)
|
||||||
|
Loading…
Reference in New Issue
Block a user