summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorZefram <zefram@fysh.org>2014-08-14 15:29:50 +0100
committerZefram <zefram@fysh.org>2014-08-15 12:25:46 +0100
commit6cc471e986c694298716c257528c653395bd757d (patch)
treee9b2ea1d15695bd7746372f28b1910e23901515c
parent1d0687556a52891aeadc0e8d9a58e44c53cb826b (diff)
Simplify music player interface
Having a track selected now implies playing it, rather than playing/stopped being a hidden state separate from track selection.
-rw-r--r--technic/locale/de.txt1
-rw-r--r--technic/locale/es.txt1
-rw-r--r--technic/locale/it.txt1
-rw-r--r--technic/locale/template.txt1
-rw-r--r--technic/machines/LV/music_player.lua87
5 files changed, 42 insertions, 49 deletions
diff --git a/technic/locale/de.txt b/technic/locale/de.txt
index 6f9f8d2..31ea107 100644
--- a/technic/locale/de.txt
+++ b/technic/locale/de.txt
@@ -113,6 +113,7 @@ Production at %d%% = Produktion bei %d%%
Choose Milling Program: = Waehle ein Fraesprogramm:
Slim Elements half / normal height: = Schmale Elemente von halber / normaler Hoehe:
Current track %s = Aktueller Titel %s
+Stopped =
Keeping %d/%d map blocks loaded =
## CNC
diff --git a/technic/locale/es.txt b/technic/locale/es.txt
index db817f8..80a5736 100644
--- a/technic/locale/es.txt
+++ b/technic/locale/es.txt
@@ -107,6 +107,7 @@ Power level = Nivel de Poder
%s. Supply: %d Demand: %d = %s. Alimentacion: %d Demanda: %d
# $1: Production percent
Production at %d%% = Produccion en %d%%
+Stopped =
Keeping %d/%d map blocks loaded =
## CNC Machine
diff --git a/technic/locale/it.txt b/technic/locale/it.txt
index 7b1c537..4ad5a97 100644
--- a/technic/locale/it.txt
+++ b/technic/locale/it.txt
@@ -110,6 +110,7 @@ Production at %d%% = Produzione a %d%%
Choose Milling Program: = Scegliere un programma di Fresatura
Slim Elements half / normal height: = Metà elementi sottili / altezza normale:
Current track %s = Traccia corrente %s
+Stopped =
Keeping %d/%d map blocks loaded =
## CNC
diff --git a/technic/locale/template.txt b/technic/locale/template.txt
index 8bd5b2d..4df3586 100644
--- a/technic/locale/template.txt
+++ b/technic/locale/template.txt
@@ -118,6 +118,7 @@ Production at %d%% =
Choose Milling Program: =
Slim Elements half / normal height: =
Current track %s =
+Stopped =
Keeping %d/%d map blocks loaded =
## CNC
diff --git a/technic/machines/LV/music_player.lua b/technic/machines/LV/music_player.lua
index ba5daab..dc7e2d0 100644
--- a/technic/machines/LV/music_player.lua
+++ b/technic/machines/LV/music_player.lua
@@ -15,22 +15,6 @@ minetest.register_craft({
local music_handles = {}
-local music_player_formspec =
- "invsize[8,9;]"..
- "label[0,0;"..S("%s Music Player"):format("LV").."]"..
- "button[4,1;1,1;track1;1]"..
- "button[5,1;1,1;track2;2]"..
- "button[6,1;1,1;track3;3]"..
- "button[4,2;1,1;track4;4]"..
- "button[5,2;1,1;track5;5]"..
- "button[6,2;1,1;track6;6]"..
- "button[4,3;1,1;track7;7]"..
- "button[5,3;1,1;track8;8]"..
- "button[6,3;1,1;track9;9]"..
- "button[4,4;1,2;play;Play]"..
- "button[6,4;1,2;stop;Stop]"..
- "label[4,0;"..S("Current track %s"):format("--").."]"
-
local function play_track(pos, track)
return minetest.sound_play("technic_track"..tostring(track),
{pos = pos, gain = 1.0, loop = true, max_hear_distance = 72,})
@@ -85,6 +69,27 @@ local function stop_player(pos, node)
end
end
+local function set_display(meta)
+ meta:set_string("formspec",
+ "size[4,4.5]"..
+ "item_image[0,0;1,1;technic:music_player]"..
+ "label[1,0;"..S("%s Music Player"):format("LV").."]"..
+ "button[0,1;1,1;track1;1]"..
+ "button[1,1;1,1;track2;2]"..
+ "button[2,1;1,1;track3;3]"..
+ "button[0,2;1,1;track4;4]"..
+ "button[1,2;1,1;track5;5]"..
+ "button[2,2;1,1;track6;6]"..
+ "button[0,3;1,1;track7;7]"..
+ "button[1,3;1,1;track8;8]"..
+ "button[2,3;1,1;track9;9]"..
+ "button[3,1;1,1;stop;Stop]"..
+ "label[0,4;"..minetest.formspec_escape(
+ meta:get_int("active") == 0 and
+ S("Stopped") or
+ S("Current track %s"):format(meta:get_int("current_track"))).."]")
+end
+
minetest.register_node("technic:music_player", {
description = S("%s Music Player"):format("LV"),
tiles = {"technic_music_player_top.png", "technic_machine_bottom.png", "technic_music_player_side.png",
@@ -94,42 +99,26 @@ minetest.register_node("technic:music_player", {
on_construct = function(pos)
local meta = minetest.get_meta(pos)
meta:set_string("infotext", S("%s Music Player"):format("LV"))
- meta:set_int("active", 0)
- meta:set_int("current_track", 1)
- meta:set_string("formspec", music_player_formspec)
+ set_display(meta)
end,
on_receive_fields = function(pos, formanme, fields, sender)
- local meta = minetest.get_meta(pos)
- local current_track = meta:get_int("current_track")
- if fields.track1 then current_track = 1 end
- if fields.track2 then current_track = 2 end
- if fields.track3 then current_track = 3 end
- if fields.track4 then current_track = 4 end
- if fields.track5 then current_track = 5 end
- if fields.track6 then current_track = 6 end
- if fields.track7 then current_track = 7 end
- if fields.track8 then current_track = 8 end
- if fields.track9 then current_track = 9 end
- meta:set_int("current_track", current_track)
- meta:set_string("formspec",
- "invsize[8,9;]"..
- "label[0,0;"..S("%s Music Player"):format("LV").."]"..
- "button[4,1;1,1;track1;1]"..
- "button[5,1;1,1;track2;2]"..
- "button[6,1;1,1;track3;3]"..
- "button[4,2;1,1;track4;4]"..
- "button[5,2;1,1;track5;5]"..
- "button[6,2;1,1;track6;6]"..
- "button[4,3;1,1;track7;7]"..
- "button[5,3;1,1;track8;8]"..
- "button[6,3;1,1;track9;9]"..
- "button[4,4;1,2;play;Play]"..
- "button[6,4;1,2;stop;Stop]"..
- "label[4,0;"..S("Current track %s")
- :format(current_track).."]")
- if fields.play or fields.stop then
+ local new_track = nil
+ if fields.stop then new_track = 0 end
+ if fields.track1 then new_track = 1 end
+ if fields.track2 then new_track = 2 end
+ if fields.track3 then new_track = 3 end
+ if fields.track4 then new_track = 4 end
+ if fields.track5 then new_track = 5 end
+ if fields.track6 then new_track = 6 end
+ if fields.track7 then new_track = 7 end
+ if fields.track8 then new_track = 8 end
+ if fields.track9 then new_track = 9 end
+ if new_track then
stop_player(pos)
- meta:set_int("active", fields.play and 1 or 0)
+ local meta = minetest.get_meta(pos)
+ meta:set_int("active", new_track == 0 and 0 or 1)
+ meta:set_int("current_track", new_track)
+ set_display(meta)
end
end,
on_destruct = stop_player,