Allow nodeboxes combination by pressing sneak + right-click

This commit is contained in:
kilbith 2016-01-26 00:07:42 +01:00
parent a8bd811e7c
commit a109624b73
2 changed files with 65 additions and 14 deletions

View File

@ -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
}) })

View File

@ -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