forked from mtcontrib/led_marquee
basic automatic horizontal scrolling support
This commit is contained in:
parent
c647effff2
commit
3141aa5ba7
72
init.lua
72
init.lua
@ -1,6 +1,8 @@
|
|||||||
-- simple LED marquee mod
|
-- simple LED marquee mod
|
||||||
-- by Vanessa Dannenberg
|
-- by Vanessa Dannenberg
|
||||||
|
|
||||||
|
led_marquee = {}
|
||||||
|
|
||||||
local S
|
local S
|
||||||
if minetest.get_modpath("intllib") then
|
if minetest.get_modpath("intllib") then
|
||||||
S = intllib.make_gettext_pair()
|
S = intllib.make_gettext_pair()
|
||||||
@ -53,6 +55,31 @@ local make_iso = function(s)
|
|||||||
return s2
|
return s2
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- scrolling
|
||||||
|
|
||||||
|
led_marquee.set_timer = function(pos, timeout)
|
||||||
|
local timer = minetest.get_node_timer(pos)
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
meta:set_int("index", 1)
|
||||||
|
timer:stop()
|
||||||
|
if timeout > 0 then
|
||||||
|
timer:start(timeout)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
led_marquee.scroll_text = function(pos, elapsed)
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
local index = meta:get_int("index")
|
||||||
|
local msg = meta:get_string("last_msg")
|
||||||
|
local channel = meta:get_string("channel")
|
||||||
|
if not index or index < 1 or index > string.len(msg) then index = 1 end
|
||||||
|
msg = string.sub(msg, index)
|
||||||
|
led_marquee.display_msg(pos, channel, msg.." ")
|
||||||
|
if string.byte(string.sub(msg,1,1)) < 32 then index = index + 1 end
|
||||||
|
meta:set_int("index", index + 1)
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
|
||||||
-- the nodes:
|
-- the nodes:
|
||||||
|
|
||||||
local fdir_to_right = {
|
local fdir_to_right = {
|
||||||
@ -71,14 +98,14 @@ local cbox = {
|
|||||||
wall_side = { -8/16, -8/16, -8/16, -7/16, 8/16, 8/16 }
|
wall_side = { -8/16, -8/16, -8/16, -7/16, 8/16, 8/16 }
|
||||||
}
|
}
|
||||||
|
|
||||||
local display_string = function(pos, channel, string)
|
led_marquee.display_msg = function(pos, channel, msg)
|
||||||
string = string.sub(string, 1, 1024)
|
msg = string.sub(msg, 1, 1024)
|
||||||
if string == "off_multi" then
|
if msg == "off_multi" then
|
||||||
string = string.rep(" ", 1024)
|
msg = string.rep(" ", 1024)
|
||||||
elseif string == "allon_multi" then
|
elseif msg == "allon_multi" then
|
||||||
string = string.rep(string.char(144), 1024)
|
msg = string.rep(string.char(144), 1024)
|
||||||
elseif string.sub(string,1,1) == string.char(255) then -- treat it as incoming UTF-8
|
elseif string.sub(msg,1,1) == string.char(255) then -- treat it as incoming UTF-8
|
||||||
string = make_iso(string.sub(string, 2, 1024))
|
msg = make_iso(string.sub(msg, 2, 1024))
|
||||||
end
|
end
|
||||||
|
|
||||||
local master_fdir = minetest.get_node(pos).param2 % 8
|
local master_fdir = minetest.get_node(pos).param2 % 8
|
||||||
@ -90,7 +117,7 @@ local display_string = function(pos, channel, string)
|
|||||||
master_meta:set_int("last_color", 0)
|
master_meta:set_int("last_color", 0)
|
||||||
end
|
end
|
||||||
local i = 1
|
local i = 1
|
||||||
local len = string.len(string)
|
local len = string.len(msg)
|
||||||
local wrapped = nil
|
local wrapped = nil
|
||||||
while i <= len do
|
while i <= len do
|
||||||
local node = minetest.get_node(pos2)
|
local node = minetest.get_node(pos2)
|
||||||
@ -98,7 +125,7 @@ local display_string = function(pos, channel, string)
|
|||||||
local meta = minetest.get_meta(pos2)
|
local meta = minetest.get_meta(pos2)
|
||||||
local setchan = nil
|
local setchan = nil
|
||||||
if meta then setchan = meta:get_string("channel") end
|
if meta then setchan = meta:get_string("channel") end
|
||||||
local asc = string.byte(string, i, i)
|
local asc = string.byte(msg, i, i)
|
||||||
if not string.match(node.name, "led_marquee:char_") then
|
if not string.match(node.name, "led_marquee:char_") then
|
||||||
if not wrapped then
|
if not wrapped then
|
||||||
pos2.x = pos.x
|
pos2.x = pos.x
|
||||||
@ -118,8 +145,8 @@ local display_string = function(pos, channel, string)
|
|||||||
i = i + 1
|
i = i + 1
|
||||||
wrapped = nil
|
wrapped = nil
|
||||||
elseif asc == 29 then
|
elseif asc == 29 then
|
||||||
local c = string.byte(string, i+1, i+1) or 0
|
local c = string.byte(msg, i+1, i+1) or 0
|
||||||
local r = string.byte(string, i+2, i+2) or 0
|
local r = string.byte(msg, i+2, i+2) or 0
|
||||||
pos2.x = pos.x + (fdir_to_right[fdir+1][1])*c
|
pos2.x = pos.x + (fdir_to_right[fdir+1][1])*c
|
||||||
pos2.y = pos.y - r
|
pos2.y = pos.y - r
|
||||||
pos2.z = pos.z + (fdir_to_right[fdir+1][2])*c
|
pos2.z = pos.z + (fdir_to_right[fdir+1][2])*c
|
||||||
@ -152,6 +179,7 @@ local on_digiline_receive_string = function(pos, node, channel, msg)
|
|||||||
|
|
||||||
if setchan ~= channel then return end
|
if setchan ~= channel then return end
|
||||||
if msg and msg ~= "" and type(msg) == "string" then
|
if msg and msg ~= "" and type(msg) == "string" then
|
||||||
|
led_marquee.set_timer(pos, 0)
|
||||||
if string.len(msg) > 1 then
|
if string.len(msg) > 1 then
|
||||||
if msg == "off" then
|
if msg == "off" then
|
||||||
minetest.swap_node(pos, { name = "led_marquee:char_32", param2 = fdir + (last_color*8)})
|
minetest.swap_node(pos, { name = "led_marquee:char_32", param2 = fdir + (last_color*8)})
|
||||||
@ -165,8 +193,20 @@ local on_digiline_receive_string = function(pos, node, channel, msg)
|
|||||||
minetest.swap_node(pos, { name = "led_marquee:char_144", param2 = fdir + (last_color*8)})
|
minetest.swap_node(pos, { name = "led_marquee:char_144", param2 = fdir + (last_color*8)})
|
||||||
elseif msg == "cursor" then
|
elseif msg == "cursor" then
|
||||||
minetest.swap_node(pos, { name = "led_marquee:char_31", param2 = fdir + (last_color*8)})
|
minetest.swap_node(pos, { name = "led_marquee:char_31", param2 = fdir + (last_color*8)})
|
||||||
|
elseif msg == "start_scroll" then
|
||||||
|
local timeout = meta:get_int("timeout")
|
||||||
|
if not timeout or timeout < 0.5 or timeout > 5 then timeout = 0 end
|
||||||
|
led_marquee.set_timer(pos, timeout)
|
||||||
|
elseif msg == "stop_scroll" then
|
||||||
|
return -- (the timer is already stopped by receipt of a message)
|
||||||
|
elseif string.sub(msg, 1, 12) == "scroll_speed" then
|
||||||
|
local timeout = tonumber(string.sub(msg, 13))
|
||||||
|
if not timeout or timeout < 0.5 or timeout > 5 then timeout = 0 end
|
||||||
|
meta:set_int("timeout", timeout)
|
||||||
|
led_marquee.set_timer(pos, timeout)
|
||||||
else
|
else
|
||||||
display_string(pos, channel, msg)
|
meta:set_string("last_msg", msg)
|
||||||
|
led_marquee.display_msg(pos, channel, msg)
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
local asc = string.byte(msg)
|
local asc = string.byte(msg)
|
||||||
@ -190,6 +230,8 @@ local on_digiline_receive_string = function(pos, node, channel, msg)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- the nodes!
|
||||||
|
|
||||||
for i = 31, 255 do
|
for i = 31, 255 do
|
||||||
local groups = { cracky = 2, not_in_creative_inventory = 1}
|
local groups = { cracky = 2, not_in_creative_inventory = 1}
|
||||||
local light = LIGHT_MAX-2
|
local light = LIGHT_MAX-2
|
||||||
@ -244,13 +286,13 @@ for i = 31, 255 do
|
|||||||
action = on_digiline_receive_string,
|
action = on_digiline_receive_string,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
drop = "led_marquee:char_32"
|
drop = "led_marquee:char_32",
|
||||||
|
on_timer = led_marquee.scroll_text
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
-- crafts
|
-- crafts
|
||||||
|
|
||||||
|
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = "led_marquee:char_32 6",
|
output = "led_marquee:char_32 6",
|
||||||
recipe = {
|
recipe = {
|
||||||
|
Loading…
Reference in New Issue
Block a user