commit
ff8f2aef27
|
@ -95,6 +95,7 @@ local function new(c, args)
|
||||||
local args = bars[position].args
|
local args = bars[position].args
|
||||||
ret:set_bg(get_color("bg", c, args))
|
ret:set_bg(get_color("bg", c, args))
|
||||||
ret:set_fg(get_color("fg", c, args))
|
ret:set_fg(get_color("fg", c, args))
|
||||||
|
ret:set_bgimage(get_color("bgimage", c, args))
|
||||||
end
|
end
|
||||||
|
|
||||||
bars[position] = {
|
bars[position] = {
|
||||||
|
|
|
@ -22,6 +22,7 @@ local timer = require("gears.timer")
|
||||||
local matrix = require("gears.matrix")
|
local matrix = require("gears.matrix")
|
||||||
local hierarchy = require("wibox.hierarchy")
|
local hierarchy = require("wibox.hierarchy")
|
||||||
local base = require("wibox.widget.base")
|
local base = require("wibox.widget.base")
|
||||||
|
local unpack = unpack or table.unpack
|
||||||
|
|
||||||
local drawables = setmetatable({}, { __mode = 'k' })
|
local drawables = setmetatable({}, { __mode = 'k' })
|
||||||
local wallpaper = nil
|
local wallpaper = nil
|
||||||
|
@ -70,18 +71,19 @@ local function do_redraw(self)
|
||||||
local cr = cairo.Context(surf)
|
local cr = cairo.Context(surf)
|
||||||
local geom = self.drawable:geometry();
|
local geom = self.drawable:geometry();
|
||||||
local x, y, width, height = geom.x, geom.y, geom.width, geom.height
|
local x, y, width, height = geom.x, geom.y, geom.width, geom.height
|
||||||
|
local context = get_widget_context(self)
|
||||||
|
|
||||||
-- Relayout
|
-- Relayout
|
||||||
if self._need_relayout or self._need_complete_repaint then
|
if self._need_relayout or self._need_complete_repaint then
|
||||||
self._need_relayout = false
|
self._need_relayout = false
|
||||||
if self._widget_hierarchy and self.widget then
|
if self._widget_hierarchy and self.widget then
|
||||||
self._widget_hierarchy:update(get_widget_context(self),
|
self._widget_hierarchy:update(context,
|
||||||
self.widget, width, height, self._dirty_area)
|
self.widget, width, height, self._dirty_area)
|
||||||
else
|
else
|
||||||
self._need_complete_repaint = true
|
self._need_complete_repaint = true
|
||||||
if self.widget then
|
if self.widget then
|
||||||
self._widget_hierarchy_callback_arg = {}
|
self._widget_hierarchy_callback_arg = {}
|
||||||
self._widget_hierarchy = hierarchy.new(get_widget_context(self), self.widget, width, height,
|
self._widget_hierarchy = hierarchy.new(context, self.widget, width, height,
|
||||||
self._redraw_callback, self._layout_callback, self._widget_hierarchy_callback_arg)
|
self._redraw_callback, self._layout_callback, self._widget_hierarchy_callback_arg)
|
||||||
else
|
else
|
||||||
self._widget_hierarchy = nil
|
self._widget_hierarchy = nil
|
||||||
|
@ -128,12 +130,24 @@ local function do_redraw(self)
|
||||||
|
|
||||||
cr:set_source(self.background_color)
|
cr:set_source(self.background_color)
|
||||||
cr:paint()
|
cr:paint()
|
||||||
|
|
||||||
|
-- Paint the background image
|
||||||
|
if self.background_image then
|
||||||
|
if type(self.background_image) == "function" then
|
||||||
|
self.background_image(context, cr, width, height, unpack(self.background_image_args))
|
||||||
|
else
|
||||||
|
local pattern = cairo.Pattern.create_for_surface(self.background_image)
|
||||||
|
cr:set_source(pattern)
|
||||||
|
cr:paint()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
cr:restore()
|
cr:restore()
|
||||||
|
|
||||||
-- Draw the widget
|
-- Draw the widget
|
||||||
if self._widget_hierarchy then
|
if self._widget_hierarchy then
|
||||||
cr:set_source(self.foreground_color)
|
cr:set_source(self.foreground_color)
|
||||||
self._widget_hierarchy:draw(get_widget_context(self), cr)
|
self._widget_hierarchy:draw(context, cr)
|
||||||
end
|
end
|
||||||
|
|
||||||
self.drawable:refresh()
|
self.drawable:refresh()
|
||||||
|
@ -199,7 +213,9 @@ end
|
||||||
-- nil or a string that gears.color() understands.
|
-- nil or a string that gears.color() understands.
|
||||||
function drawable:set_bg(c)
|
function drawable:set_bg(c)
|
||||||
local c = c or "#000000"
|
local c = c or "#000000"
|
||||||
if type(c) == "string" or type(c) == "table" then
|
local t = type(c)
|
||||||
|
|
||||||
|
if t == "string" or t == "table" then
|
||||||
c = color(c)
|
c = color(c)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -224,6 +240,18 @@ function drawable:set_bg(c)
|
||||||
self._do_complete_repaint()
|
self._do_complete_repaint()
|
||||||
end
|
end
|
||||||
|
|
||||||
|
--- Set the background image of the drawable
|
||||||
|
-- If `image` is a function, it will be called with `(context, cr, width, height)`
|
||||||
|
-- as arguments. Any other arguments passed to this method will be appended.
|
||||||
|
-- @param image A background image or a function
|
||||||
|
function drawable:set_bgimage(image, ...)
|
||||||
|
|
||||||
|
self.background_image = image
|
||||||
|
self.background_image_args = {...}
|
||||||
|
|
||||||
|
self._do_complete_repaint()
|
||||||
|
end
|
||||||
|
|
||||||
--- Set the foreground of the drawable
|
--- Set the foreground of the drawable
|
||||||
-- @param c The foreground to use. This must either be a cairo pattern object,
|
-- @param c The foreground to use. This must either be a cairo pattern object,
|
||||||
-- nil or a string that gears.color() understands.
|
-- nil or a string that gears.color() understands.
|
||||||
|
|
|
@ -51,6 +51,14 @@ function wibox:set_bg(c)
|
||||||
self._drawable:set_bg(c)
|
self._drawable:set_bg(c)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
--- Set the background image of the drawable
|
||||||
|
-- If `image` is a function, it will be called with `(context, cr, width, height)`
|
||||||
|
-- as arguments. Any other arguments passed to this method will be appended.
|
||||||
|
-- @param image A background image or a function
|
||||||
|
function wibox:set_bgimage(image, ...)
|
||||||
|
self._drawable:set_bgimage(image, ...)
|
||||||
|
end
|
||||||
|
|
||||||
--- Set the foreground of the wibox
|
--- Set the foreground of the wibox
|
||||||
-- @param c The foreground to use. This must either be a cairo pattern object,
|
-- @param c The foreground to use. This must either be a cairo pattern object,
|
||||||
-- nil or a string that gears.color() understands.
|
-- nil or a string that gears.color() understands.
|
||||||
|
|
|
@ -43,10 +43,14 @@ function background:draw(context, cr, width, height)
|
||||||
cr:paint()
|
cr:paint()
|
||||||
end
|
end
|
||||||
if self.bgimage then
|
if self.bgimage then
|
||||||
|
if type(self.bgimage) == "function" then
|
||||||
|
self.bgimage(context, cr, width, height,unpack(self.bgimage_args))
|
||||||
|
else
|
||||||
local pattern = cairo.Pattern.create_for_surface(self.bgimage)
|
local pattern = cairo.Pattern.create_for_surface(self.bgimage)
|
||||||
cr:set_source(pattern)
|
cr:set_source(pattern)
|
||||||
cr:paint()
|
cr:paint()
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -153,8 +157,12 @@ function background:set_shape_border_color(fg)
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Set the background image to use
|
--- Set the background image to use
|
||||||
function background:set_bgimage(image)
|
-- If `image` is a function, it will be called with `(context, cr, width, height)`
|
||||||
self.bgimage = surface.load(image)
|
-- as arguments. Any other arguments passed to this method will be appended.
|
||||||
|
-- @param image A background image or a function
|
||||||
|
function background:set_bgimage(image, ...)
|
||||||
|
self.bgimage = type(image) == "function" and image or surface.load(image)
|
||||||
|
self.bgimage_args = {...}
|
||||||
self:emit_signal("widget::redraw_needed")
|
self:emit_signal("widget::redraw_needed")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue