Compare commits

..

No commits in common. "4487d8b147bdd3f6014dd361b925ad46c4a39185" and "b5ce84a5d3c7f1360fd1da1f310cd4d42a23c45c" have entirely different histories.

1 changed files with 53 additions and 38 deletions

View File

@ -28,33 +28,6 @@ local m_rules = {
{x = 0, y = -2, z = 0},
}
local function a_action_on(pos, node)
for _, obj in ipairs(minetest.get_objects_inside_radius(pos, 20)) do
local sound = minetest.sound_play("alarm_" .. node.name:split(":")[2], {
to_player = obj:get_player_name(),
max_hear_distance = 20,
gain = 10.0,
loop = true,
})
local meta = minetest.get_meta(pos)
local sounds = minetest.parse_json(meta:get_string("sounds"))
if not sounds then sounds = {} end
table.insert(sounds, sound)
meta:set_string("sounds", minetest.write_json(sounds))
end
end
local function a_action_off(pos, node)
local meta = minetest.get_meta(pos)
local sounds = minetest.parse_json(meta:get_string("sounds"))
if not sounds then return end
for _, sound in ipairs(sounds) do
minetest.sound_stop(sound)
end
sounds = {}
meta:set_string("sounds", minetest.write_json(sounds))
end
minetest.register_node("alarms:fire", {
description = "Fire alarm",
groups = {snappy = 1},
@ -65,18 +38,32 @@ minetest.register_node("alarms:fire", {
node_box = {
type = "fixed",
fixed = {
{-0.2, -0.2, 0.5, 0.2, 0.2, 0.4},
{-0.2, -0.2, -0.5, 0.2, 0.2, -0.4},
},
},
mesecons = {
effector = {
rules = m_rules,
action_on = a_action_on,
action_off = a_action_off,
action_on = function(pos, node)
for _, obj in ipairs(minetest.get_objects_inside_radius(pos, 20)) do
if not obj:is_player() then return end
local sound = minetest.sound_play("alarm_fire", {
to_player = obj:get_player_name(),
max_hear_distance = 20,
gain = 10.0,
})
end
minetest.get_meta(pos):set_int("sound", sound)
end,
action_off = function(pos, node)
if not minetest.get_meta(pos):get_int("sound") then return end
minetest.sound_stop(minetest.get_meta(pos):get_int("sound"))
end,
},
},
on_destruct = function(pos)
a_action_off(pos, {name = "alarms:fire"})
if not minetest.get_meta(pos):get_int("sound") then return end
minetest.sound_stop(minetest.get_meta(pos):get_int("sound"))
end,
})
minetest.register_node("alarms:nuclear", {
@ -95,12 +82,26 @@ minetest.register_node("alarms:nuclear", {
mesecons = {
effector = {
rules = m_rules,
action_on = a_action_on,
action_off = a_action_off,
action_on = function(pos, node)
for _, obj in ipairs(minetest.get_objects_inside_radius(pos, 20)) do
if not obj:is_player() then return end
local sound = minetest.sound_play("alarm_nuclear", {
to_player = obj:get_player_name(),
max_hear_distance = 20,
gain = 10.0,
})
end
minetest.get_meta(pos):set_int("sound", sound)
end,
action_off = function(pos, node)
if not minetest.get_meta(pos):get_int("sound") then return end
minetest.sound_stop(minetest.get_meta(pos):get_int("sound"))
end,
},
},
on_destruct = function(pos)
a_action_off(pos, {name = "alarms:nuclear"})
if not minetest.get_meta(pos):get_int("sound") then return end
minetest.sound_stop(minetest.get_meta(pos):get_int("sound"))
end,
})
minetest.register_node("alarms:intruder", {
@ -113,17 +114,31 @@ minetest.register_node("alarms:intruder", {
node_box = {
type = "fixed",
fixed = {
{-0.2, -0.2, 0.5, 0.2, 0.2, 0.4},
{-0.2, -0.2, -0.5, 0.2, 0.2, -0.4},
},
},
mesecons = {
effector = {
rules = m_rules,
action_on = a_action_on,
action_off = a_action_off,
action_on = function(pos, node)
for _, obj in ipairs(minetest.get_objects_inside_radius(pos, 20)) do
if not obj:is_player() then return end
local sound = minetest.sound_play("alarm_intruder", {
to_player = obj:get_player_name(),
max_hear_distance = 20,
gain = 10.0,
})
end
minetest.get_meta(pos):set_int("sound", sound)
end,
action_off = function(pos, node)
if not minetest.get_meta(pos):get_int("sound") then return end
minetest.sound_stop(minetest.get_meta(pos):get_int("sound"))
end,
},
},
on_destruct = function(pos)
a_action_off(pos, {name = "alarms:nuclear"})
if not minetest.get_meta(pos):get_int("sound") then return end
minetest.sound_stop(minetest.get_meta(pos):get_int("sound"))
end,
})