2022-06-11 16:21:14 +00:00
|
|
|
-- State (Text) Indicator Graphics Element
|
|
|
|
|
|
|
|
local util = require("scada-common.util")
|
|
|
|
|
|
|
|
local element = require("graphics.element")
|
|
|
|
|
|
|
|
---@class state_text_color
|
|
|
|
---@field color cpair
|
|
|
|
---@field text string
|
|
|
|
|
|
|
|
---@class state_indicator_args
|
|
|
|
---@field states table state color and text table
|
2022-06-16 15:19:32 +00:00
|
|
|
---@field value? integer default state, defaults to 1
|
2022-06-11 16:21:14 +00:00
|
|
|
---@field min_width? integer max state text length if omitted
|
|
|
|
---@field parent graphics_element
|
2022-07-28 14:09:34 +00:00
|
|
|
---@field id? string element id
|
2022-06-11 16:21:14 +00:00
|
|
|
---@field x? integer 1 if omitted
|
|
|
|
---@field y? integer 1 if omitted
|
|
|
|
---@field height? integer 1 if omitted, must be an odd number
|
2022-06-11 21:06:32 +00:00
|
|
|
---@field fg_bg? cpair foreground/background colors
|
2022-06-11 16:21:14 +00:00
|
|
|
|
|
|
|
-- new state indicator
|
2023-02-25 00:50:01 +00:00
|
|
|
---@nodiscard
|
2022-06-11 16:21:14 +00:00
|
|
|
---@param args state_indicator_args
|
2022-07-28 14:09:34 +00:00
|
|
|
---@return graphics_element element, element_id id
|
2022-06-11 16:21:14 +00:00
|
|
|
local function state_indicator(args)
|
2022-06-16 15:19:32 +00:00
|
|
|
assert(type(args.states) == "table", "graphics.elements.indicators.state: states is a required field")
|
2022-06-11 21:06:32 +00:00
|
|
|
|
2022-06-11 16:21:14 +00:00
|
|
|
-- determine height
|
|
|
|
if util.is_int(args.height) then
|
2022-06-16 15:19:32 +00:00
|
|
|
assert(args.height % 2 == 1, "graphics.elements.indicators.state: height should be an odd number")
|
2022-06-11 16:21:14 +00:00
|
|
|
else
|
|
|
|
args.height = 1
|
|
|
|
end
|
|
|
|
|
|
|
|
-- initial guess at width
|
|
|
|
args.width = args.min_width or 1
|
|
|
|
|
|
|
|
-- state blit strings
|
|
|
|
local state_blit_cmds = {}
|
|
|
|
for i = 1, #args.states do
|
|
|
|
local state_def = args.states[i] ---@type state_text_color
|
|
|
|
|
|
|
|
-- re-determine width
|
|
|
|
if string.len(state_def.text) > args.width then
|
|
|
|
args.width = string.len(state_def.text)
|
|
|
|
end
|
|
|
|
|
2022-08-16 15:22:06 +00:00
|
|
|
local text = util.pad(state_def.text, args.width)
|
2022-06-11 16:21:14 +00:00
|
|
|
|
|
|
|
table.insert(state_blit_cmds, {
|
2022-06-16 15:19:32 +00:00
|
|
|
text = text,
|
|
|
|
fgd = util.strrep(state_def.color.blit_fgd, string.len(text)),
|
|
|
|
bkg = util.strrep(state_def.color.blit_bkg, string.len(text))
|
2022-06-11 16:21:14 +00:00
|
|
|
})
|
|
|
|
end
|
|
|
|
|
|
|
|
-- create new graphics element base object
|
|
|
|
local e = element.new(args)
|
|
|
|
|
|
|
|
-- on state change
|
|
|
|
---@param new_state integer indicator state
|
|
|
|
function e.on_update(new_state)
|
|
|
|
local blit_cmd = state_blit_cmds[new_state]
|
2022-09-12 16:59:28 +00:00
|
|
|
e.value = new_state
|
2022-06-11 16:21:14 +00:00
|
|
|
e.window.setCursorPos(1, 1)
|
|
|
|
e.window.blit(blit_cmd.text, blit_cmd.fgd, blit_cmd.bkg)
|
|
|
|
end
|
|
|
|
|
2022-09-12 19:58:43 +00:00
|
|
|
-- set indicator state
|
|
|
|
---@param val integer indicator state
|
2022-09-12 16:59:28 +00:00
|
|
|
function e.set_value(val) e.on_update(val) end
|
|
|
|
|
2022-06-11 16:21:14 +00:00
|
|
|
-- initial draw
|
2022-06-16 15:19:32 +00:00
|
|
|
e.on_update(args.value or 1)
|
2022-06-11 16:21:14 +00:00
|
|
|
|
2022-07-28 15:17:34 +00:00
|
|
|
return e.get()
|
2022-06-11 16:21:14 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
return state_indicator
|