mirror of
https://github.com/mt-mods/homedecor_modpack.git
synced 2025-01-24 15:10:16 +01:00
Mesecons support, fix sounds
Fix sounds so right closing doors sound like they're closing, also add support for mesecons to both doors and gates. TODO: handle already placed doors better
This commit is contained in:
parent
27280bc699
commit
47d98410b5
@ -11,6 +11,23 @@ end
|
|||||||
|
|
||||||
-- doors
|
-- doors
|
||||||
|
|
||||||
|
-- isClosed flag, is 0 or 1 0 = open, 1 = closed
|
||||||
|
function getClosed(pos)
|
||||||
|
local isClosed = minetest.get_meta(pos):get_int('closed')
|
||||||
|
if isClosed == nil then
|
||||||
|
-- doors when unknown, are closed.
|
||||||
|
return 1
|
||||||
|
else
|
||||||
|
-- may be closed or open (0 or 1)
|
||||||
|
return isClosed
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function addDoorNode(pos,def,isClosed)
|
||||||
|
minetest.add_node(pos, def)
|
||||||
|
minetest.get_meta(pos):set_int('closed',isClosed)
|
||||||
|
end
|
||||||
|
|
||||||
local sides = {"left", "right"}
|
local sides = {"left", "right"}
|
||||||
local rsides = {"right", "left"}
|
local rsides = {"right", "left"}
|
||||||
|
|
||||||
@ -95,7 +112,28 @@ for i in ipairs(sides) do
|
|||||||
end,
|
end,
|
||||||
on_rightclick = function(pos, node, clicker)
|
on_rightclick = function(pos, node, clicker)
|
||||||
homedecor_flip_door({x=pos.x, y=pos.y-1, z=pos.z}, node, clicker, doorname, side)
|
homedecor_flip_door({x=pos.x, y=pos.y-1, z=pos.z}, node, clicker, doorname, side)
|
||||||
|
end,
|
||||||
|
|
||||||
|
-- both left and right doors may be used for open or closed doors
|
||||||
|
-- so they have to have both action_on and action_off and just
|
||||||
|
-- check when that action is invoked if to continue
|
||||||
|
|
||||||
|
mesecons = {
|
||||||
|
effector = {
|
||||||
|
action_on = function(pos,node)
|
||||||
|
local isClosed = getClosed(pos)
|
||||||
|
if isClosed==1 then
|
||||||
|
homedecor_flip_door(pos,node,nil,doorname,side,isClosed)
|
||||||
end
|
end
|
||||||
|
end,
|
||||||
|
action_off = function(pos,node)
|
||||||
|
local isClosed = getClosed(pos)
|
||||||
|
if isClosed==0 then
|
||||||
|
homedecor_flip_door(pos,node,nil,doorname,side,isClosed)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
}
|
||||||
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_node("homedecor:door_"..doorname.."_bottom_"..side, {
|
minetest.register_node("homedecor:door_"..doorname.."_bottom_"..side, {
|
||||||
@ -177,7 +215,7 @@ for i in ipairs(gates_list) do
|
|||||||
|
|
||||||
local gate=gates_list[i]
|
local gate=gates_list[i]
|
||||||
|
|
||||||
minetest.register_node("homedecor:gate_"..gate.."_closed", {
|
local def = {
|
||||||
drawtype = "nodebox",
|
drawtype = "nodebox",
|
||||||
description = S(gate_names[i].." Fence Gate"),
|
description = S(gate_names[i].." Fence Gate"),
|
||||||
tiles = {
|
tiles = {
|
||||||
@ -204,40 +242,31 @@ for i in ipairs(gates_list) do
|
|||||||
},
|
},
|
||||||
on_rightclick = function(pos, node, clicker)
|
on_rightclick = function(pos, node, clicker)
|
||||||
homedecor_flip_gate(pos, node, clicker, gate, "closed")
|
homedecor_flip_gate(pos, node, clicker, gate, "closed")
|
||||||
end
|
end,
|
||||||
})
|
mesecons = {
|
||||||
|
effector = {
|
||||||
|
action_on = function(pos,node) homedecor_flip_gate(pos,node,player,gate, "closed") end
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
minetest.register_node("homedecor:gate_"..gate.."_open", {
|
-- gates when placed default to closed, closed.
|
||||||
drawtype = "nodebox",
|
|
||||||
description = S(gate_names[i].." Fence Gate"),
|
minetest.register_node("homedecor:gate_"..gate.."_closed", def)
|
||||||
tiles = {
|
|
||||||
"homedecor_gate_"..gate.."_top.png",
|
-- this is either a terrible idea or a great one
|
||||||
"homedecor_gate_"..gate.."_bottom.png",
|
def.groups.not_in_creative_inventory = 1
|
||||||
"homedecor_gate_"..gate.."_front.png",
|
def.selection_box.fixed = { 0.4, -0.5, -0.5, 0.5, 0.5, 0.5 }
|
||||||
"homedecor_gate_"..gate.."_back.png",
|
def.node_box.fixed = gate_models_open[i]
|
||||||
"homedecor_gate_"..gate.."_left.png",
|
def.drop = "homedecor:gate_"..gate.."_closed"
|
||||||
"homedecor_gate_"..gate.."_right.png"
|
def.on_rightclick = function(pos, node, clicker)
|
||||||
},
|
|
||||||
paramtype = "light",
|
|
||||||
is_ground_content = true,
|
|
||||||
groups = {snappy=3, not_in_creative_inventory=1},
|
|
||||||
sounds = default.node_sound_wood_defaults(),
|
|
||||||
walkable = true,
|
|
||||||
paramtype2 = "facedir",
|
|
||||||
selection_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed ={ 0.4, -0.5, -0.5, 0.5, 0.5, 0.5 }
|
|
||||||
},
|
|
||||||
node_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = gate_models_open[i]
|
|
||||||
},
|
|
||||||
drop = "homedecor:gate_"..gate.."_closed",
|
|
||||||
on_rightclick = function(pos, node, clicker)
|
|
||||||
homedecor_flip_gate(pos, node, clicker, gate, "open")
|
homedecor_flip_gate(pos, node, clicker, gate, "open")
|
||||||
end
|
end
|
||||||
})
|
def.mesecons.effector = {
|
||||||
|
action_off = function(pos,node) homedecor_flip_gate(pos,node,player,gate, "open") end
|
||||||
|
}
|
||||||
|
|
||||||
|
minetest.register_node("homedecor:gate_"..gate.."_open", def)
|
||||||
end
|
end
|
||||||
|
|
||||||
minetest.register_alias("homedecor:fence_barbed_wire_gate_open", "homedecor:gate_barbed_wire_open")
|
minetest.register_alias("homedecor:fence_barbed_wire_gate_open", "homedecor:gate_barbed_wire_open")
|
||||||
@ -289,7 +318,8 @@ function homedecor_place_door(itemstack, placer, pointed_thing, name, side)
|
|||||||
minetest.chat_send_player( placer:get_player_name(), S('Not enough space above that spot to place a door!') )
|
minetest.chat_send_player( placer:get_player_name(), S('Not enough space above that spot to place a door!') )
|
||||||
else
|
else
|
||||||
local fdir = minetest.dir_to_facedir(placer:get_look_dir())
|
local fdir = minetest.dir_to_facedir(placer:get_look_dir())
|
||||||
minetest.add_node(pos1, { name = "homedecor:door_"..name.."_bottom_"..side, param2=fdir})
|
local def = { name = "homedecor:door_"..name.."_bottom_"..side, param2=fdir}
|
||||||
|
addDoorNode(pos1, def, 1)
|
||||||
minetest.add_node(pos2, { name = "homedecor:door_"..name.."_top_"..side, param2=fdir})
|
minetest.add_node(pos2, { name = "homedecor:door_"..name.."_top_"..side, param2=fdir})
|
||||||
if not homedecor_expect_infinite_stacks then
|
if not homedecor_expect_infinite_stacks then
|
||||||
itemstack:take_item()
|
itemstack:take_item()
|
||||||
@ -302,33 +332,41 @@ function homedecor_place_door(itemstack, placer, pointed_thing, name, side)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
function homedecor_flip_door(pos, node, player, name, side)
|
-- to open a door, you switch left for right and subtract from param2, or vice versa right for left
|
||||||
|
-- that is to say open "right" doors become left door nodes, and open left doors right door nodes.
|
||||||
|
-- also adjusting param2 so the node is at 90 degrees.
|
||||||
|
|
||||||
|
function homedecor_flip_door(pos, node, player, name, side, isClosed)
|
||||||
local rside = nil
|
local rside = nil
|
||||||
local nfdir = nil
|
local nfdir = nil
|
||||||
if side == "left" then
|
if side == "left" then
|
||||||
rside = "right"
|
rside = "right"
|
||||||
nfdir=node.param2 - 1
|
nfdir=node.param2 - 1
|
||||||
if nfdir < 0 then nfdir = 3 end
|
if nfdir < 0 then nfdir = 3 end
|
||||||
minetest.sound_play("homedecor_door_open", {
|
|
||||||
pos=pos,
|
|
||||||
max_hear_distance = 5,
|
|
||||||
gain = 2,
|
|
||||||
})
|
|
||||||
else
|
else
|
||||||
rside = "left"
|
rside = "left"
|
||||||
nfdir=node.param2 + 1
|
nfdir=node.param2 + 1
|
||||||
if nfdir > 3 then nfdir = 0 end
|
if nfdir > 3 then nfdir = 0 end
|
||||||
minetest.sound_play("homedecor_door_close", {
|
end
|
||||||
|
local sound;
|
||||||
|
if isClosed then
|
||||||
|
sound = 'close'
|
||||||
|
else
|
||||||
|
sound = 'open'
|
||||||
|
end
|
||||||
|
minetest.sound_play("homedecor_door_"+sound, {
|
||||||
pos=pos,
|
pos=pos,
|
||||||
max_hear_distance = 5,
|
max_hear_distance = 5,
|
||||||
gain = 2,
|
gain = 2,
|
||||||
})
|
})
|
||||||
end
|
-- XXX: does the top half have to remember open/closed too?
|
||||||
minetest.add_node({x=pos.x, y=pos.y+1, z=pos.z}, { name = "homedecor:door_"..name.."_top_"..rside, param2=nfdir})
|
minetest.add_node({x=pos.x, y=pos.y+1, z=pos.z}, { name = "homedecor:door_"..name.."_top_"..rside, param2=nfdir})
|
||||||
minetest.add_node(pos, { name = "homedecor:door_"..name.."_bottom_"..rside, param2=nfdir})
|
|
||||||
|
addDoorNode(pos,{ name = "homedecor:door_"..name.."_bottom_"..rside, param2=nfdir },isClosed)
|
||||||
end
|
end
|
||||||
|
|
||||||
function homedecor_flip_gate(pos, node, player, gate, oc)
|
function homedecor_flip_gate(pos, node, player, gate, oc)
|
||||||
|
local isClosed = getClosed(pos);
|
||||||
minetest.sound_play("homedecor_gate_open_close", {
|
minetest.sound_play("homedecor_gate_open_close", {
|
||||||
pos=pos,
|
pos=pos,
|
||||||
max_hear_distance = 5,
|
max_hear_distance = 5,
|
||||||
@ -337,22 +375,33 @@ function homedecor_flip_gate(pos, node, player, gate, oc)
|
|||||||
|
|
||||||
local fdir = node.param2
|
local fdir = node.param2
|
||||||
|
|
||||||
|
-- since right facing gates use "open" nodes for closed, we need an
|
||||||
|
-- isClosed flag to tell if it's "really" closed.
|
||||||
|
|
||||||
if oc == "closed" then
|
if oc == "closed" then
|
||||||
gateresult = "homedecor:gate_"..gate.."_open"
|
gateresult = "homedecor:gate_"..gate.."_open"
|
||||||
else
|
else
|
||||||
gateresult = "homedecor:gate_"..gate.."_closed"
|
gateresult = "homedecor:gate_"..gate.."_closed"
|
||||||
end
|
end
|
||||||
|
|
||||||
minetest.add_node(pos, { name = gateresult, param2=fdir})
|
local def = {name=gateresult, param2=fdir}
|
||||||
nodeabove = minetest.get_node({x=pos.x, y=pos.y+1, z=pos.z})
|
|
||||||
nodebelow = minetest.get_node({x=pos.x, y=pos.y-1, z=pos.z})
|
addDoorNode(pos, def, isClosed)
|
||||||
|
|
||||||
|
-- the following opens and closes gates below and above in sync with this one
|
||||||
|
-- (without three gate open/close sounds)
|
||||||
|
|
||||||
|
local above = {x=pos.x, y=pos.y+1, z=pos.z}
|
||||||
|
local below = {x=pos.x, y=pos.y-1, z=pos.z}
|
||||||
|
local nodeabove = minetest.get_node(above)
|
||||||
|
local nodebelow = minetest.get_node(below)
|
||||||
|
|
||||||
if string.find(nodeabove.name, "homedecor:gate_"..gate) then
|
if string.find(nodeabove.name, "homedecor:gate_"..gate) then
|
||||||
minetest.add_node({x=pos.x, y=pos.y+1, z=pos.z}, {name=gateresult, param2=fdir} )
|
addDoorNode(above, def, isClosed)
|
||||||
end
|
end
|
||||||
|
|
||||||
if string.find(nodebelow.name, "homedecor:gate_"..gate) then
|
if string.find(nodebelow.name, "homedecor:gate_"..gate) then
|
||||||
minetest.add_node({x=pos.x, y=pos.y-1, z=pos.z}, {name=gateresult, param2=fdir} )
|
addDoorNode(below, def, isClosed)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user