mirror of
https://github.com/sys4-fr/server-nalc.git
synced 2025-01-12 02:50:25 +01:00
Changed homedecor's itemframe with fork overriden during merge..
This commit is contained in:
parent
59037e6a7c
commit
edc7d6d23a
@ -1,4 +1,7 @@
|
|||||||
|
-- See README.txt for licensing and other information.
|
||||||
|
|
||||||
local tmp = {}
|
local tmp = {}
|
||||||
|
itemframes = {}
|
||||||
|
|
||||||
minetest.register_entity("itemframes:item",{
|
minetest.register_entity("itemframes:item",{
|
||||||
hp_max = 1,
|
hp_max = 1,
|
||||||
@ -25,7 +28,7 @@ minetest.register_entity("itemframes:item",{
|
|||||||
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:frame" then
|
||||||
self.object:set_properties({automatic_rotate=1})
|
self.object:set_properties({automatic_rotate=1})
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
@ -36,20 +39,17 @@ minetest.register_entity("itemframes:item",{
|
|||||||
return ""
|
return ""
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
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, .5)
|
objs = minetest.env:get_objects_inside_radius(pos, .5)
|
||||||
elseif node.name == "itemframes:pedestal" then
|
elseif minetest.get_item_group(node.name, "group:pedestal") then
|
||||||
objs = minetest.get_objects_inside_radius({x=pos.x,y=pos.y+1,z=pos.z}, .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
|
||||||
@ -59,10 +59,9 @@ local remove_item = function(pos, node)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
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]
|
||||||
@ -70,26 +69,25 @@ local update_item = function(pos, node)
|
|||||||
pos.x = pos.x + posad.x*6.5/16
|
pos.x = pos.x + posad.x*6.5/16
|
||||||
pos.y = pos.y + posad.y*6.5/16
|
pos.y = pos.y + posad.y*6.5/16
|
||||||
pos.z = pos.z + posad.z*6.5/16
|
pos.z = pos.z + posad.z*6.5/16
|
||||||
elseif node.name == "itemframes:pedestal" then
|
elseif minetest.get_item_group(node.name, "group:pedestal") then
|
||||||
pos.y = pos.y + 12/16+.33
|
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)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
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 minetest.get_item_group(node.name, "group: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
|
||||||
@ -111,13 +109,13 @@ minetest.register_node("itemframes:frame",{
|
|||||||
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: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()
|
||||||
@ -127,42 +125,48 @@ 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.env:get_meta(pos)
|
||||||
local meta = minetest.get_meta(pos)
|
|
||||||
return player:get_player_name() == meta:get_string("owner")
|
return player:get_player_name() == meta:get_string("owner")
|
||||||
end,
|
end,
|
||||||
after_destruct = remove_item,
|
|
||||||
})
|
})
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
output = 'itemframes:frame',
|
||||||
|
recipe = {
|
||||||
|
{'group:stick', 'group:stick', 'group:stick'},
|
||||||
|
{'group:stick', 'default:paper', 'group:stick'},
|
||||||
|
{'group:stick', 'group:stick', 'group:stick'},
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
minetest.register_node("itemframes:pedestal",{
|
function itemframes.register_pedestal(subname, recipeitem, groups, images, description, sounds)
|
||||||
description = "Pedestal",
|
minetest.register_node("itemframes:pedestal_" .. subname, {
|
||||||
|
description = description,
|
||||||
drawtype = "nodebox",
|
drawtype = "nodebox",
|
||||||
|
tiles = images,
|
||||||
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, 11/16, 0.25}, -- pillar
|
{-0.25, -6/16, -0.25, 0.25, 11/16, 0.25}, -- pillar
|
||||||
{-7/16, 11/16, -7/16, 7/16, 12/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} },
|
groups = groups,
|
||||||
tiles = {"itemframes_pedestal.png"},
|
sounds = sounds,
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
groups = { cracky=3 },
|
|
||||||
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()
|
||||||
@ -172,24 +176,91 @@ minetest.register_node("itemframes:pedestal",{
|
|||||||
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.env:get_meta(pos)
|
||||||
local meta = minetest.get_meta(pos)
|
|
||||||
return player:get_player_name() == meta:get_string("owner")
|
return player:get_player_name() == meta:get_string("owner")
|
||||||
end,
|
end,
|
||||||
after_destruct = remove_item,
|
|
||||||
})
|
})
|
||||||
|
|
||||||
-- automatically restore entities lost from frames/pedestals
|
minetest.register_craft({
|
||||||
-- due to /clearobjects or similar
|
output = 'itemframes:pedestal_' .. subname,
|
||||||
|
recipe = {
|
||||||
|
{recipeitem, recipeitem, recipeitem},
|
||||||
|
{'', recipeitem, ''},
|
||||||
|
{recipeitem, recipeitem, recipeitem},
|
||||||
|
}
|
||||||
|
})
|
||||||
|
end
|
||||||
|
|
||||||
|
itemframes.register_pedestal("wood", "default:wood",
|
||||||
|
{snappy=2,choppy=2,oddly_breakable_by_hand=2,flammable=3,pedestal=1},
|
||||||
|
{"default_wood.png"},
|
||||||
|
"Wooden Pedestal",
|
||||||
|
default.node_sound_wood_defaults()
|
||||||
|
)
|
||||||
|
itemframes.register_pedestal("stone", "default:stone",
|
||||||
|
{cracky=3,pedestal=1},
|
||||||
|
{"default_stone.png"},
|
||||||
|
"Stone Pedestal",
|
||||||
|
default.node_sound_stone_defaults()
|
||||||
|
)
|
||||||
|
itemframes.register_pedestal("cobble", "default:cobble",
|
||||||
|
{cracky=3,pedestal=1},
|
||||||
|
{"default_cobble.png"},
|
||||||
|
"Cobblestone Pedestal",
|
||||||
|
default.node_sound_stone_defaults()
|
||||||
|
)
|
||||||
|
itemframes.register_pedestal("desert_stone", "default:desert_stone",
|
||||||
|
{cracky=3,pedestal=1},
|
||||||
|
{"default_desert_stone.png"},
|
||||||
|
"Desert Stone Pedestal",
|
||||||
|
default.node_sound_stone_defaults()
|
||||||
|
)
|
||||||
|
itemframes.register_pedestal("desert_cobble", "default:desert_cobble",
|
||||||
|
{cracky=3,pedestal=1},
|
||||||
|
{"default_desert_cobble.png"},
|
||||||
|
"Desert Cobblestone Pedestal",
|
||||||
|
default.node_sound_stone_defaults()
|
||||||
|
)
|
||||||
|
itemframes.register_pedestal("desert_stonebrick", "default:desert_stonebrick",
|
||||||
|
{cracky=3,pedestal=1},
|
||||||
|
{"default_desert_stone_brick.png"},
|
||||||
|
"Desert Stone Brick Pedestal",
|
||||||
|
default.node_sound_stone_defaults()
|
||||||
|
)
|
||||||
|
itemframes.register_pedestal("brick", "default:brick",
|
||||||
|
{cracky=3,pedestal=1},
|
||||||
|
{"default_brick.png"},
|
||||||
|
"Brick Pedestal",
|
||||||
|
default.node_sound_stone_defaults()
|
||||||
|
)
|
||||||
|
itemframes.register_pedestal("sandstone", "default:sandstone",
|
||||||
|
{crumbly=2,cracky=2,pedestal=1},
|
||||||
|
{"default_sandstone.png"},
|
||||||
|
"Sandstone Pedestal",
|
||||||
|
default.node_sound_stone_defaults()
|
||||||
|
)
|
||||||
|
itemframes.register_pedestal("sandstonebrick", "default:sandstonebrick",
|
||||||
|
{crumbly=2,cracky=2,pedestal=1},
|
||||||
|
{"default_sandstone_brick.png"},
|
||||||
|
"Sandstone Brick Pedestal",
|
||||||
|
default.node_sound_stone_defaults()
|
||||||
|
)
|
||||||
|
itemframes.register_pedestal("stonebrick", "default:stonebrick",
|
||||||
|
{cracky=3,pedestal=1},
|
||||||
|
{"default_stone_brick.png"},
|
||||||
|
"Stone Brick Pedestal",
|
||||||
|
default.node_sound_stone_defaults()
|
||||||
|
)
|
||||||
|
-- automatically restore entities lost from
|
||||||
|
-- frames/pedestals due to /clearobjects or similar
|
||||||
minetest.register_abm({
|
minetest.register_abm({
|
||||||
nodenames = { "itemframes:frame", "itemframes:pedestal" },
|
nodenames = {"itemframes:frame", "group:pedestal"},
|
||||||
interval = 15,
|
interval = 15,
|
||||||
chance = 1,
|
chance = 1,
|
||||||
action = function(pos, node, active_object_count, active_object_count_wider)
|
action = function(pos, node, active_object_count, active_object_count_wider)
|
||||||
@ -198,21 +269,7 @@ minetest.register_abm({
|
|||||||
end
|
end
|
||||||
})
|
})
|
||||||
|
|
||||||
-- crafts
|
-- homedecor/itemframes -> itemframes::stone
|
||||||
|
-- minetest.register_alias("itemframes:pedestal","itemframes:pedestal_stone")
|
||||||
minetest.register_craft({
|
-- itemframes::stone -> homedecor/itemframes
|
||||||
output = 'itemframes:frame',
|
minetest.register_alias("itemframes:pedestal_stone","itemframes:pedestal")
|
||||||
recipe = {
|
|
||||||
{'default:stick', 'default:stick', 'default:stick'},
|
|
||||||
{'default:stick', 'default:paper', 'default:stick'},
|
|
||||||
{'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'},
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
Loading…
Reference in New Issue
Block a user