Add gui.core.(disable|clear)KeyFocus
This commit is contained in:
parent
370c10c787
commit
465aaf1885
2 changed files with 32 additions and 21 deletions
|
@ -17,6 +17,11 @@ Quickie is an [immediate mode gui][IMGUI] library for [LÖVE][LOVE]
|
|||
-- checkboxes have only a `checked' status
|
||||
local checkbox = {checked = false}
|
||||
|
||||
function love.load()
|
||||
-- disable tabbing through the widgets
|
||||
gui.core.disableKeyFocus()
|
||||
end
|
||||
|
||||
function love.update(dt)
|
||||
-- widgets are defined by simply calling them. usually a widget returns true if
|
||||
-- if its value changed or if it was activated (click on button, ...)
|
||||
|
@ -37,8 +42,8 @@ Quickie is an [immediate mode gui][IMGUI] library for [LÖVE][LOVE]
|
|||
end
|
||||
|
||||
function love.keypressed(key,code)
|
||||
-- forward keyboard events to the gui. If you don't want widget tabbing and
|
||||
-- input widgets, skip this line
|
||||
-- forward keyboard events to the gui. If you don't want keyboard support
|
||||
-- skip this line
|
||||
gui.core.keyboard.pressed(key, code)
|
||||
end
|
||||
|
||||
|
|
44
core.lua
44
core.lua
|
@ -17,6 +17,9 @@ local function isActive(id) return context.active == id end
|
|||
local function setKeyFocus(id) context.keyfocus = id end
|
||||
local function hasKeyFocus(id) return context.keyfocus == id end
|
||||
|
||||
local function disableKeyFocus() return setKeyFocus{} end
|
||||
local function clearKeyFocus() return setKeyFocus(nil) end
|
||||
|
||||
-- input
|
||||
local mouse = {x = 0, y = 0, down = false}
|
||||
local keyboard = {key = nil, code = -1}
|
||||
|
@ -50,7 +53,7 @@ end
|
|||
|
||||
function keyboard.tryGrab(id)
|
||||
if not context.keyfocus then
|
||||
context.keyfocus = id
|
||||
setKeyFocus(id)
|
||||
end
|
||||
end
|
||||
|
||||
|
@ -136,25 +139,28 @@ local function draw()
|
|||
end
|
||||
|
||||
return {
|
||||
mouse = mouse,
|
||||
keyboard = keyboard,
|
||||
mouse = mouse,
|
||||
keyboard = keyboard,
|
||||
|
||||
generateID = generateID,
|
||||
setHot = setHot,
|
||||
setActive = setActive,
|
||||
setKeyFocus = setKeyFocus,
|
||||
isHot = isHot,
|
||||
isActive = isActive,
|
||||
hasKeyFocus = hasKeyFocus,
|
||||
makeCyclable = makeCyclable,
|
||||
generateID = generateID,
|
||||
setHot = setHot,
|
||||
setActive = setActive,
|
||||
setKeyFocus = setKeyFocus,
|
||||
isHot = isHot,
|
||||
isActive = isActive,
|
||||
hasKeyFocus = hasKeyFocus,
|
||||
|
||||
style = require((...):match("(.-)[^%.]+$") .. '.style-default'),
|
||||
color = color,
|
||||
registerDraw = registerDraw,
|
||||
draw = draw,
|
||||
disableKeyFocus = disableKeyFocus,
|
||||
clearKeyFocus = clearKeyFocus,
|
||||
makeCyclable = makeCyclable,
|
||||
|
||||
strictAnd = strictAnd,
|
||||
strictOr = strictOr,
|
||||
save_pack = save_pack,
|
||||
save_unpack = save_unpack,
|
||||
style = require((...):match("(.-)[^%.]+$") .. '.style-default'),
|
||||
color = color,
|
||||
registerDraw = registerDraw,
|
||||
draw = draw,
|
||||
|
||||
strictAnd = strictAnd,
|
||||
strictOr = strictOr,
|
||||
save_pack = save_pack,
|
||||
save_unpack = save_unpack,
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue