forked from Mirrorlandia_minetest/mesecons
Properly handle rotation of buttons / levers
Buttons and levers can now also be pointed upwards / downwards which will make them connect to corresponding up / down receivers. You will need to use the screwdriver for this. Receivers cannot be rotated using the screwdriver anymore.
This commit is contained in:
parent
79edbed8d7
commit
1bd936ad8c
@ -41,12 +41,19 @@ mesecon.rules.alldirs =
|
|||||||
|
|
||||||
mesecon.rules.buttonlike_get = function(node)
|
mesecon.rules.buttonlike_get = function(node)
|
||||||
local rules = mesecon.rules.buttonlike
|
local rules = mesecon.rules.buttonlike
|
||||||
if node.param2 == 2 then
|
local dir = minetest.facedir_to_dir(node.param2)
|
||||||
|
if dir.x == 1 then
|
||||||
|
-- No action needed
|
||||||
|
elseif dir.z == -1 then
|
||||||
rules=mesecon.rotate_rules_left(rules)
|
rules=mesecon.rotate_rules_left(rules)
|
||||||
elseif node.param2 == 3 then
|
elseif dir.x == -1 then
|
||||||
rules=mesecon.rotate_rules_right(mesecon.rotate_rules_right(rules))
|
rules=mesecon.rotate_rules_right(mesecon.rotate_rules_right(rules))
|
||||||
elseif node.param2 == 0 then
|
elseif dir.z == 1 then
|
||||||
rules=mesecon.rotate_rules_right(rules)
|
rules=mesecon.rotate_rules_right(rules)
|
||||||
|
elseif dir.y == -1 then
|
||||||
|
rules=mesecon.rotate_rules_up(rules)
|
||||||
|
elseif dir.y == 1 then
|
||||||
|
rules=mesecon.rotate_rules_down(rules)
|
||||||
end
|
end
|
||||||
return rules
|
return rules
|
||||||
end
|
end
|
||||||
|
@ -26,6 +26,7 @@ minetest.register_node("mesecons_button:button_off", {
|
|||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
legacy_wallmounted = true,
|
legacy_wallmounted = true,
|
||||||
walkable = false,
|
walkable = false,
|
||||||
|
on_rotate = mesecon.buttonlike_onrotate,
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
selection_box = {
|
selection_box = {
|
||||||
type = "fixed",
|
type = "fixed",
|
||||||
@ -67,6 +68,7 @@ minetest.register_node("mesecons_button:button_on", {
|
|||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
legacy_wallmounted = true,
|
legacy_wallmounted = true,
|
||||||
walkable = false,
|
walkable = false,
|
||||||
|
on_rotate = false,
|
||||||
light_source = default.LIGHT_MAX-7,
|
light_source = default.LIGHT_MAX-7,
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
selection_box = {
|
selection_box = {
|
||||||
|
@ -1,10 +1,30 @@
|
|||||||
rcvboxes = {
|
local rcvboxes = {
|
||||||
{ -3/16, -3/16, -8/16 , 3/16, 3/16 , -13/32 }, -- the smaller bump
|
{ -3/16, -3/16, -8/16 , 3/16, 3/16 , -13/32 }, -- the smaller bump
|
||||||
{ -1/32, -1/32, -3/2 , 1/32, 1/32 , -1/2 }, -- the wire through the block
|
{ -1/32, -1/32, -3/2 , 1/32, 1/32 , -1/2 }, -- the wire through the block
|
||||||
{ -2/32, -1/2 , -.5 , 2/32, 0 , -.5002+3/32 }, -- the vertical wire bit
|
{ -2/32, -1/2 , -.5 , 2/32, 0 , -.5002+3/32 }, -- the vertical wire bit
|
||||||
{ -2/32, -1/2 , -7/16+0.002 , 2/32, -14/32, 16/32+0.001 } -- the horizontal wire
|
{ -2/32, -1/2 , -7/16+0.002 , 2/32, -14/32, 16/32+0.001 } -- the horizontal wire
|
||||||
}
|
}
|
||||||
|
|
||||||
|
local down_rcvboxes = {
|
||||||
|
{-6/16, -8/16, -6/16, 6/16, -7/16, 6/16}, -- Top plate
|
||||||
|
{-2/16, -6/16, -2/16, 2/16, -7/16, 2/16}, -- Bump
|
||||||
|
{-1/16, -8/16, -1/16, 1/16, -24/16, 1/16}, -- Wire through the block
|
||||||
|
{-1/16, -8/16, 6/16, 1/16, -7/16, 8/16}, -- Plate extension (North)
|
||||||
|
{-1/16, -8/16, -6/16, 1/16, -7/16, -8/16}, -- Plate extension (South)
|
||||||
|
{-8/16, -8/16, 1/16, -6/16, -7/16, -1/16}, -- Plate extension (West)
|
||||||
|
{6/16, -8/16, 1/16, 8/16, -7/16, -1/16}, -- Plate extension (East)
|
||||||
|
}
|
||||||
|
|
||||||
|
local up_rcvboxes = {
|
||||||
|
{-6/16, -8/16, -6/16, 6/16, -7/16, 6/16}, -- Top plate
|
||||||
|
{-2/16, -6/16, -2/16, 2/16, -7/16, 2/16}, -- Bump
|
||||||
|
{-1/16, -6/16, -1/16, 1/16, 24/16, 1/16}, -- Wire through the block
|
||||||
|
{-1/16, -8/16, 6/16, 1/16, -7/16, 8/16}, -- Plate extension (North)
|
||||||
|
{-1/16, -8/16, -6/16, 1/16, -7/16, -8/16}, -- Plate extension (South)
|
||||||
|
{-8/16, -8/16, 1/16, -6/16, -7/16, -1/16}, -- Plate extension (West)
|
||||||
|
{6/16, -8/16, 1/16, 8/16, -7/16, -1/16}, -- Plate extension (East)
|
||||||
|
}
|
||||||
|
|
||||||
local receiver_get_rules = function (node)
|
local receiver_get_rules = function (node)
|
||||||
local rules = { {x = 1, y = 0, z = 0},
|
local rules = { {x = 1, y = 0, z = 0},
|
||||||
{x = -2, y = 0, z = 0}}
|
{x = -2, y = 0, z = 0}}
|
||||||
@ -18,20 +38,13 @@ local receiver_get_rules = function (node)
|
|||||||
return rules
|
return rules
|
||||||
end
|
end
|
||||||
|
|
||||||
minetest.register_node("mesecons_receiver:receiver_on", {
|
mesecon.register_node("mesecons_receiver:receiver", {
|
||||||
drawtype = "nodebox",
|
drawtype = "nodebox",
|
||||||
tiles = {
|
|
||||||
"receiver_top_on.png",
|
|
||||||
"receiver_bottom_on.png",
|
|
||||||
"receiver_lr_on.png",
|
|
||||||
"receiver_lr_on.png",
|
|
||||||
"receiver_fb_on.png",
|
|
||||||
"receiver_fb_on.png",
|
|
||||||
},
|
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
walkable = false,
|
walkable = false,
|
||||||
|
on_rotate = false,
|
||||||
selection_box = {
|
selection_box = {
|
||||||
type = "fixed",
|
type = "fixed",
|
||||||
fixed = { -3/16, -8/16, -8/16, 3/16, 3/16, 8/16 }
|
fixed = { -3/16, -8/16, -8/16, 3/16, 3/16, 8/16 }
|
||||||
@ -42,16 +55,7 @@ minetest.register_node("mesecons_receiver:receiver_on", {
|
|||||||
},
|
},
|
||||||
groups = {dig_immediate = 3, not_in_creative_inventory = 1},
|
groups = {dig_immediate = 3, not_in_creative_inventory = 1},
|
||||||
drop = "mesecons:wire_00000000_off",
|
drop = "mesecons:wire_00000000_off",
|
||||||
mesecons = {conductor = {
|
}, {
|
||||||
state = mesecon.state.on,
|
|
||||||
rules = receiver_get_rules,
|
|
||||||
offstate = "mesecons_receiver:receiver_off"
|
|
||||||
}}
|
|
||||||
})
|
|
||||||
|
|
||||||
minetest.register_node("mesecons_receiver:receiver_off", {
|
|
||||||
drawtype = "nodebox",
|
|
||||||
description = "You hacker you",
|
|
||||||
tiles = {
|
tiles = {
|
||||||
"receiver_top_off.png",
|
"receiver_top_off.png",
|
||||||
"receiver_bottom_off.png",
|
"receiver_bottom_off.png",
|
||||||
@ -60,51 +64,147 @@ minetest.register_node("mesecons_receiver:receiver_off", {
|
|||||||
"receiver_fb_off.png",
|
"receiver_fb_off.png",
|
||||||
"receiver_fb_off.png",
|
"receiver_fb_off.png",
|
||||||
},
|
},
|
||||||
paramtype = "light",
|
|
||||||
paramtype2 = "facedir",
|
|
||||||
sunlight_propagates = true,
|
|
||||||
walkable = false,
|
|
||||||
selection_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = { -3/16, -8/16, -8/16, 3/16, 3/16, 8/16 }
|
|
||||||
},
|
|
||||||
node_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = rcvboxes
|
|
||||||
},
|
|
||||||
groups = {dig_immediate = 3, not_in_creative_inventory = 1},
|
|
||||||
drop = "mesecons:wire_00000000_off",
|
|
||||||
mesecons = {conductor = {
|
mesecons = {conductor = {
|
||||||
state = mesecon.state.off,
|
state = mesecon.state.off,
|
||||||
rules = receiver_get_rules,
|
rules = receiver_get_rules,
|
||||||
onstate = "mesecons_receiver:receiver_on"
|
onstate = "mesecons_receiver:receiver_on"
|
||||||
}}
|
}}
|
||||||
|
}, {
|
||||||
|
tiles = {
|
||||||
|
"receiver_top_on.png",
|
||||||
|
"receiver_bottom_on.png",
|
||||||
|
"receiver_lr_on.png",
|
||||||
|
"receiver_lr_on.png",
|
||||||
|
"receiver_fb_on.png",
|
||||||
|
"receiver_fb_on.png",
|
||||||
|
},
|
||||||
|
mesecons = {conductor = {
|
||||||
|
state = mesecon.state.on,
|
||||||
|
rules = receiver_get_rules,
|
||||||
|
offstate = "mesecons_receiver:receiver_off"
|
||||||
|
}}
|
||||||
|
})
|
||||||
|
|
||||||
|
mesecon.register_node("mesecons_receiver:receiver_up", {
|
||||||
|
drawtype = "nodebox",
|
||||||
|
paramtype = "light",
|
||||||
|
paramtype2 = "facedir",
|
||||||
|
sunlight_propagates = true,
|
||||||
|
walkable = false,
|
||||||
|
on_rotate = false,
|
||||||
|
selection_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = up_rcvboxes
|
||||||
|
},
|
||||||
|
node_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = up_rcvboxes
|
||||||
|
},
|
||||||
|
groups = {dig_immediate = 3, not_in_creative_inventory = 1},
|
||||||
|
drop = "mesecons:wire_00000000_off",
|
||||||
|
}, {
|
||||||
|
tiles = {"mesecons_wire_off.png"},
|
||||||
|
mesecons = {conductor = {
|
||||||
|
state = mesecon.state.off,
|
||||||
|
rules = {{x=1, y=0, z=0},
|
||||||
|
{x=-1, y=0, z=0},
|
||||||
|
{x=0, y=0, z=1},
|
||||||
|
{x=0, y=0, z=-1},
|
||||||
|
{x=0, y=1, z=0},
|
||||||
|
{x=0, y=2, z=0}},
|
||||||
|
onstate = "mesecons_receiver:receiver_up_on"
|
||||||
|
}}
|
||||||
|
}, {
|
||||||
|
tiles = {"mesecons_wire_on.png"},
|
||||||
|
mesecons = {conductor = {
|
||||||
|
state = mesecon.state.on,
|
||||||
|
rules = {{x=1, y=0, z=0},
|
||||||
|
{x=-1, y=0, z=0},
|
||||||
|
{x=0, y=0, z=1},
|
||||||
|
{x=0, y=0, z=-1},
|
||||||
|
{x=0, y=1, z=0},
|
||||||
|
{x=0, y=2, z=0}},
|
||||||
|
offstate = "mesecons_receiver:receiver_up_off"
|
||||||
|
}}
|
||||||
|
})
|
||||||
|
|
||||||
|
mesecon.register_node("mesecons_receiver:receiver_down", {
|
||||||
|
drawtype = "nodebox",
|
||||||
|
paramtype = "light",
|
||||||
|
paramtype2 = "facedir",
|
||||||
|
sunlight_propagates = true,
|
||||||
|
walkable = false,
|
||||||
|
on_rotate = false,
|
||||||
|
selection_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = down_rcvboxes
|
||||||
|
},
|
||||||
|
node_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = down_rcvboxes
|
||||||
|
},
|
||||||
|
groups = {dig_immediate = 3, not_in_creative_inventory = 1},
|
||||||
|
drop = "mesecons:wire_00000000_off",
|
||||||
|
}, {
|
||||||
|
tiles = {"mesecons_wire_off.png"},
|
||||||
|
mesecons = {conductor = {
|
||||||
|
state = mesecon.state.off,
|
||||||
|
rules = {{x=1,y=0, z=0},
|
||||||
|
{x=-1,y=0, z=0},
|
||||||
|
{x=0, y=0, z=1},
|
||||||
|
{x=0, y=0, z=-1},
|
||||||
|
{x=0, y=-2,z=0}},
|
||||||
|
onstate = "mesecons_receiver:receiver_down_on"
|
||||||
|
}}
|
||||||
|
}, {
|
||||||
|
tiles = {"mesecons_wire_on.png"},
|
||||||
|
mesecons = {conductor = {
|
||||||
|
state = mesecon.state.on,
|
||||||
|
rules = {{x=1,y=0, z=0},
|
||||||
|
{x=-1,y=0, z=0},
|
||||||
|
{x=0, y=0, z=1},
|
||||||
|
{x=0, y=0, z=-1},
|
||||||
|
{x=0, y=-2,z=0}},
|
||||||
|
offstate = "mesecons_receiver:receiver_down_off"
|
||||||
|
}}
|
||||||
})
|
})
|
||||||
|
|
||||||
function mesecon.receiver_get_pos_from_rcpt(pos, param2)
|
function mesecon.receiver_get_pos_from_rcpt(pos, param2)
|
||||||
local rules = {{x = 2, y = 0, z = 0}}
|
local rules = {{x = 2, y = 0, z = 0}}
|
||||||
if param2 == nil then param2 = minetest.get_node(pos).param2 end
|
if param2 == nil then param2 = minetest.get_node(pos).param2 end
|
||||||
if param2 == 2 then
|
local rcvtype = "mesecons_receiver:receiver_off"
|
||||||
|
local dir = minetest.facedir_to_dir(param2)
|
||||||
|
|
||||||
|
if dir.x == 1 then
|
||||||
|
-- No action needed
|
||||||
|
elseif dir.z == -1 then
|
||||||
rules = mesecon.rotate_rules_left(rules)
|
rules = mesecon.rotate_rules_left(rules)
|
||||||
elseif param2 == 3 then
|
elseif dir.x == -1 then
|
||||||
rules = mesecon.rotate_rules_right(mesecon.rotate_rules_right(rules))
|
rules = mesecon.rotate_rules_right(mesecon.rotate_rules_right(rules))
|
||||||
elseif param2 == 0 then
|
elseif dir.z == 1 then
|
||||||
rules = mesecon.rotate_rules_right(rules)
|
rules = mesecon.rotate_rules_right(rules)
|
||||||
|
elseif dir.y == -1 then
|
||||||
|
rules = mesecon.rotate_rules_up(rules)
|
||||||
|
rcvtype = "mesecons_receiver:receiver_up_off"
|
||||||
|
elseif dir.y == 1 then
|
||||||
|
rules = mesecon.rotate_rules_down(rules)
|
||||||
|
rcvtype = "mesecons_receiver:receiver_down_off"
|
||||||
end
|
end
|
||||||
local np = { x = pos.x + rules[1].x,
|
local np = { x = pos.x + rules[1].x,
|
||||||
y = pos.y + rules[1].y,
|
y = pos.y + rules[1].y,
|
||||||
z = pos.z + rules[1].z}
|
z = pos.z + rules[1].z}
|
||||||
return np
|
return np, rcvtype
|
||||||
end
|
end
|
||||||
|
|
||||||
function mesecon.receiver_place(rcpt_pos)
|
function mesecon.receiver_place(rcpt_pos)
|
||||||
local node = minetest.get_node(rcpt_pos)
|
local node = minetest.get_node(rcpt_pos)
|
||||||
local pos = mesecon.receiver_get_pos_from_rcpt(rcpt_pos, node.param2)
|
local pos, rcvtype = mesecon.receiver_get_pos_from_rcpt(rcpt_pos, node.param2)
|
||||||
local nn = minetest.get_node(pos)
|
local nn = minetest.get_node(pos)
|
||||||
|
local param2 = minetest.dir_to_facedir(minetest.facedir_to_dir(node.param2))
|
||||||
|
|
||||||
if string.find(nn.name, "mesecons:wire_") ~= nil then
|
if string.find(nn.name, "mesecons:wire_") ~= nil then
|
||||||
minetest.dig_node(pos)
|
minetest.dig_node(pos)
|
||||||
minetest.set_node(pos, {name = "mesecons_receiver:receiver_off", param2 = node.param2})
|
minetest.set_node(pos, {name = rcvtype, param2 = param2})
|
||||||
mesecon.on_placenode(pos, nn)
|
mesecon.on_placenode(pos, nn)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -137,7 +237,9 @@ minetest.register_on_placenode(function (pos, node)
|
|||||||
local rules = { {x = 2, y = 0, z = 0},
|
local rules = { {x = 2, y = 0, z = 0},
|
||||||
{x =-2, y = 0, z = 0},
|
{x =-2, y = 0, z = 0},
|
||||||
{x = 0, y = 0, z = 2},
|
{x = 0, y = 0, z = 2},
|
||||||
{x = 0, y = 0, z =-2}}
|
{x = 0, y = 0, z =-2},
|
||||||
|
{x = 0, y = 2, z = 0},
|
||||||
|
{x = 0, y = -2, z = 0}}
|
||||||
local i = 1
|
local i = 1
|
||||||
while rules[i] ~= nil do
|
while rules[i] ~= nil do
|
||||||
local np = { x = pos.x + rules[i].x,
|
local np = { x = pos.x + rules[i].x,
|
||||||
@ -150,3 +252,8 @@ minetest.register_on_placenode(function (pos, node)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
|
|
||||||
|
function mesecon.buttonlike_onrotate(pos, node)
|
||||||
|
minetest.after(0, mesecon.receiver_remove, pos, node)
|
||||||
|
minetest.after(0, mesecon.receiver_place, pos)
|
||||||
|
end
|
||||||
|
@ -31,6 +31,7 @@ mesecon.register_node("mesecons_walllever:wall_lever", {
|
|||||||
"jeija_wall_lever_back_edges.png"
|
"jeija_wall_lever_back_edges.png"
|
||||||
},
|
},
|
||||||
mesh="jeija_wall_lever_off.obj",
|
mesh="jeija_wall_lever_off.obj",
|
||||||
|
on_rotate = mesecon.buttonlike_onrotate,
|
||||||
mesecons = {receptor = {
|
mesecons = {receptor = {
|
||||||
rules = mesecon.rules.buttonlike_get,
|
rules = mesecon.rules.buttonlike_get,
|
||||||
state = mesecon.state.off
|
state = mesecon.state.off
|
||||||
@ -44,6 +45,7 @@ mesecon.register_node("mesecons_walllever:wall_lever", {
|
|||||||
"jeija_wall_lever_back_edges.png"
|
"jeija_wall_lever_back_edges.png"
|
||||||
},
|
},
|
||||||
mesh="jeija_wall_lever_on.obj",
|
mesh="jeija_wall_lever_on.obj",
|
||||||
|
on_rotate = false,
|
||||||
mesecons = {receptor = {
|
mesecons = {receptor = {
|
||||||
rules = mesecon.rules.buttonlike_get,
|
rules = mesecon.rules.buttonlike_get,
|
||||||
state = mesecon.state.on
|
state = mesecon.state.on
|
||||||
|
Loading…
Reference in New Issue
Block a user