Fix music player

Sounds not included
This commit is contained in:
ShadowNinja 2013-12-16 18:57:01 -05:00
parent ae235ee8f3
commit 0ea1bd1fa2

View File

@ -13,6 +13,8 @@ minetest.register_craft({
} }
}) })
local music_handles = {}
local music_player_formspec = local music_player_formspec =
"invsize[8,9;]".. "invsize[8,9;]"..
"label[0,0;"..S("Music Player").."]".. "label[0,0;"..S("Music Player").."]"..
@ -29,6 +31,11 @@ local music_player_formspec =
"button[6,4;1,2;stop;Stop]".. "button[6,4;1,2;stop;Stop]"..
"label[4,0;Current track --]" "label[4,0;Current track --]"
local function play_track(pos, track)
return minetest.sound_play("technic_track"..track,
{pos = pos, gain = 1.0, loop = true, max_hear_distance = 72,})
end
minetest.register_node("technic:music_player", { minetest.register_node("technic:music_player", {
description = S("Music Player"), description = S("Music Player"),
tiles = {"technic_music_player_top.png", "technic_machine_bottom.png", "technic_music_player_side.png", tiles = {"technic_music_player_top.png", "technic_machine_bottom.png", "technic_music_player_side.png",
@ -44,7 +51,8 @@ minetest.register_node("technic:music_player", {
end, end,
on_receive_fields = function(pos, formanme, fields, sender) on_receive_fields = function(pos, formanme, fields, sender)
local meta = minetest.get_meta(pos) local meta = minetest.get_meta(pos)
local music_handle = meta:get_int("music_handle") local pos_hash = minetest.hash_node_position(pos)
local music_handle = music_handles[pos_hash]
local current_track = meta:get_int("current_track") local current_track = meta:get_int("current_track")
if fields.track1 then current_track = 1 end if fields.track1 then current_track = 1 end
if fields.track2 then current_track = 2 end if fields.track2 then current_track = 2 end
@ -76,6 +84,7 @@ minetest.register_node("technic:music_player", {
if music_handle then if music_handle then
minetest.sound_stop(music_handle) minetest.sound_stop(music_handle)
end end
music_handle = play_track(pos, current_track)
meta:set_int("active", 1) meta:set_int("active", 1)
end end
if fields.stop then if fields.stop then
@ -84,7 +93,7 @@ minetest.register_node("technic:music_player", {
minetest.sound_stop(music_handle) minetest.sound_stop(music_handle)
end end
end end
meta:set_int("music_handle", music_handle) music_handles[pos_hash] = music_handle
end, end,
}) })
@ -99,8 +108,9 @@ minetest.register_abm({
local machine_node = "technic:music_player" local machine_node = "technic:music_player"
local demand = 150 local demand = 150
local music_handle = meta:get_int("music_handle")
local current_track = meta:get_int("current_track") local current_track = meta:get_int("current_track")
local pos_hash = minetest.hash_node_position(pos)
local music_handle = music_handles[pos_hash]
-- Setup meta data if it does not exist. -- Setup meta data if it does not exist.
if not eu_input then if not eu_input then
@ -115,9 +125,6 @@ minetest.register_abm({
if meta:get_int("active") == 0 then if meta:get_int("active") == 0 then
meta:set_string("infotext", S("%s Idle"):format(machine_name)) meta:set_string("infotext", S("%s Idle"):format(machine_name))
meta:set_int("LV_EU_demand", 0) meta:set_int("LV_EU_demand", 0)
if music_handle then
minetest.sound_stop(music_handle)
end
return return
end end
@ -125,13 +132,15 @@ minetest.register_abm({
meta:set_string("infotext", S("%s Unpowered"):format(machine_name)) meta:set_string("infotext", S("%s Unpowered"):format(machine_name))
if music_handle then if music_handle then
minetest.sound_stop(music_handle) minetest.sound_stop(music_handle)
music_handle = nil
end end
elseif eu_input >= demand then elseif eu_input >= demand then
meta:set_string("infotext", S("%s Active"):format(machine_name)) meta:set_string("infotext", S("%s Active"):format(machine_name))
music_handle = minetest.sound_play("technic_track"..current_track, if not music_handle then
{pos = pos, gain = 1.0, loop = true, max_hear_distance = 72,}) music_handle = play_track(pos, current_track)
meta:set_int("music_handle", music_handle)
end end
end
music_handles[pos_hash] = music_handle
meta:set_int("LV_EU_demand", demand) meta:set_int("LV_EU_demand", demand)
end end
}) })