2022-09-03 14:50:14 +00:00
|
|
|
local log = require("scada-common.log")
|
|
|
|
|
2022-09-07 02:38:27 +00:00
|
|
|
local iocontrol = require("coordinator.iocontrol")
|
2022-06-11 21:58:29 +00:00
|
|
|
|
2022-06-16 15:24:35 +00:00
|
|
|
local main_view = require("coordinator.ui.layout.main_view")
|
|
|
|
local unit_view = require("coordinator.ui.layout.unit_view")
|
2022-07-05 16:46:31 +00:00
|
|
|
local style = require("coordinator.ui.style")
|
2022-06-06 19:42:39 +00:00
|
|
|
|
2022-05-29 18:34:09 +00:00
|
|
|
local renderer = {}
|
|
|
|
|
2022-06-06 19:42:39 +00:00
|
|
|
-- render engine
|
2022-05-29 18:34:09 +00:00
|
|
|
local engine = {
|
|
|
|
monitors = nil,
|
2022-09-03 14:50:14 +00:00
|
|
|
dmesg_window = nil,
|
|
|
|
ui_ready = false
|
2022-05-29 18:34:09 +00:00
|
|
|
}
|
|
|
|
|
2022-06-14 16:02:42 +00:00
|
|
|
-- UI layouts
|
2022-06-06 19:42:39 +00:00
|
|
|
local ui = {
|
2022-06-14 16:02:42 +00:00
|
|
|
main_layout = nil,
|
|
|
|
unit_layouts = {}
|
2022-06-06 19:42:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
-- reset a display to the "default", but set text scale to 0.5
|
2022-07-05 16:46:31 +00:00
|
|
|
---@param monitor table monitor
|
|
|
|
---@param recolor? boolean override default color palette
|
|
|
|
local function _reset_display(monitor, recolor)
|
2022-06-06 19:42:39 +00:00
|
|
|
monitor.setTextScale(0.5)
|
|
|
|
monitor.setTextColor(colors.white)
|
|
|
|
monitor.setBackgroundColor(colors.black)
|
|
|
|
monitor.clear()
|
|
|
|
monitor.setCursorPos(1, 1)
|
2022-07-05 16:46:31 +00:00
|
|
|
|
|
|
|
if recolor then
|
|
|
|
-- set overridden colors
|
|
|
|
for i = 1, #style.colors do
|
|
|
|
monitor.setPaletteColor(style.colors[i].c, style.colors[i].hex)
|
|
|
|
end
|
|
|
|
else
|
|
|
|
-- reset all colors
|
2022-09-05 20:24:57 +00:00
|
|
|
for _, val in pairs(colors) do
|
2022-07-05 16:46:31 +00:00
|
|
|
-- colors api has constants and functions, just get color constants
|
|
|
|
if type(val) == "number" then
|
|
|
|
monitor.setPaletteColor(val, term.nativePaletteColor(val))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2022-06-06 19:42:39 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
-- link to the monitor peripherals
|
2022-05-29 18:34:09 +00:00
|
|
|
---@param monitors monitors_struct
|
|
|
|
function renderer.set_displays(monitors)
|
|
|
|
engine.monitors = monitors
|
|
|
|
end
|
|
|
|
|
2022-06-06 19:42:39 +00:00
|
|
|
-- reset all displays in use by the renderer
|
2022-07-05 16:46:31 +00:00
|
|
|
---@param recolor? boolean true to use color palette from style
|
|
|
|
function renderer.reset(recolor)
|
2022-05-29 18:34:09 +00:00
|
|
|
-- reset primary monitor
|
2022-07-05 16:46:31 +00:00
|
|
|
_reset_display(engine.monitors.primary, recolor)
|
2022-05-29 18:34:09 +00:00
|
|
|
|
|
|
|
-- reset unit displays
|
|
|
|
for _, monitor in pairs(engine.monitors.unit_displays) do
|
2022-07-05 16:46:31 +00:00
|
|
|
_reset_display(monitor, recolor)
|
2022-05-29 18:34:09 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2022-06-06 19:42:39 +00:00
|
|
|
-- initialize the dmesg output window
|
2022-05-29 18:34:09 +00:00
|
|
|
function renderer.init_dmesg()
|
|
|
|
local disp_x, disp_y = engine.monitors.primary.getSize()
|
|
|
|
engine.dmesg_window = window.create(engine.monitors.primary, 1, 1, disp_x, disp_y)
|
|
|
|
|
|
|
|
log.direct_dmesg(engine.dmesg_window)
|
|
|
|
end
|
|
|
|
|
2022-06-06 19:42:39 +00:00
|
|
|
-- start the coordinator GUI
|
|
|
|
function renderer.start_ui()
|
2022-06-16 15:24:35 +00:00
|
|
|
-- hide dmesg
|
|
|
|
engine.dmesg_window.setVisible(false)
|
2022-06-06 19:42:39 +00:00
|
|
|
|
2022-06-16 15:24:35 +00:00
|
|
|
-- show main view on main monitor
|
|
|
|
ui.main_layout = main_view(engine.monitors.primary)
|
|
|
|
|
|
|
|
-- show unit views on unit displays
|
2022-06-14 16:02:42 +00:00
|
|
|
for id, monitor in pairs(engine.monitors.unit_displays) do
|
2022-06-16 15:24:35 +00:00
|
|
|
table.insert(ui.unit_layouts, unit_view(monitor, id))
|
2022-06-06 19:42:39 +00:00
|
|
|
end
|
2022-09-03 14:50:14 +00:00
|
|
|
|
|
|
|
-- report ui as ready
|
|
|
|
engine.ui_ready = true
|
2022-06-06 19:42:39 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
-- close out the UI
|
2022-07-05 16:46:31 +00:00
|
|
|
---@param recolor? boolean true to restore to color palette from style
|
|
|
|
function renderer.close_ui(recolor)
|
2022-09-03 14:50:14 +00:00
|
|
|
-- report ui as not ready
|
|
|
|
engine.ui_ready = false
|
|
|
|
|
2022-06-06 19:42:39 +00:00
|
|
|
-- clear root UI elements
|
2022-06-14 16:02:42 +00:00
|
|
|
ui.main_layout = nil
|
|
|
|
ui.unit_layouts = {}
|
2022-06-11 21:58:29 +00:00
|
|
|
|
|
|
|
-- reset displays
|
2022-07-05 16:46:31 +00:00
|
|
|
renderer.reset(recolor)
|
2022-06-11 21:58:29 +00:00
|
|
|
|
|
|
|
-- re-draw dmesg
|
2022-06-16 15:24:35 +00:00
|
|
|
engine.dmesg_window.setVisible(true)
|
2022-06-11 21:58:29 +00:00
|
|
|
engine.dmesg_window.redraw()
|
2022-06-06 19:42:39 +00:00
|
|
|
end
|
|
|
|
|
2022-09-03 14:50:14 +00:00
|
|
|
-- is the UI ready?
|
|
|
|
---@return boolean ready
|
|
|
|
function renderer.ui_ready() return engine.ui_ready end
|
|
|
|
|
2022-07-20 17:28:58 +00:00
|
|
|
-- handle a touch event
|
|
|
|
---@param event monitor_touch
|
|
|
|
function renderer.handle_touch(event)
|
|
|
|
if event.monitor == engine.monitors.primary_name then
|
|
|
|
ui.main_layout.handle_touch(event)
|
|
|
|
else
|
|
|
|
for id, monitor in pairs(engine.monitors.unit_name_map) do
|
|
|
|
if event.monitor == monitor then
|
|
|
|
local layout = ui.unit_layouts[id] ---@type graphics_element
|
|
|
|
layout.handle_touch(event)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2022-05-29 18:34:09 +00:00
|
|
|
return renderer
|