From 91cc8519b54ae8074ee00f8e2441a7e47a1b129c Mon Sep 17 00:00:00 2001 From: Uli Schlachter Date: Sun, 23 Feb 2014 12:19:26 +0100 Subject: [PATCH] wibox.drawable: Cache the wallpaper Signed-off-by: Uli Schlachter --- lib/wibox/drawable.lua.in | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/lib/wibox/drawable.lua.in b/lib/wibox/drawable.lua.in index 3f73c73d..8458e5c0 100644 --- a/lib/wibox/drawable.lua.in +++ b/lib/wibox/drawable.lua.in @@ -17,6 +17,7 @@ local sort = require("gears.sort") local surface = require("gears.surface") local drawables = setmetatable({}, { __mode = 'k' }) +local wallpaper = nil local function do_redraw(self) local surf = surface(self.drawable.surface) @@ -31,7 +32,9 @@ local function do_redraw(self) if not capi.awesome.composite_manager_running then -- This is pseudo-transparency: We draw the wallpaper in the background - local wallpaper = surface(capi.root.wallpaper()) + if not wallpaper then + wallpaper = surface(capi.root.wallpaper()) + end if wallpaper then cr.operator = cairo.Operator.SOURCE cr:set_source_surface(wallpaper, -x, -y) @@ -39,6 +42,7 @@ local function do_redraw(self) end cr.operator = cairo.Operator.OVER else + -- This is true transparency: We draw a translucent background cr.operator = cairo.Operator.SOURCE end @@ -269,6 +273,7 @@ end -- Redraw all drawables when the wallpaper changes capi.awesome.connect_signal("wallpaper_changed", function() local k + wallpaper = nil for k in pairs(drawables) do k() end