2
0
mirror of https://github.com/koreader/koreader synced 2024-11-13 19:11:25 +00:00
koreader/frontend/ui/widget/closebutton.lua

87 lines
2.4 KiB
Lua
Raw Normal View History

--[[--
Button widget that shows an "×" and handles closing window when tapped
Example:
2016-02-16 07:21:36 +00:00
local CloseButton = require("ui/widget/closebutton")
local parent_widget = OverlapGroup:new{}
table.insert(parent_widget, CloseButton:new{
window = parent_widget,
})
UIManager:show(parent_widget)
]]
2017-04-29 08:38:09 +00:00
local Font = require("ui/font")
local FrameContainer = require("ui/widget/container/framecontainer")
2017-04-29 08:38:09 +00:00
local GestureRange = require("ui/gesturerange")
local InputContainer = require("ui/widget/container/inputcontainer")
local TextWidget = require("ui/widget/textwidget")
local Screen = require("device").screen
local CloseButton = InputContainer:new{
overlap_align = "right",
2014-03-13 13:52:43 +00:00
window = nil,
padding_left = Screen:scaleBySize(14), -- for larger touch area
padding_right = 0,
padding_top = 0,
padding_bottom = 0,
}
function CloseButton:init()
2014-03-13 13:52:43 +00:00
local text_widget = TextWidget:new{
text = "×",
face = Font:getFace("cfont", 30),
2014-03-13 13:52:43 +00:00
}
-- The text box height is greater than its width, and we want this × to be
-- diagonally aligned with the top right corner (assuming padding_right=0,
-- or padding_right = padding_top so the diagonal aligment is preserved).
local text_size = text_widget:getSize()
local text_width_pad = (text_size.h - text_size.w) / 2
2014-03-13 13:52:43 +00:00
self[1] = FrameContainer:new{
bordersize = 0,
padding = 0,
padding_top = self.padding_top,
padding_bottom = self.padding_bottom,
padding_left = self.padding_left,
padding_right = self.padding_right + text_width_pad,
text_widget,
2014-03-13 13:52:43 +00:00
}
2015-04-27 00:49:27 +00:00
2014-03-13 13:52:43 +00:00
self.ges_events.Close = {
GestureRange:new{
ges = "tap",
-- x and y coordinates for the widget is only known after the it is
-- drawn. so use callback to get range at runtime.
range = function() return self.dimen end,
2014-03-13 13:52:43 +00:00
},
doc = "Tap on close button",
}
self.ges_events.HoldClose = {
GestureRange:new{
ges = "hold_release",
range = function() return self.dimen end,
},
doc = "Hold on close button",
}
end
function CloseButton:onClose()
if self.window.onClose then
self.window:onClose()
end
return true
end
function CloseButton:onHoldClose()
if self.window.onHoldClose then
self.window:onHoldClose()
end
2014-03-13 13:52:43 +00:00
return true
end
return CloseButton