1
0
mirror of https://github.com/sys4-fr/server-nalc.git synced 2025-01-12 11:00:25 +01:00

Itemframes mod update

MAJ de "itemframe" (Suppression de la version Carbone, ajout de la
version de VanessaE provenant de "homedecor_modpack" étant plus à jour
et corrigeant entre autre un bugfix qui faisait crasher le serveur, et
une auto-regénération des objets framed si un clearobjects est effectué)
This commit is contained in:
Ombridride 2014-11-15 04:06:04 +01:00
parent bd50c46fc2
commit 8af48eefe2
6 changed files with 65 additions and 55 deletions

View File

@ -3,10 +3,10 @@ local tmp = {}
minetest.register_entity("itemframes:item",{ minetest.register_entity("itemframes:item",{
hp_max = 1, hp_max = 1,
visual="wielditem", visual="wielditem",
visual_size = {x = 0.3333, y = 0.3333}, visual_size={x=.33,y=.33},
collisionbox = {0,0,0,0,0,0}, collisionbox = {0,0,0,0,0,0},
physical = false, physical=false,
textures = {"air"}, textures={"air"},
on_activate = function(self, staticdata) on_activate = function(self, staticdata)
if tmp.nodename ~= nil and tmp.texture ~= nil then if tmp.nodename ~= nil and tmp.texture ~= nil then
self.nodename = tmp.nodename self.nodename = tmp.nodename
@ -15,7 +15,7 @@ minetest.register_entity("itemframes:item",{
tmp.texture = nil tmp.texture = nil
else else
if staticdata ~= nil and staticdata ~= "" then if staticdata ~= nil and staticdata ~= "" then
local data = staticdata:split(";") local data = staticdata:split(';')
if data and data[1] and data[2] then if data and data[1] and data[2] then
self.nodename = data[1] self.nodename = data[1]
self.texture = data[2] self.texture = data[2]
@ -23,15 +23,15 @@ minetest.register_entity("itemframes:item",{
end end
end end
if self.texture ~= nil then if self.texture ~= nil then
self.object:set_properties({textures = {self.texture}}) self.object:set_properties({textures={self.texture}})
end end
if self.nodename == "itemframes:pedestal" then if self.nodename == "itemframes:pedestal" then
self.object:set_properties({automatic_rotate = 0.5}) self.object:set_properties({automatic_rotate=1})
end end
end, end,
get_staticdata = function(self) get_staticdata = function(self)
if self.nodename ~= nil and self.texture ~= nil then if self.nodename ~= nil and self.texture ~= nil then
return self.nodename .. ";" .. self.texture return self.nodename .. ';' .. self.texture
end end
return "" return ""
end, end,
@ -39,17 +39,17 @@ minetest.register_entity("itemframes:item",{
local facedir = {} local facedir = {}
facedir[0] = {x = 0, y = 0, z = 1} facedir[0] = {x=0,y=0,z=1}
facedir[1] = {x = 1, y = 0, z = 0} facedir[1] = {x=1,y=0,z=0}
facedir[2] = {x = 0, y = 0, z = -1} facedir[2] = {x=0,y=0,z=-1}
facedir[3] = {x = -1, y = 0, z = 0} facedir[3] = {x=-1,y=0,z=0}
local remove_item = function(pos, node) local remove_item = function(pos, node)
local objs = nil local objs = nil
if node.name == "itemframes:frame" then if node.name == "itemframes:frame" then
objs = minetest.get_objects_inside_radius(pos, 0.5) objs = minetest.env:get_objects_inside_radius(pos, .5)
elseif node.name == "itemframes:pedestal" then elseif node.name == "itemframes:pedestal" then
objs = minetest.get_objects_inside_radius({x = pos.x, y = pos.y + 1, z = pos.z}, 0.5) objs = minetest.env:get_objects_inside_radius({x=pos.x,y=pos.y+1,z=pos.z}, .5)
end end
if objs then if objs then
for _, obj in ipairs(objs) do for _, obj in ipairs(objs) do
@ -62,19 +62,20 @@ end
local update_item = function(pos, node) local update_item = function(pos, node)
remove_item(pos, node) remove_item(pos, node)
local meta = minetest.get_meta(pos) local meta = minetest.env:get_meta(pos)
if meta:get_string("item") ~= "" then if meta:get_string("item") ~= "" then
if node.name == "itemframes:frame" then if node.name == "itemframes:frame" then
local posad = facedir[node.param2] local posad = facedir[node.param2]
pos.x = pos.x + posad.x * 6.5 / 16 if not posad then return end
pos.y = pos.y + posad.y * 6.5 / 16 pos.x = pos.x + posad.x*6.5/16
pos.z = pos.z + posad.z * 6.5 / 16 pos.y = pos.y + posad.y*6.5/16
pos.z = pos.z + posad.z*6.5/16
elseif node.name == "itemframes:pedestal" then elseif node.name == "itemframes:pedestal" then
pos.y = pos.y + 0.5 + 0.3333 pos.y = pos.y + 12/16+.33
end end
tmp.nodename = node.name tmp.nodename = node.name
tmp.texture = ItemStack(meta:get_string("item")):get_name() tmp.texture = ItemStack(meta:get_string("item")):get_name()
local e = minetest.add_entity(pos,"itemframes:item") local e = minetest.env:add_entity(pos,"itemframes:item")
if node.name == "itemframes:frame" then if node.name == "itemframes:frame" then
local yaw = math.pi*2 - node.param2 * math.pi/2 local yaw = math.pi*2 - node.param2 * math.pi/2
e:setyaw(yaw) e:setyaw(yaw)
@ -83,12 +84,12 @@ local update_item = function(pos, node)
end end
local drop_item = function(pos, node) local drop_item = function(pos, node)
local meta = minetest.get_meta(pos) local meta = minetest.env:get_meta(pos)
if meta:get_string("item") ~= "" then if meta:get_string("item") ~= "" then
if node.name == "itemframes:frame" then if node.name == "itemframes:frame" then
minetest.add_item(pos, meta:get_string("item")) minetest.env:add_item(pos, meta:get_string("item"))
elseif node.name == "itemframes:pedestal" then elseif node.name == "itemframes:pedestal" then
minetest.add_item({x=pos.x,y=pos.y+1,z=pos.z}, meta:get_string("item")) minetest.env:add_item({x=pos.x,y=pos.y+1,z=pos.z}, meta:get_string("item"))
end end
meta:set_string("item","") meta:set_string("item","")
end end
@ -99,23 +100,24 @@ minetest.register_node("itemframes:frame",{
description = "Item frame", description = "Item frame",
drawtype = "nodebox", drawtype = "nodebox",
node_box = { type = "fixed", fixed = {-0.5, -0.5, 7/16, 0.5, 0.5, 0.5} }, node_box = { type = "fixed", fixed = {-0.5, -0.5, 7/16, 0.5, 0.5, 0.5} },
selection_box = { type = "fixed", fixed = {-0.5, -0.5, 7/16, 0.5, 0.5, 0.5} },
tiles = {"itemframes_frame.png"}, tiles = {"itemframes_frame.png"},
inventory_image = "itemframes_frame.png", inventory_image = "itemframes_frame.png",
wield_image = "itemframes_frame.png", wield_image = "itemframes_frame.png",
paramtype = "light", paramtype = "light",
paramtype2 = "facedir", paramtype2 = "facedir",
sunlight_propagates = true, sunlight_propagates = true,
groups = { choppy = 2, dig_immediate = 2}, groups = { choppy=2,dig_immediate=2 },
legacy_wallmounted = true, legacy_wallmounted = true,
sounds = default.node_sound_defaults(), sounds = default.node_sound_defaults(),
after_place_node = function(pos, placer, itemstack) after_place_node = function(pos, placer, itemstack)
local meta = minetest.get_meta(pos) local meta = minetest.env:get_meta(pos)
meta:set_string("owner",placer:get_player_name()) meta:set_string("owner",placer:get_player_name())
meta:set_string("infotext","Item frame (owned by "..placer:get_player_name()..")") meta:set_string("infotext","Item frame (owned by "..placer:get_player_name()..")")
end, end,
on_rightclick = function(pos, node, clicker, itemstack) on_rightclick = function(pos, node, clicker, itemstack)
if not itemstack then return end if not itemstack then return end
local meta = minetest.get_meta(pos) local meta = minetest.env:get_meta(pos)
if clicker:get_player_name() == meta:get_string("owner") then if clicker:get_player_name() == meta:get_string("owner") then
drop_item(pos,node) drop_item(pos,node)
local s = itemstack:take_item() local s = itemstack:take_item()
@ -125,14 +127,14 @@ minetest.register_node("itemframes:frame",{
return itemstack return itemstack
end, end,
on_punch = function(pos,node,puncher) on_punch = function(pos,node,puncher)
local meta = minetest.get_meta(pos) local meta = minetest.env:get_meta(pos)
if puncher:get_player_name() == meta:get_string("owner") then if puncher:get_player_name() == meta:get_string("owner") then
drop_item(pos, node) drop_item(pos, node)
end end
end, end,
can_dig = function(pos,player) can_dig = function(pos,player)
local meta = minetest.get_meta(pos) local meta = minetest.env:get_meta(pos)
return player:get_player_name() == meta:get_string("owner") return player:get_player_name() == meta:get_string("owner")
end, end,
}) })
@ -142,25 +144,24 @@ minetest.register_node("itemframes:pedestal",{
description = "Pedestal", description = "Pedestal",
drawtype = "nodebox", drawtype = "nodebox",
node_box = { type = "fixed", fixed = { node_box = { type = "fixed", fixed = {
{-7/16, -8/16, -7/16, 7/16, -7/16, 7/16}, -- Bottom plate {-7/16, -8/16, -7/16, 7/16, -7/16, 7/16}, -- bottom plate
{-6/16, -7/16, -6/16, 6/16, -6/16, 6/16}, -- Bottom plate (upper) {-6/16, -7/16, -6/16, 6/16, -6/16, 6/16}, -- bottom plate (upper)
{-0.25, -6/16, -0.25, 0.25, 7/16, 0.25}, -- Pillar {-0.25, -6/16, -0.25, 0.25, 11/16, 0.25}, -- pillar
{-7/16, 7/16, -7/16, 7/16, 8/16, 7/16}, -- Top plate {-7/16, 11/16, -7/16, 7/16, 12/16, 7/16}, -- top plate
} }, } },
--selection_box = { type = "fixed", fixed = {-7/16, -0.5, -7/16, 7/16, 12/16, 7/16} },
tiles = {"itemframes_pedestal.png"}, tiles = {"itemframes_pedestal.png"},
paramtype = "light", paramtype = "light",
groups = {cracky = 2}, groups = { cracky=3 },
sounds = default.node_sound_defaults(), sounds = default.node_sound_defaults(),
after_place_node = function(pos, placer, itemstack) after_place_node = function(pos, placer, itemstack)
local meta = minetest.get_meta(pos) local meta = minetest.env:get_meta(pos)
meta:set_string("owner",placer:get_player_name()) meta:set_string("owner",placer:get_player_name())
meta:set_string("infotext","Pedestal (owned by "..placer:get_player_name()..")") meta:set_string("infotext","Pedestal (owned by "..placer:get_player_name()..")")
end, end,
on_rightclick = function(pos, node, clicker, itemstack) on_rightclick = function(pos, node, clicker, itemstack)
if not itemstack then return end if not itemstack then return end
local meta = minetest.get_meta(pos) local meta = minetest.env:get_meta(pos)
if clicker:get_player_name() == meta:get_string("owner") then if clicker:get_player_name() == meta:get_string("owner") then
drop_item(pos,node) drop_item(pos,node)
local s = itemstack:take_item() local s = itemstack:take_item()
@ -169,38 +170,47 @@ minetest.register_node("itemframes:pedestal",{
end end
return itemstack return itemstack
end, end,
on_punch = function(pos,node,puncher) on_punch = function(pos,node,puncher)
local meta = minetest.get_meta(pos) local meta = minetest.env:get_meta(pos)
if puncher:get_player_name() == meta:get_string("owner") then if puncher:get_player_name() == meta:get_string("owner") then
drop_item(pos,node) drop_item(pos,node)
end end
end, end,
can_dig = function(pos,player) can_dig = function(pos,player)
local meta = minetest.get_meta(pos)
local meta = minetest.env:get_meta(pos)
return player:get_player_name() == meta:get_string("owner") return player:get_player_name() == meta:get_string("owner")
end, end,
}) })
minetest.register_craft({ -- automatically restore entities lost from frames/pedestals
output = "itemframes:frame", -- due to /clearobjects or similar
recipe = {
{"default:stick", "default:stick", "default:stick"}, minetest.register_abm({
{"default:stick", "default:paper", "default:stick"}, nodenames = { "itemframes:frame", "itemframes:pedestal" },
{"default:stick", "default:stick", "default:stick"}, interval = 15,
} chance = 1,
action = function(pos, node, active_object_count, active_object_count_wider)
if #minetest.get_objects_inside_radius(pos, 0.5) > 0 then return end
update_item(pos, node)
end
}) })
-- crafts
minetest.register_craft({ minetest.register_craft({
output = "itemframes:pedestal", output = 'itemframes:frame',
recipe = { recipe = {
{"default:stone", "default:stone", "default:stone"}, {'default:stick', 'default:stick', 'default:stick'},
{" ", "default:stone", " "}, {'default:stick', 'default:paper', 'default:stick'},
{"default:stone", "default:stone", "default:stone"}, {'default:stick', 'default:stick', 'default:stick'},
}
})
minetest.register_craft({
output = 'itemframes:pedestal',
recipe = {
{'default:stone', 'default:stone', 'default:stone'},
{'', 'default:stone', ''},
{'default:stone', 'default:stone', 'default:stone'},
} }
}) })
if minetest.setting_getbool("log_mods") then
minetest.log("action", "Carbone: [itemframes] loaded.")
end

Binary file not shown.

After

Width:  |  Height:  |  Size: 104 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 340 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 564 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 286 B