2022-06-08 18:16:05 +00:00
|
|
|
-- Horizontal Bar Graphics Element
|
|
|
|
|
|
|
|
local util = require("scada-common.util")
|
|
|
|
|
|
|
|
local element = require("graphics.element")
|
|
|
|
|
|
|
|
---@class hbar_args
|
2022-06-09 15:59:55 +00:00
|
|
|
---@field show_percent? boolean whether or not to show the percent
|
|
|
|
---@field bar_fg_bg? cpair bar foreground/background colors if showing percent
|
2022-06-08 18:16:05 +00:00
|
|
|
---@field parent graphics_element
|
2022-07-28 14:09:34 +00:00
|
|
|
---@field id? string element id
|
2022-06-08 18:16:05 +00:00
|
|
|
---@field x? integer 1 if omitted
|
|
|
|
---@field y? integer 1 if omitted
|
|
|
|
---@field width? integer parent width if omitted
|
2022-06-09 15:59:55 +00:00
|
|
|
---@field height? integer parent height if omitted
|
|
|
|
---@field gframe? graphics_frame frame instead of x/y/width/height
|
2022-06-11 21:06:32 +00:00
|
|
|
---@field fg_bg? cpair foreground/background colors
|
2022-06-08 18:16:05 +00:00
|
|
|
|
|
|
|
-- new horizontal bar
|
|
|
|
---@param args hbar_args
|
2022-07-28 14:09:34 +00:00
|
|
|
---@return graphics_element element, element_id id
|
2022-06-08 18:16:05 +00:00
|
|
|
local function hbar(args)
|
2022-06-09 15:59:55 +00:00
|
|
|
-- properties/state
|
2022-06-08 18:16:05 +00:00
|
|
|
local last_num_bars = -1
|
|
|
|
|
|
|
|
-- create new graphics element base object
|
|
|
|
local e = element.new(args)
|
|
|
|
|
2022-06-09 15:59:55 +00:00
|
|
|
-- bar width is width - 5 characters for " 100%" if showing percent
|
|
|
|
local bar_width = util.trinary(args.show_percent, e.frame.w - 5, e.frame.w)
|
2022-06-08 18:16:05 +00:00
|
|
|
|
2022-06-16 15:29:47 +00:00
|
|
|
assert(bar_width > 0, "graphics.elements.indicators.hbar: too small for bar")
|
2022-06-08 18:16:05 +00:00
|
|
|
|
2022-06-09 15:59:55 +00:00
|
|
|
-- determine bar colors
|
2022-06-16 15:29:47 +00:00
|
|
|
local bar_bkg = e.fg_bg.blit_bkg
|
|
|
|
local bar_fgd = e.fg_bg.blit_fgd
|
2022-08-09 04:40:50 +00:00
|
|
|
if args.bar_fg_bg ~= nil then
|
2022-06-16 15:29:47 +00:00
|
|
|
bar_bkg = args.bar_fg_bg.blit_bkg
|
|
|
|
bar_fgd = args.bar_fg_bg.blit_fgd
|
|
|
|
end
|
2022-06-09 15:59:55 +00:00
|
|
|
|
2022-06-08 18:16:05 +00:00
|
|
|
-- handle data changes
|
2022-09-12 19:58:43 +00:00
|
|
|
---@param fraction number 0.0 to 1.0
|
2022-06-08 18:16:05 +00:00
|
|
|
function e.on_update(fraction)
|
2022-09-12 16:59:28 +00:00
|
|
|
e.value = fraction
|
|
|
|
|
2022-06-08 18:16:05 +00:00
|
|
|
-- enforce minimum and maximum
|
|
|
|
if fraction < 0 then
|
|
|
|
fraction = 0.0
|
|
|
|
elseif fraction > 1 then
|
|
|
|
fraction = 1.0
|
|
|
|
end
|
|
|
|
|
|
|
|
-- compute number of bars
|
2022-06-16 15:19:32 +00:00
|
|
|
local num_bars = util.round(fraction * (bar_width * 2))
|
2022-06-08 18:16:05 +00:00
|
|
|
|
|
|
|
-- redraw bar if changed
|
|
|
|
if num_bars ~= last_num_bars then
|
|
|
|
last_num_bars = num_bars
|
|
|
|
|
2022-06-09 15:59:55 +00:00
|
|
|
local fgd = ""
|
2022-06-16 15:19:32 +00:00
|
|
|
local bkg = ""
|
2022-06-08 18:16:05 +00:00
|
|
|
local spaces = ""
|
|
|
|
|
|
|
|
-- fill percentage
|
|
|
|
for _ = 1, num_bars / 2 do
|
|
|
|
spaces = spaces .. " "
|
2022-06-09 15:59:55 +00:00
|
|
|
fgd = fgd .. bar_fgd
|
2022-06-16 15:19:32 +00:00
|
|
|
bkg = bkg .. bar_bkg
|
2022-06-08 18:16:05 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
-- add fractional bar if needed
|
|
|
|
if num_bars % 2 == 1 then
|
|
|
|
spaces = spaces .. "\x95"
|
2022-06-16 15:19:32 +00:00
|
|
|
fgd = fgd .. bar_bkg
|
|
|
|
bkg = bkg .. bar_fgd
|
2022-06-08 18:16:05 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
-- pad background
|
2022-06-16 15:19:32 +00:00
|
|
|
for _ = 1, ((bar_width * 2) - num_bars) / 2 do
|
2022-06-08 18:16:05 +00:00
|
|
|
spaces = spaces .. " "
|
2022-06-09 15:59:55 +00:00
|
|
|
fgd = fgd .. bar_bkg
|
2022-06-16 15:19:32 +00:00
|
|
|
bkg = bkg .. bar_bkg
|
2022-06-08 18:16:05 +00:00
|
|
|
end
|
|
|
|
|
2022-06-09 15:59:55 +00:00
|
|
|
-- draw bar
|
|
|
|
for y = 1, e.frame.h do
|
|
|
|
e.window.setCursorPos(1, y)
|
2022-06-16 15:19:32 +00:00
|
|
|
-- intentionally swapped fgd/bkg since we use spaces as fill, but they are the opposite
|
|
|
|
e.window.blit(spaces, bkg, fgd)
|
2022-06-09 15:59:55 +00:00
|
|
|
end
|
2022-06-08 18:16:05 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
-- update percentage
|
2022-06-09 15:59:55 +00:00
|
|
|
if args.show_percent then
|
2022-06-25 18:51:59 +00:00
|
|
|
e.window.setCursorPos(bar_width + 2, math.max(1, math.ceil(e.frame.h / 2)))
|
2022-06-09 15:59:55 +00:00
|
|
|
e.window.write(util.sprintf("%3.0f%%", fraction * 100))
|
|
|
|
end
|
2022-06-08 18:16:05 +00:00
|
|
|
end
|
|
|
|
|
2022-09-12 18:43:01 +00:00
|
|
|
-- change bar color
|
2022-09-12 16:59:28 +00:00
|
|
|
---@param bar_fg_bg cpair new bar colors
|
|
|
|
function e.recolor(bar_fg_bg)
|
|
|
|
bar_bkg = bar_fg_bg.blit_bkg
|
|
|
|
bar_fgd = bar_fg_bg.blit_fgd
|
|
|
|
|
|
|
|
-- re-draw
|
|
|
|
last_num_bars = 0
|
|
|
|
e.on_update(e.value)
|
|
|
|
end
|
|
|
|
|
2022-09-12 19:58:43 +00:00
|
|
|
-- set the percentage value
|
|
|
|
---@param val number 0.0 to 1.0
|
2022-09-12 16:59:28 +00:00
|
|
|
function e.set_value(val) e.on_update(val) end
|
|
|
|
|
2022-06-25 18:27:15 +00:00
|
|
|
-- initialize to 0
|
|
|
|
e.on_update(0)
|
|
|
|
|
2022-07-28 15:17:34 +00:00
|
|
|
return e.get()
|
2022-06-08 18:16:05 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
return hbar
|