mirror of
https://github.com/MikaylaFischler/cc-mek-scada.git
synced 2024-08-30 18:22:34 +00:00
#232 added container mode indicators for tanks
This commit is contained in:
parent
9bf07e6c3e
commit
c5d38a5584
@ -210,8 +210,8 @@ local function make(parent, x, y, wide, unit)
|
|||||||
local sna_act = IndicatorLight{parent=sna_po,label="ACTIVE",colors=ind_grn}
|
local sna_act = IndicatorLight{parent=sna_po,label="ACTIVE",colors=ind_grn}
|
||||||
local sna_cnt = DataIndicator{parent=sna_po,x=12,y=1,lu_colors=lu_c,label="CNT",unit="",format="%2d",value=0,width=7}
|
local sna_cnt = DataIndicator{parent=sna_po,x=12,y=1,lu_colors=lu_c,label="CNT",unit="",format="%2d",value=0,width=7}
|
||||||
local sna_pk = DataIndicator{parent=sna_po,y=3,lu_colors=lu_c,label="PEAK",unit="mB/t",format="%7.2f",value=0,width=17}
|
local sna_pk = DataIndicator{parent=sna_po,y=3,lu_colors=lu_c,label="PEAK",unit="mB/t",format="%7.2f",value=0,width=17}
|
||||||
local sna_max = DataIndicator{parent=sna_po,lu_colors=lu_c,label="MAX ",unit="mB/t",format="%7.2f",value=0,width=17}
|
local sna_max = DataIndicator{parent=sna_po,lu_colors=lu_c,label="MAX",unit="mB/t",format="%8.2f",value=0,width=17}
|
||||||
local sna_in = DataIndicator{parent=sna_po,lu_colors=lu_c,label="IN ",unit="mB/t",format="%7.2f",value=0,width=17}
|
local sna_in = DataIndicator{parent=sna_po,lu_colors=lu_c,label="IN",unit="mB/t",format="%9.2f",value=0,width=17}
|
||||||
|
|
||||||
sna_act.register(unit.unit_ps, "po_rate", function (r) sna_act.update(r > 0) end)
|
sna_act.register(unit.unit_ps, "po_rate", function (r) sna_act.update(r > 0) end)
|
||||||
sna_cnt.register(unit.unit_ps, "sna_count", sna_cnt.update)
|
sna_cnt.register(unit.unit_ps, "sna_count", sna_cnt.update)
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
-- Flow Monitor GUI
|
-- Flow Monitor GUI
|
||||||
--
|
--
|
||||||
|
|
||||||
|
local types = require("scada-common.types")
|
||||||
local util = require("scada-common.util")
|
local util = require("scada-common.util")
|
||||||
|
|
||||||
local iocontrol = require("coordinator.iocontrol")
|
local iocontrol = require("coordinator.iocontrol")
|
||||||
@ -22,6 +23,8 @@ local HorizontalBar = require("graphics.elements.indicators.hbar")
|
|||||||
local IndicatorLight = require("graphics.elements.indicators.light")
|
local IndicatorLight = require("graphics.elements.indicators.light")
|
||||||
local StateIndicator = require("graphics.elements.indicators.state")
|
local StateIndicator = require("graphics.elements.indicators.state")
|
||||||
|
|
||||||
|
local CONTAINER_MODE = types.CONTAINER_MODE
|
||||||
|
|
||||||
local TEXT_ALIGN = core.TEXT_ALIGN
|
local TEXT_ALIGN = core.TEXT_ALIGN
|
||||||
|
|
||||||
local cpair = core.cpair
|
local cpair = core.cpair
|
||||||
@ -71,7 +74,7 @@ local function init(main)
|
|||||||
for i = 1, facility.num_units do
|
for i = 1, facility.num_units do
|
||||||
if units[i].has_tank then
|
if units[i].has_tank then
|
||||||
local y = y_ofs(i)
|
local y = y_ofs(i)
|
||||||
table.insert(water_pipes, pipe(2, y, 2, y + 5, colors.blue, true))
|
table.insert(water_pipes, pipe(2, y, 2, y + 3, colors.blue, true))
|
||||||
table.insert(water_pipes, pipe(2, y, 21, y, colors.blue, true))
|
table.insert(water_pipes, pipe(2, y, 21, y, colors.blue, true))
|
||||||
|
|
||||||
local u = units[i] ---@type ioctl_unit
|
local u = units[i] ---@type ioctl_unit
|
||||||
@ -88,7 +91,7 @@ local function init(main)
|
|||||||
if tank_defs[i] == 2 then
|
if tank_defs[i] == 2 then
|
||||||
table.insert(water_pipes, pipe(1, y, 21, y, colors.blue, true))
|
table.insert(water_pipes, pipe(1, y, 21, y, colors.blue, true))
|
||||||
else
|
else
|
||||||
table.insert(water_pipes, pipe(2, y, 2, y + 5, colors.blue, true))
|
table.insert(water_pipes, pipe(2, y, 2, y + 3, colors.blue, true))
|
||||||
table.insert(water_pipes, pipe(2, y, 21, y, colors.blue, true))
|
table.insert(water_pipes, pipe(2, y, 21, y, colors.blue, true))
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -105,12 +108,12 @@ local function init(main)
|
|||||||
for i = 1, #tank_defs do
|
for i = 1, #tank_defs do
|
||||||
local y = y_ofs(i)
|
local y = y_ofs(i)
|
||||||
if i == first_fdef then
|
if i == first_fdef then
|
||||||
table.insert(water_pipes, pipe(0, y, 1, y + 6, colors.blue, true))
|
table.insert(water_pipes, pipe(0, y, 1, y + 5, colors.blue, true))
|
||||||
elseif i > first_fdef then
|
elseif i > first_fdef then
|
||||||
if i == last_fdef then
|
if i == last_fdef then
|
||||||
table.insert(water_pipes, pipe(0, y - 13, 0, y, colors.blue, true))
|
table.insert(water_pipes, pipe(0, y - 14, 0, y, colors.blue, true))
|
||||||
elseif i < last_fdef then
|
elseif i < last_fdef then
|
||||||
table.insert(water_pipes, pipe(0, y - 13, 0, y + 6, colors.blue, true))
|
table.insert(water_pipes, pipe(0, y - 14, 0, y + 5, colors.blue, true))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -122,15 +125,15 @@ local function init(main)
|
|||||||
local y = y_ofs(i)
|
local y = y_ofs(i)
|
||||||
if i == 4 then
|
if i == 4 then
|
||||||
if tank_defs[i] == 2 then
|
if tank_defs[i] == 2 then
|
||||||
table.insert(water_pipes, pipe(0, y, 1, y + 6, colors.blue, true))
|
table.insert(water_pipes, pipe(0, y, 1, y + 5, colors.blue, true))
|
||||||
end
|
end
|
||||||
elseif i == first_fdef then
|
elseif i == first_fdef then
|
||||||
table.insert(water_pipes, pipe(0, y, 1, y + 6, colors.blue, true))
|
table.insert(water_pipes, pipe(0, y, 1, y + 5, colors.blue, true))
|
||||||
elseif i > first_fdef then
|
elseif i > first_fdef then
|
||||||
if i == last_fdef then
|
if i == last_fdef then
|
||||||
table.insert(water_pipes, pipe(0, y - 13, 0, y, colors.blue, true))
|
table.insert(water_pipes, pipe(0, y - 14, 0, y, colors.blue, true))
|
||||||
elseif i < last_fdef then
|
elseif i < last_fdef then
|
||||||
table.insert(water_pipes, pipe(0, y - 13, 0, y + 6, colors.blue, true))
|
table.insert(water_pipes, pipe(0, y - 14, 0, y + 5, colors.blue, true))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -155,15 +158,15 @@ local function init(main)
|
|||||||
local y = y_ofs(i)
|
local y = y_ofs(i)
|
||||||
if i == 1 then
|
if i == 1 then
|
||||||
if tank_defs[i] == 2 then
|
if tank_defs[i] == 2 then
|
||||||
table.insert(water_pipes, pipe(0, y, 1, y + 6, colors.blue, true))
|
table.insert(water_pipes, pipe(0, y, 1, y + 5, colors.blue, true))
|
||||||
end
|
end
|
||||||
elseif i == first_fdef then
|
elseif i == first_fdef then
|
||||||
table.insert(water_pipes, pipe(0, y, 1, y + 6, colors.blue, true))
|
table.insert(water_pipes, pipe(0, y, 1, y + 5, colors.blue, true))
|
||||||
elseif i > first_fdef then
|
elseif i > first_fdef then
|
||||||
if i == last_fdef then
|
if i == last_fdef then
|
||||||
table.insert(water_pipes, pipe(0, y - 13, 0, y, colors.blue, true))
|
table.insert(water_pipes, pipe(0, y - 14, 0, y, colors.blue, true))
|
||||||
elseif i < last_fdef then
|
elseif i < last_fdef then
|
||||||
table.insert(water_pipes, pipe(0, y - 13, 0, y + 6, colors.blue, true))
|
table.insert(water_pipes, pipe(0, y - 14, 0, y + 5, colors.blue, true))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -175,15 +178,15 @@ local function init(main)
|
|||||||
local y = y_ofs(i)
|
local y = y_ofs(i)
|
||||||
if i == 3 or i == 4 then
|
if i == 3 or i == 4 then
|
||||||
if tank_defs[i] == 2 then
|
if tank_defs[i] == 2 then
|
||||||
table.insert(water_pipes, pipe(0, y, 1, y + 6, colors.blue, true))
|
table.insert(water_pipes, pipe(0, y, 1, y + 5, colors.blue, true))
|
||||||
end
|
end
|
||||||
elseif i == first_fdef then
|
elseif i == first_fdef then
|
||||||
table.insert(water_pipes, pipe(0, y, 1, y + 6, colors.blue, true))
|
table.insert(water_pipes, pipe(0, y, 1, y + 5, colors.blue, true))
|
||||||
elseif i > first_fdef then
|
elseif i > first_fdef then
|
||||||
if i == last_fdef then
|
if i == last_fdef then
|
||||||
table.insert(water_pipes, pipe(0, y - 13, 0, y, colors.blue, true))
|
table.insert(water_pipes, pipe(0, y - 14, 0, y, colors.blue, true))
|
||||||
elseif i < last_fdef then
|
elseif i < last_fdef then
|
||||||
table.insert(water_pipes, pipe(0, y - 13, 0, y + 6, colors.blue, true))
|
table.insert(water_pipes, pipe(0, y - 14, 0, y + 5, colors.blue, true))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -195,15 +198,15 @@ local function init(main)
|
|||||||
local y = y_ofs(i)
|
local y = y_ofs(i)
|
||||||
if i == 1 or i == 4 then
|
if i == 1 or i == 4 then
|
||||||
if tank_defs[i] == 2 then
|
if tank_defs[i] == 2 then
|
||||||
table.insert(water_pipes, pipe(0, y, 1, y + 6, colors.blue, true))
|
table.insert(water_pipes, pipe(0, y, 1, y + 5, colors.blue, true))
|
||||||
end
|
end
|
||||||
elseif i == first_fdef then
|
elseif i == first_fdef then
|
||||||
table.insert(water_pipes, pipe(0, y, 1, y + 6, colors.blue, true))
|
table.insert(water_pipes, pipe(0, y, 1, y + 5, colors.blue, true))
|
||||||
elseif i > first_fdef then
|
elseif i > first_fdef then
|
||||||
if i == last_fdef then
|
if i == last_fdef then
|
||||||
table.insert(water_pipes, pipe(0, y - 13, 0, y, colors.blue, true))
|
table.insert(water_pipes, pipe(0, y - 14, 0, y, colors.blue, true))
|
||||||
elseif i < last_fdef then
|
elseif i < last_fdef then
|
||||||
table.insert(water_pipes, pipe(0, y - 13, 0, y + 6, colors.blue, true))
|
table.insert(water_pipes, pipe(0, y - 14, 0, y + 5, colors.blue, true))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -215,15 +218,15 @@ local function init(main)
|
|||||||
local y = y_ofs(i)
|
local y = y_ofs(i)
|
||||||
if i == 1 or i == 2 then
|
if i == 1 or i == 2 then
|
||||||
if tank_defs[i] == 2 then
|
if tank_defs[i] == 2 then
|
||||||
table.insert(water_pipes, pipe(0, y, 1, y + 6, colors.blue, true))
|
table.insert(water_pipes, pipe(0, y, 1, y + 5, colors.blue, true))
|
||||||
end
|
end
|
||||||
elseif i == first_fdef then
|
elseif i == first_fdef then
|
||||||
table.insert(water_pipes, pipe(0, y, 1, y + 6, colors.blue, true))
|
table.insert(water_pipes, pipe(0, y, 1, y + 5, colors.blue, true))
|
||||||
elseif i > first_fdef then
|
elseif i > first_fdef then
|
||||||
if i == last_fdef then
|
if i == last_fdef then
|
||||||
table.insert(water_pipes, pipe(0, y - 13, 0, y, colors.blue, true))
|
table.insert(water_pipes, pipe(0, y - 14, 0, y, colors.blue, true))
|
||||||
elseif i < last_fdef then
|
elseif i < last_fdef then
|
||||||
table.insert(water_pipes, pipe(0, y - 13, 0, y + 6, colors.blue, true))
|
table.insert(water_pipes, pipe(0, y - 14, 0, y + 5, colors.blue, true))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -275,12 +278,12 @@ local function init(main)
|
|||||||
|
|
||||||
local y_offset = y_ofs(i)
|
local y_offset = y_ofs(i)
|
||||||
|
|
||||||
local tank = Div{parent=main,x=3,y=8+y_offset,width=20,height=12}
|
local tank = Div{parent=main,x=3,y=7+y_offset,width=20,height=14}
|
||||||
|
|
||||||
TextBox{parent=tank,text=" ",height=1,x=1,y=1,fg_bg=cpair(colors.lightGray,colors.gray)}
|
TextBox{parent=tank,text=" ",height=1,x=1,y=1,fg_bg=cpair(colors.lightGray,colors.gray)}
|
||||||
TextBox{parent=tank,text="DYNAMIC TANK "..id,alignment=TEXT_ALIGN.CENTER,height=1,fg_bg=cpair(colors.white,colors.gray)}
|
TextBox{parent=tank,text="DYNAMIC TANK "..id,alignment=TEXT_ALIGN.CENTER,height=1,fg_bg=cpair(colors.white,colors.gray)}
|
||||||
|
|
||||||
local tank_box = Rectangle{parent=tank,border=border(1, colors.gray, true),width=20,height=10}
|
local tank_box = Rectangle{parent=tank,border=border(1,colors.gray,true),width=20,height=12}
|
||||||
|
|
||||||
local status = StateIndicator{parent=tank_box,x=3,y=1,states=style.dtank.states,value=1,min_width=14}
|
local status = StateIndicator{parent=tank_box,x=3,y=1,states=style.dtank.states,value=1,min_width=14}
|
||||||
|
|
||||||
@ -291,16 +294,32 @@ local function init(main)
|
|||||||
TextBox{parent=tank_box,x=2,y=6,text="Water Level",height=1,width=11,fg_bg=style.label}
|
TextBox{parent=tank_box,x=2,y=6,text="Water Level",height=1,width=11,fg_bg=style.label}
|
||||||
local level = HorizontalBar{parent=tank_box,x=2,y=7,bar_fg_bg=cpair(colors.blue,colors.gray),height=1,width=16}
|
local level = HorizontalBar{parent=tank_box,x=2,y=7,bar_fg_bg=cpair(colors.blue,colors.gray),height=1,width=16}
|
||||||
|
|
||||||
|
TextBox{parent=tank_box,x=2,y=9,text="In/Out Mode",height=1,width=11,fg_bg=style.label}
|
||||||
|
local can_fill = IndicatorLight{parent=tank_box,x=2,y=10,label="FILL",colors=style.ind_wht}
|
||||||
|
local can_empty = IndicatorLight{parent=tank_box,x=10,y=10,label="EMPTY",colors=style.ind_wht}
|
||||||
|
|
||||||
|
local function _can_fill(mode)
|
||||||
|
can_fill.update((mode == CONTAINER_MODE.BOTH) or (mode == CONTAINER_MODE.FILL))
|
||||||
|
end
|
||||||
|
|
||||||
|
local function _can_empty(mode)
|
||||||
|
can_empty.update((mode == CONTAINER_MODE.BOTH) or (mode == CONTAINER_MODE.EMPTY))
|
||||||
|
end
|
||||||
|
|
||||||
if tank_list[i] == 1 then
|
if tank_list[i] == 1 then
|
||||||
status.register(units[i].tank_ps_tbl[1], "computed_status", status.update)
|
status.register(units[i].tank_ps_tbl[1], "computed_status", status.update)
|
||||||
tank_pcnt.register(units[i].tank_ps_tbl[1], "fill", function (f) tank_pcnt.update(f * 100) end)
|
tank_pcnt.register(units[i].tank_ps_tbl[1], "fill", function (f) tank_pcnt.update(f * 100) end)
|
||||||
tank_amnt.register(units[i].tank_ps_tbl[1], "stored", function (sto) tank_amnt.update(sto.amount) end)
|
tank_amnt.register(units[i].tank_ps_tbl[1], "stored", function (sto) tank_amnt.update(sto.amount) end)
|
||||||
level.register(units[i].tank_ps_tbl[1], "fill", level.update)
|
level.register(units[i].tank_ps_tbl[1], "fill", level.update)
|
||||||
|
can_fill.register(units[i].tank_ps_tbl[1], "container_mode", _can_fill)
|
||||||
|
can_empty.register(units[i].tank_ps_tbl[1], "container_mode", _can_empty)
|
||||||
else
|
else
|
||||||
status.register(facility.tank_ps_tbl[f_id], "computed_status", status.update)
|
status.register(facility.tank_ps_tbl[f_id], "computed_status", status.update)
|
||||||
tank_pcnt.register(facility.tank_ps_tbl[f_id], "fill", function (f) tank_pcnt.update(f * 100) end)
|
tank_pcnt.register(facility.tank_ps_tbl[f_id], "fill", function (f) tank_pcnt.update(f * 100) end)
|
||||||
tank_amnt.register(facility.tank_ps_tbl[f_id], "stored", function (sto) tank_amnt.update(sto.amount) end)
|
tank_amnt.register(facility.tank_ps_tbl[f_id], "stored", function (sto) tank_amnt.update(sto.amount) end)
|
||||||
level.register(facility.tank_ps_tbl[f_id], "fill", level.update)
|
level.register(facility.tank_ps_tbl[f_id], "fill", level.update)
|
||||||
|
can_fill.register(facility.tank_ps_tbl[f_id], "container_mode", _can_fill)
|
||||||
|
can_empty.register(facility.tank_ps_tbl[f_id], "container_mode", _can_empty)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user