cc-mek-scada/graphics/elements/indicators/led.lua

105 lines
2.9 KiB
Lua
Raw Permalink Normal View History

2023-04-07 02:10:33 +00:00
-- Indicator "LED" Graphics Element
local util = require("scada-common.util")
local element = require("graphics.element")
local flasher = require("graphics.flasher")
---@class indicator_led_args
---@field label string indicator label
---@field colors cpair on/off colors (a/b respectively)
---@field min_label_width? integer label length if omitted
---@field flash? boolean whether to flash on true rather than stay on
---@field period? PERIOD flash period
---@field parent graphics_element
---@field id? string element id
---@field x? integer 1 if omitted
2023-07-10 03:42:44 +00:00
---@field y? integer auto incremented if omitted
2023-04-07 02:10:33 +00:00
---@field fg_bg? cpair foreground/background colors
---@field hidden? boolean true to hide on initial draw
2023-04-07 02:10:33 +00:00
-- new indicator LED
---@nodiscard
---@param args indicator_led_args
---@return graphics_element element, element_id id
local function indicator_led(args)
2023-09-30 15:46:47 +00:00
element.assert(type(args.label) == "string", "label is a required field")
element.assert(type(args.colors) == "table", "colors is a required field")
2023-04-07 02:10:33 +00:00
if args.flash then
2023-09-30 15:46:47 +00:00
element.assert(util.is_int(args.period), "period is a required field if flash is enabled")
2023-04-07 02:10:33 +00:00
end
args.height = 1
2023-04-21 00:40:28 +00:00
args.width = math.max(args.min_label_width or 0, string.len(args.label)) + 2
2023-04-07 02:10:33 +00:00
local flash_on = true
-- create new graphics element base object
local e = element.new(args)
e.value = false
2023-04-07 02:10:33 +00:00
-- called by flasher when enabled
local function flash_callback()
2023-08-31 01:11:57 +00:00
e.w_set_cur(1, 1)
2023-04-07 02:10:33 +00:00
if flash_on then
2023-08-31 01:11:57 +00:00
e.w_blit("\x8c", args.colors.blit_a, e.fg_bg.blit_bkg)
2023-04-07 02:10:33 +00:00
else
2023-08-31 01:11:57 +00:00
e.w_blit("\x8c", args.colors.blit_b, e.fg_bg.blit_bkg)
2023-04-07 02:10:33 +00:00
end
flash_on = not flash_on
end
-- enable light or start flashing
local function enable()
if args.flash then
flash_on = true
flasher.start(flash_callback, args.period)
else
2023-08-31 01:11:57 +00:00
e.w_set_cur(1, 1)
e.w_blit("\x8c", args.colors.blit_a, e.fg_bg.blit_bkg)
2023-04-07 02:10:33 +00:00
end
end
-- disable light or stop flashing
local function disable()
if args.flash then
flash_on = false
flasher.stop(flash_callback)
end
2023-08-31 01:11:57 +00:00
e.w_set_cur(1, 1)
e.w_blit("\x8c", args.colors.blit_b, e.fg_bg.blit_bkg)
2023-04-07 02:10:33 +00:00
end
-- on state change
---@param new_state boolean indicator state
function e.on_update(new_state)
e.value = new_state
if new_state then enable() else disable() end
end
-- set indicator state
---@param val boolean indicator state
function e.set_value(val) e.on_update(val) end
-- draw label and indicator light
function e.redraw()
e.on_update(e.value)
if string.len(args.label) > 0 then
e.w_set_cur(3, 1)
e.w_write(args.label)
end
2023-04-21 00:40:28 +00:00
end
2023-04-07 02:10:33 +00:00
-- initial draw
e.redraw()
return e.complete()
2023-04-07 02:10:33 +00:00
end
return indicator_led