tests: Improve wibox.widget.background documentation

This commit is contained in:
Emmanuel Lepage Vallee 2016-03-29 00:42:31 -04:00
parent c62116f505
commit c64c223ede
1 changed files with 27 additions and 12 deletions

View File

@ -1,4 +1,6 @@
--------------------------------------------------------------------------- ---------------------------------------------------------------------------
-- A container capable of changing the background color, foreground color
-- widget shape.
-- @author Uli Schlachter -- @author Uli Schlachter
-- @copyright 2010 Uli Schlachter -- @copyright 2010 Uli Schlachter
-- @release @AWESOME_VERSION@ -- @release @AWESOME_VERSION@
@ -17,7 +19,7 @@ local unpack = unpack or table.unpack -- luacheck: globals unpack (compatibility
local background = { mt = {} } local background = { mt = {} }
--- Draw this widget -- Draw this widget
function background:draw(context, cr, width, height) function background:draw(context, cr, width, height)
if not self.widget or not self.widget.visible then if not self.widget or not self.widget.visible then
return return
@ -67,7 +69,7 @@ function background:after_draw_children(_, cr)
end end
end end
--- Prepare drawing the children of this widget -- Prepare drawing the children of this widget
function background:before_draw_children(_, cr) function background:before_draw_children(_, cr)
if self.foreground then if self.foreground then
cr:set_source(self.foreground) cr:set_source(self.foreground)
@ -80,14 +82,14 @@ function background:before_draw_children(_, cr)
end end
end end
--- Layout this widget -- Layout this widget
function background:layout(_, width, height) function background:layout(_, width, height)
if self.widget then if self.widget then
return { base.place_widget_at(self.widget, 0, 0, width, height) } return { base.place_widget_at(self.widget, 0, 0, width, height) }
end end
end end
--- Fit this widget into the given area -- Fit this widget into the given area
function background:fit(context, width, height) function background:fit(context, width, height)
if not self.widget then if not self.widget then
return 0, 0 return 0, 0
@ -97,6 +99,8 @@ function background:fit(context, width, height)
end end
--- Set the widget that is drawn on top of the background --- Set the widget that is drawn on top of the background
-- @tparam widget widget The widget to be disaplayed inside of the background
-- area
function background:set_widget(widget) function background:set_widget(widget)
if widget then if widget then
base.check_widget(widget) base.check_widget(widget)
@ -105,20 +109,22 @@ function background:set_widget(widget)
self:emit_signal("widget::layout_changed") self:emit_signal("widget::layout_changed")
end end
--- Get the number of children element -- Get children element
-- @treturn table The children -- @treturn table The children
function background:get_children() function background:get_children()
return {self.widget} return {self.widget}
end end
--- Replace the layout children -- Replace the layout children
-- This layout only accept one children, all others will be ignored -- This layout only accept one children, all others will be ignored
-- @tparam table children A table composed of valid widgets -- @tparam table children A table composed of valid widgets
function background:set_children(children) function background:set_children(children)
self:set_widget(children[1]) self:set_widget(children[1])
end end
--- Set the background to use --- Set the background to use.
--@DOC_wibox_widget_background_bg_EXAMPLE@
-- @param bg A color string, pattern or gradient (see `gears.color`)
function background:set_bg(bg) function background:set_bg(bg)
if bg then if bg then
self.background = color(bg) self.background = color(bg)
@ -128,7 +134,9 @@ function background:set_bg(bg)
self:emit_signal("widget::redraw_needed") self:emit_signal("widget::redraw_needed")
end end
--- Set the foreground to use --- Set the foreground to use.
--@DOC_wibox_widget_background_fg_EXAMPLE@
-- @param fg A color string, pattern or gradient (see `gears.color`)
function background:set_fg(fg) function background:set_fg(fg)
if fg then if fg then
self.foreground = color(fg) self.foreground = color(fg)
@ -138,23 +146,29 @@ function background:set_fg(fg)
self:emit_signal("widget::redraw_needed") self:emit_signal("widget::redraw_needed")
end end
--- Set the background shape --- Set the background shape.
-- @param shape A function taking a context, width and height as arguments --
-- Any other arguments will be passed to the shape function -- Any other arguments will be passed to the shape function
--@DOC_wibox_widget_background_shape_EXAMPLE@
-- @param shape A function taking a context, width and height as arguments
function background:set_shape(shape, ...) function background:set_shape(shape, ...)
self._shape = shape self._shape = shape
self._shape_args = {...} self._shape_args = {...}
self:emit_signal("widget::redraw_needed") self:emit_signal("widget::redraw_needed")
end end
--- When a `shape` is set, also draw a border --- When a `shape` is set, also draw a border.
--
-- See `wibox.widget.background.set_shape` for an usage example.
-- @tparam number width The border width -- @tparam number width The border width
function background:set_shape_border_width(width) function background:set_shape_border_width(width)
self._shape_border_width = width self._shape_border_width = width
self:emit_signal("widget::redraw_needed") self:emit_signal("widget::redraw_needed")
end end
--- When a `shape` is set, also draw a border --- When a `shape` is set, also draw a border.
--
-- See `wibox.widget.background.set_shape` for an usage example.
-- @param[opt=self.foreground] fg The border color, pattern or gradient -- @param[opt=self.foreground] fg The border color, pattern or gradient
function background:set_shape_border_color(fg) function background:set_shape_border_color(fg)
self._shape_border_color = fg self._shape_border_color = fg
@ -162,6 +176,7 @@ function background:set_shape_border_color(fg)
end end
--- When a `shape` is set, make sure nothing is drawn outside of it. --- When a `shape` is set, make sure nothing is drawn outside of it.
--@DOC_wibox_widget_background_clip_EXAMPLE@
-- @tparam boolean value If the shape clip is enable -- @tparam boolean value If the shape clip is enable
function background:set_shape_clip(value) function background:set_shape_clip(value)
self._shape_clip = value self._shape_clip = value