mirror of
https://github.com/MikaylaFischler/cc-mek-scada.git
synced 2024-08-30 18:22:34 +00:00
#73 core map and bugfixes
This commit is contained in:
parent
17dd35e6de
commit
826114e5bf
@ -16,7 +16,7 @@ local config = require("coordinator.config")
|
||||
local coordinator = require("coordinator.coordinator")
|
||||
local renderer = require("coordinator.renderer")
|
||||
|
||||
local COORDINATOR_VERSION = "alpha-v0.3.8"
|
||||
local COORDINATOR_VERSION = "alpha-v0.3.9"
|
||||
|
||||
local print = util.print
|
||||
local println = util.println
|
||||
|
@ -47,6 +47,7 @@ local function new_view(root, x, y, ps)
|
||||
ps.subscribe("steam", steam.update)
|
||||
ps.subscribe("ccool", ccool.update)
|
||||
|
||||
---@fixme test code
|
||||
hcool.update(0.22)
|
||||
water.update(1)
|
||||
steam.update(0.05)
|
||||
|
@ -50,6 +50,7 @@ local function new_view(root, x, y, ps)
|
||||
ps.subscribe("hcool", hcool.update)
|
||||
ps.subscribe("waste", waste.update)
|
||||
|
||||
---@fixme test code
|
||||
fuel.update(1)
|
||||
ccool.update(0.85)
|
||||
hcool.update(0.08)
|
||||
|
@ -36,6 +36,7 @@ local function new_view(root, x, y, ps)
|
||||
|
||||
ps.subscribe("steam", steam.update)
|
||||
|
||||
---@fixme test code
|
||||
steam.update(0.12)
|
||||
end
|
||||
|
||||
|
@ -10,8 +10,9 @@ local style = require("coordinator.ui.style")
|
||||
local DisplayBox = require("graphics.elements.displaybox")
|
||||
local Div = require("graphics.elements.div")
|
||||
local TextBox = require("graphics.elements.textbox")
|
||||
local Tiling = require("graphics.elements.tiling")
|
||||
local ColorMap = require("graphics.elements.colormap")
|
||||
|
||||
local CoreMap = require("graphics.elements.indicators.coremap")
|
||||
local DataIndicator = require("graphics.elements.indicators.data")
|
||||
local HorizontalBar = require("graphics.elements.indicators.hbar")
|
||||
local IndicatorLight = require("graphics.elements.indicators.light")
|
||||
@ -31,18 +32,28 @@ local function init(monitor, id)
|
||||
|
||||
TextBox{parent=main,text="Reactor Unit #" .. id,alignment=TEXT_ALIGN.CENTER,height=1,fg_bg=style.header}
|
||||
|
||||
local reactor_width = 18
|
||||
local core_width = ((reactor_width - 2) * 2) + 4
|
||||
local core_height = reactor_width
|
||||
|
||||
local scram_fg_bg = core.graphics.cpair(colors.white, colors.gray)
|
||||
|
||||
local reactor_top_view = Tiling{parent=main,x=2,y=3,width=core_width,height=core_height,fill_c=cpair(colors.lightGray,colors.lightBlue),even=true,border_c=colors.gray}
|
||||
---@fixme test code
|
||||
local t = 300
|
||||
if id == 1 then
|
||||
t = 340
|
||||
elseif id == 2 then
|
||||
t = 340
|
||||
elseif id == 3 then
|
||||
t = 300
|
||||
elseif id == 4 then
|
||||
t = 300
|
||||
end
|
||||
|
||||
local core_view = CoreMap{parent=main,x=2,y=3}
|
||||
core_view.update(t)
|
||||
local core_shift = core_view.height()
|
||||
|
||||
local f = function () print("scram!") end
|
||||
local scram = SCRAMButton{parent=main,x=2,y=core_height+4,callback=f,fg_bg=scram_fg_bg}
|
||||
local scram = SCRAMButton{parent=main,x=2,y=core_shift+4,callback=f,fg_bg=scram_fg_bg}
|
||||
|
||||
local burn_control = Div{parent=main,x=13,y=core_height+4,width=19,height=3,fg_bg=cpair(colors.gray,colors.white)}
|
||||
local burn_control = Div{parent=main,x=13,y=core_shift+4,width=19,height=3,fg_bg=cpair(colors.gray,colors.white)}
|
||||
|
||||
local burn_rate = SpinboxNumeric{parent=burn_control,x=2,y=1,whole_num_precision=4,fractional_precision=1,arrow_fg_bg=cpair(colors.gray,colors.white),fg_bg=cpair(colors.black,colors.white)}
|
||||
local set_burn = function () print("set burn to " .. burn_rate.get_value()) end
|
||||
@ -50,7 +61,11 @@ local function init(monitor, id)
|
||||
TextBox{parent=burn_control,x=9,y=2,text="mB/t"}
|
||||
PushButton{parent=burn_control,x=14,y=2,text="SET",min_width=5,fg_bg=cpair(colors.black,colors.yellow),active_fg_bg=cpair(colors.white,colors.gray),callback=set_burn}
|
||||
|
||||
local annunciator = Div{parent=main,x=34,y=core_height+4}
|
||||
---@fixme test code
|
||||
main.line_break()
|
||||
ColorMap{parent=main}
|
||||
|
||||
local annunciator = Div{parent=main,x=34,y=3}
|
||||
|
||||
-- annunciator colors per IAEA-TECDOC-812 recommendations
|
||||
|
||||
@ -63,8 +78,8 @@ local function init(monitor, id)
|
||||
annunciator.line_break()
|
||||
|
||||
-- annunciator fields
|
||||
local r_trip = IndicatorLight{parent=annunciator,label="Reactor Trip",colors=cpair(colors.red,colors.gray)}
|
||||
local r_mtrp = IndicatorLight{parent=annunciator,label="Manual Reactor Trip",colors=cpair(colors.red,colors.gray)}
|
||||
local r_trip = IndicatorLight{parent=annunciator,label="Reactor SCRAM",colors=cpair(colors.red,colors.gray)}
|
||||
local r_mtrp = IndicatorLight{parent=annunciator,label="Manual Reactor SCRAM",colors=cpair(colors.red,colors.gray)}
|
||||
local r_rtrp = IndicatorLight{parent=annunciator,label="RCP Trip",colors=cpair(colors.red,colors.gray)}
|
||||
local r_cflo = IndicatorLight{parent=annunciator,label="RCS Flow Low",colors=cpair(colors.yellow,colors.gray)}
|
||||
local r_temp = IndicatorLight{parent=annunciator,label="Reactor Temp. High",colors=cpair(colors.red,colors.gray)}
|
||||
@ -86,6 +101,16 @@ local function init(monitor, id)
|
||||
local rps_flt = IndicatorLight{parent=annunciator,label="PPM Fault",colors=cpair(colors.yellow,colors.gray)}
|
||||
local rps_tmo = IndicatorLight{parent=annunciator,label="Timeout",colors=cpair(colors.yellow,colors.gray)}
|
||||
|
||||
annunciator.line_break()
|
||||
|
||||
-- cooling
|
||||
local c_brm = IndicatorLight{parent=annunciator,label="Boil Rate Mismatch",colors=cpair(colors.yellow,colors.gray)}
|
||||
local c_cfm = IndicatorLight{parent=annunciator,label="Coolant Feed Mismatch",colors=cpair(colors.yellow,colors.gray)}
|
||||
local c_sfm = IndicatorLight{parent=annunciator,label="Steam Feed Mismatch",colors=cpair(colors.yellow,colors.gray)}
|
||||
local c_mwrf = IndicatorLight{parent=annunciator,label="Max Water Return Feed",colors=cpair(colors.yellow,colors.gray)}
|
||||
local c_tbnt = IndicatorLight{parent=annunciator,label="Turbine Trip",colors=cpair(colors.red,colors.gray)}
|
||||
|
||||
---@fixme test code
|
||||
plc_hbeat.update(true)
|
||||
r_auto.update(true)
|
||||
r_trip.update(true)
|
||||
@ -93,6 +118,7 @@ local function init(monitor, id)
|
||||
rps_trp.update(true)
|
||||
rps_nof.update(true)
|
||||
|
||||
---@fixme test code
|
||||
local heartbeat = true
|
||||
local function _test_toggle()
|
||||
plc_hbeat.update(heartbeat)
|
||||
@ -100,6 +126,7 @@ local function init(monitor, id)
|
||||
tcallbackdsp.dispatch(1, _test_toggle)
|
||||
end
|
||||
|
||||
---@fixme test code
|
||||
local rps = true
|
||||
local function _test_toggle1()
|
||||
rps_nof.update(rps)
|
||||
@ -107,6 +134,7 @@ local function init(monitor, id)
|
||||
tcallbackdsp.dispatch(0.25, _test_toggle1)
|
||||
end
|
||||
|
||||
---@fixme test code
|
||||
tcallbackdsp.dispatch(1, _test_toggle)
|
||||
tcallbackdsp.dispatch(0.25, _test_toggle1)
|
||||
|
||||
|
33
graphics/elements/colormap.lua
Normal file
33
graphics/elements/colormap.lua
Normal file
@ -0,0 +1,33 @@
|
||||
-- Color Map Graphics Element
|
||||
|
||||
local util = require("scada-common.util")
|
||||
|
||||
local element = require("graphics.element")
|
||||
|
||||
---@class colormap_args
|
||||
---@field parent graphics_element
|
||||
---@field id? string element id
|
||||
---@field x? integer 1 if omitted
|
||||
---@field y? integer 1 if omitted
|
||||
|
||||
-- new color map
|
||||
---@param args colormap_args
|
||||
---@return graphics_element element, element_id id
|
||||
local function colormap(args)
|
||||
local bkg = "008877FFCCEE114455DD9933BBAA2266"
|
||||
local spaces = util.spaces(32)
|
||||
|
||||
args.width = 32
|
||||
args.height = 1
|
||||
|
||||
-- create new graphics element base object
|
||||
local e = element.new(args)
|
||||
|
||||
-- draw color map
|
||||
e.window.setCursorPos(1, 1)
|
||||
e.window.blit(spaces, bkg, bkg)
|
||||
|
||||
return e.get()
|
||||
end
|
||||
|
||||
return colormap
|
106
graphics/elements/indicators/coremap.lua
Normal file
106
graphics/elements/indicators/coremap.lua
Normal file
@ -0,0 +1,106 @@
|
||||
-- Reactor Core View Graphics Element
|
||||
|
||||
local util = require("scada-common.util")
|
||||
|
||||
local core = require("graphics.core")
|
||||
local element = require("graphics.element")
|
||||
|
||||
---@class core_map_args
|
||||
---@field parent graphics_element
|
||||
---@field id? string element id
|
||||
---@field x? integer 1 if omitted
|
||||
---@field y? integer 1 if omitted
|
||||
---@field fg_bg? cpair foreground/background colors
|
||||
|
||||
-- new core map box
|
||||
---@param args core_map_args
|
||||
---@return graphics_element element, element_id id
|
||||
local function core_map(args)
|
||||
args.width = 30
|
||||
args.height = 18
|
||||
|
||||
-- arbitrary foreground color, gray reactor frame background
|
||||
args.fg_bg = core.graphics.cpair(colors.white, colors.gray)
|
||||
|
||||
-- create new graphics element base object
|
||||
local e = element.new(args)
|
||||
|
||||
-- draw core map box
|
||||
|
||||
local start_x = 2
|
||||
local start_y = 2
|
||||
|
||||
local inner_width = math.floor((e.frame.w - 2) / 2)
|
||||
local inner_height = e.frame.h - 2
|
||||
local alternator = true
|
||||
|
||||
-- check dimensions
|
||||
assert(inner_width > 0, "graphics.elements.indicators.coremap: inner_width <= 0")
|
||||
assert(inner_height > 0, "graphics.elements.indicators.coremap: inner_height <= 0")
|
||||
assert(start_x <= inner_width, "graphics.elements.indicators.coremap: start_x > inner_width")
|
||||
assert(start_y <= inner_height, "graphics.elements.indicators.coremap: start_y > inner_height")
|
||||
|
||||
-- draw the core
|
||||
local function draw(t)
|
||||
local i = 1
|
||||
local back_c = "FF"
|
||||
local text_c = "FF"
|
||||
|
||||
-- determine fuel assembly coloring
|
||||
if t <= 300 then
|
||||
-- gray
|
||||
back_c = "88"
|
||||
elseif t <= 350 then
|
||||
-- blue
|
||||
back_c = "33"
|
||||
elseif t < 600 then
|
||||
-- green
|
||||
back_c = "DD"
|
||||
elseif t < 1000 then
|
||||
-- yellow
|
||||
back_c = "44"
|
||||
elseif t < 1200 then
|
||||
-- orange
|
||||
back_c = "11"
|
||||
elseif t < 1300 then
|
||||
-- red
|
||||
back_c = "EE"
|
||||
text_c = "00"
|
||||
else
|
||||
-- pink
|
||||
back_c = "22"
|
||||
text_c = "00"
|
||||
end
|
||||
|
||||
-- draw pattern
|
||||
for y = start_y, inner_height + (start_y - 1) do
|
||||
e.window.setCursorPos(start_x, y)
|
||||
for x = 1, inner_width do
|
||||
local str = util.sprintf("%02X", i)
|
||||
|
||||
if alternator then
|
||||
i = i + 1
|
||||
e.window.blit(str, text_c, back_c)
|
||||
else
|
||||
e.window.blit(" ", "00", "00")
|
||||
end
|
||||
|
||||
alternator = not alternator
|
||||
end
|
||||
|
||||
if inner_width % 2 == 0 then alternator = not alternator end
|
||||
end
|
||||
end
|
||||
|
||||
draw(300)
|
||||
|
||||
-- on state change
|
||||
---@param temperature integer temperature in Kelvin
|
||||
function e.on_update(temperature)
|
||||
draw(temperature)
|
||||
end
|
||||
|
||||
return e.get()
|
||||
end
|
||||
|
||||
return core_map
|
Loading…
Reference in New Issue
Block a user