2022-06-08 18:48:17 +00:00
|
|
|
-- Button Graphics Element
|
|
|
|
|
2023-05-10 15:46:06 +00:00
|
|
|
local core = require("graphics.core")
|
2022-06-08 18:48:17 +00:00
|
|
|
local element = require("graphics.element")
|
|
|
|
|
2022-06-08 20:21:49 +00:00
|
|
|
---@class switch_button_args
|
2022-06-08 18:48:17 +00:00
|
|
|
---@field text string button text
|
|
|
|
---@field callback function function to call on touch
|
2022-06-08 20:21:49 +00:00
|
|
|
---@field default? boolean default state, defaults to off (false)
|
2022-06-08 18:48:17 +00:00
|
|
|
---@field min_width? integer text length + 2 if omitted
|
2022-06-08 20:21:49 +00:00
|
|
|
---@field active_fg_bg cpair foreground/background colors when pressed
|
2022-06-08 18:48:17 +00:00
|
|
|
---@field parent graphics_element
|
2022-07-28 14:09:34 +00:00
|
|
|
---@field id? string element id
|
2022-06-08 18:48:17 +00:00
|
|
|
---@field x? integer 1 if omitted
|
2023-07-10 03:42:44 +00:00
|
|
|
---@field y? integer auto incremented if omitted
|
2022-06-08 18:48:17 +00:00
|
|
|
---@field height? integer parent height if omitted
|
2022-06-11 21:06:32 +00:00
|
|
|
---@field fg_bg? cpair foreground/background colors
|
2023-05-25 21:40:16 +00:00
|
|
|
---@field hidden? boolean true to hide on initial draw
|
2022-06-08 18:48:17 +00:00
|
|
|
|
2022-06-08 20:21:49 +00:00
|
|
|
-- new switch button (latch high/low)
|
|
|
|
---@param args switch_button_args
|
2022-07-28 14:09:34 +00:00
|
|
|
---@return graphics_element element, element_id id
|
2022-06-08 20:21:49 +00:00
|
|
|
local function switch_button(args)
|
2022-06-16 15:19:32 +00:00
|
|
|
assert(type(args.text) == "string", "graphics.elements.controls.switch_button: text is a required field")
|
|
|
|
assert(type(args.callback) == "function", "graphics.elements.controls.switch_button: callback is a required field")
|
|
|
|
assert(type(args.active_fg_bg) == "table", "graphics.elements.controls.switch_button: active_fg_bg is a required field")
|
2023-05-11 23:55:02 +00:00
|
|
|
assert(type(args.min_width) == "nil" or (type(args.min_width) == "number" and args.min_width > 0),
|
|
|
|
"graphics.elements.controls.switch_button: min_width must be nil or a number > 0")
|
2022-06-16 15:19:32 +00:00
|
|
|
|
2022-06-08 18:48:17 +00:00
|
|
|
local text_width = string.len(args.text)
|
2023-05-11 23:55:02 +00:00
|
|
|
|
|
|
|
-- single line height, calculate width
|
|
|
|
args.height = 1
|
|
|
|
args.min_width = args.min_width or 0
|
|
|
|
args.width = math.max(text_width, args.min_width)
|
2022-06-08 18:48:17 +00:00
|
|
|
|
|
|
|
-- create new graphics element base object
|
|
|
|
local e = element.new(args)
|
|
|
|
|
2022-09-12 16:59:28 +00:00
|
|
|
-- button state (convert nil to false if missing)
|
|
|
|
e.value = args.default or false
|
|
|
|
|
2022-12-04 18:59:10 +00:00
|
|
|
local h_pad = math.floor((e.frame.w - text_width) / 2) + 1
|
2022-06-08 18:48:17 +00:00
|
|
|
local v_pad = math.floor(e.frame.h / 2) + 1
|
|
|
|
|
2022-06-08 20:21:49 +00:00
|
|
|
-- show the button state
|
|
|
|
local function draw_state()
|
2022-09-12 16:59:28 +00:00
|
|
|
if e.value then
|
2022-06-08 18:48:17 +00:00
|
|
|
-- show as pressed
|
|
|
|
e.window.setTextColor(args.active_fg_bg.fgd)
|
|
|
|
e.window.setBackgroundColor(args.active_fg_bg.bkg)
|
2022-06-08 20:21:49 +00:00
|
|
|
else
|
|
|
|
-- show as unpressed
|
|
|
|
e.window.setTextColor(e.fg_bg.fgd)
|
|
|
|
e.window.setBackgroundColor(e.fg_bg.bkg)
|
2022-06-08 18:48:17 +00:00
|
|
|
end
|
|
|
|
|
2022-12-04 18:59:10 +00:00
|
|
|
-- clear to redraw background
|
|
|
|
e.window.clear()
|
|
|
|
|
2022-08-16 15:22:58 +00:00
|
|
|
-- write the button text
|
|
|
|
e.window.setCursorPos(h_pad, v_pad)
|
|
|
|
e.window.write(args.text)
|
2022-06-08 20:21:49 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
-- initial draw
|
|
|
|
draw_state()
|
|
|
|
|
2023-04-09 01:33:54 +00:00
|
|
|
-- handle mouse interaction
|
2023-05-10 15:46:06 +00:00
|
|
|
---@param event mouse_interaction mouse event
|
|
|
|
function e.handle_mouse(event)
|
|
|
|
if e.enabled and core.events.was_clicked(event.type) then
|
2022-10-20 16:22:45 +00:00
|
|
|
-- toggle state
|
|
|
|
e.value = not e.value
|
|
|
|
draw_state()
|
2022-09-12 16:59:28 +00:00
|
|
|
|
2022-10-20 16:22:45 +00:00
|
|
|
-- call the touch callback with state
|
|
|
|
args.callback(e.value)
|
|
|
|
end
|
2022-09-12 16:59:28 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
-- set the value
|
|
|
|
---@param val boolean new value
|
|
|
|
function e.set_value(val)
|
|
|
|
-- set state
|
|
|
|
e.value = val
|
2022-06-08 20:21:49 +00:00
|
|
|
draw_state()
|
2022-06-08 18:48:17 +00:00
|
|
|
end
|
|
|
|
|
2023-05-30 23:51:10 +00:00
|
|
|
return e.complete()
|
2022-06-08 18:48:17 +00:00
|
|
|
end
|
|
|
|
|
2022-06-08 20:21:49 +00:00
|
|
|
return switch_button
|