Allow nodeboxes combination by pressing sneak + right-click
This commit is contained in:
parent
a8bd811e7c
commit
a109624b73
17
sitting.lua
17
sitting.lua
@ -1,13 +1,9 @@
|
|||||||
local function node_pointed_face(pointed_thing)
|
local function pointed_face(pointed_thing)
|
||||||
local ay = pointed_thing.above.y
|
return pointed_thing.above.y > pointed_thing.under.y -- Top face pointed.
|
||||||
local uy = pointed_thing.under.y
|
|
||||||
|
|
||||||
if ay > uy then return 1 -- Top face pointed.
|
|
||||||
elseif ay < uy then return 2 end -- Bottom face pointed.
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local function sit(pos, node, clicker, pointed_thing)
|
local function sit(pos, node, clicker, pointed_thing)
|
||||||
if node_pointed_face(pointed_thing) == 2 then return end
|
if not pointed_face(pointed_thing) then return end
|
||||||
local player = clicker:get_player_name()
|
local player = clicker:get_player_name()
|
||||||
local objs = minetest.get_objects_inside_radius(pos, 0.1)
|
local objs = minetest.get_objects_inside_radius(pos, 0.1)
|
||||||
|
|
||||||
@ -102,16 +98,15 @@ xdecor.register("cushion", {
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
if node_pointed_face(pointed_thing) == 1 then
|
if pointed_face(pointed_thing) then
|
||||||
minetest.set_node(pos, {name="xdecor:cushion_block", param2=node.param2})
|
minetest.set_node(pos, {name="xdecor:cushion_block", param2=node.param2})
|
||||||
else
|
|
||||||
minetest.set_node(pointed_thing.above, {name = wield_item, param2 = 20})
|
|
||||||
end
|
end
|
||||||
|
|
||||||
if not minetest.setting_getbool("creative_mode") then
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
itemstack:take_item()
|
itemstack:take_item()
|
||||||
return itemstack
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
return itemstack
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
})
|
})
|
||||||
|
@ -33,7 +33,7 @@ local defs = {
|
|||||||
{"microslab", 8, { 0, 0, 0, 16, 1, 16 }},
|
{"microslab", 8, { 0, 0, 0, 16, 1, 16 }},
|
||||||
{"thinstair", 8, { 0, 7, 0, 16, 1, 8 },
|
{"thinstair", 8, { 0, 7, 0, 16, 1, 8 },
|
||||||
{ 0, 15, 8, 16, 1, 8 }},
|
{ 0, 15, 8, 16, 1, 8 }},
|
||||||
{"cube", 4, { 0, 0, 8, 8, 8, 8 }},
|
{"cube", 4, { 0, 0, 0, 8, 8, 8 }},
|
||||||
{"panel", 4, { 0, 0, 0, 16, 8, 8 }},
|
{"panel", 4, { 0, 0, 0, 16, 8, 8 }},
|
||||||
{"slab", 2, { 0, 0, 0, 16, 8, 16 }},
|
{"slab", 2, { 0, 0, 0, 16, 8, 16 }},
|
||||||
{"doublepanel", 2, { 0, 0, 0, 16, 8, 8 },
|
{"doublepanel", 2, { 0, 0, 0, 16, 8, 8 },
|
||||||
@ -431,7 +431,63 @@ for name in n:gmatch("[%w_]+") do
|
|||||||
groups = groups,
|
groups = groups,
|
||||||
node_box = xdecor.pixelnodebox(16, {d[3], d[4], d[5]}),
|
node_box = xdecor.pixelnodebox(16, {d[3], d[4], d[5]}),
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
on_place = minetest.rotate_node
|
on_place = minetest.rotate_node,
|
||||||
|
on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
|
||||||
|
local pointed_nodebox = minetest.get_node(pos).name:match("(%w+)$")
|
||||||
|
local wield_item = clicker:get_wielded_item():get_name()
|
||||||
|
local player_name = clicker:get_player_name()
|
||||||
|
local newnode = ""
|
||||||
|
|
||||||
|
if minetest.is_protected(pos, player_name) then
|
||||||
|
minetest.record_protection_violation(pos, player_name)
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
local T = {
|
||||||
|
{"nanoslab", nil, 2},
|
||||||
|
{"micropanel", nil, 3},
|
||||||
|
{"cube", nil, 6},
|
||||||
|
{"cube", "panel", 9},
|
||||||
|
{"cube", "slab", 10},
|
||||||
|
{"cube", "outerstair", 11},
|
||||||
|
{"cube", "stair", 12},
|
||||||
|
{"cube", "halfstair", 7},
|
||||||
|
{"cube", "innerstair", nil},
|
||||||
|
{"panel", nil, 7},
|
||||||
|
{"panel", "slab", 11},
|
||||||
|
{"panel", "outerstair", 12},
|
||||||
|
{"panel", "stair", nil},
|
||||||
|
{"halfstair", nil, 11},
|
||||||
|
{"halfstair", "slab", 12},
|
||||||
|
{"slab", nil, nil}
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, x in pairs(T) do
|
||||||
|
if wield_item == mod..":"..name.."_"..x[1] then
|
||||||
|
if not x[2] then x[2] = x[1] end
|
||||||
|
if x[2] == pointed_nodebox then
|
||||||
|
if not x[3] then
|
||||||
|
newnode = mod..":"..name
|
||||||
|
else
|
||||||
|
newnode = mod..":"..name.."_"..defs[x[3]][1]
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if clicker:get_player_control().sneak then
|
||||||
|
if not minetest.registered_nodes[newnode] then return end
|
||||||
|
minetest.set_node(pos, {name=newnode, param2=node.param2})
|
||||||
|
else
|
||||||
|
minetest.item_place_node(ItemStack(wield_item), clicker, pointed_thing)
|
||||||
|
end
|
||||||
|
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
|
itemstack:take_item()
|
||||||
|
end
|
||||||
|
|
||||||
|
return itemstack
|
||||||
|
end
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user