2021-07-04 17:24:00 +02:00
|
|
|
---------------------------------------------------------------------------
|
|
|
|
-- An implementation of my battery_widget widget with a dynamicly generated
|
|
|
|
-- icon based on the battery percentage level.
|
|
|
|
--
|
|
|
|
-- Find more about my battery_widget widget at
|
|
|
|
-- https://github.com/Aire-One/awesome-battery_widget
|
|
|
|
--
|
|
|
|
-- @author Aire-One
|
|
|
|
-- @copyright 2020 Aire-One
|
|
|
|
---------------------------------------------------------------------------
|
2021-11-29 18:53:23 +01:00
|
|
|
local lgi = require "lgi"
|
2021-07-04 17:24:00 +02:00
|
|
|
local cairo = lgi.cairo
|
|
|
|
local rsvg = lgi.Rsvg
|
|
|
|
|
2021-11-29 18:53:23 +01:00
|
|
|
local atooltip = require "awful.tooltip"
|
|
|
|
local beautiful = require "beautiful"
|
|
|
|
local gcolor = require "gears.color"
|
|
|
|
local imagebox = require "wibox.widget.imagebox"
|
2021-07-04 17:24:00 +02:00
|
|
|
|
2021-11-29 18:53:23 +01:00
|
|
|
local battery_widget = require "battery-widget"
|
2021-07-04 17:24:00 +02:00
|
|
|
|
|
|
|
local my_battery = {}
|
|
|
|
local mt = {}
|
|
|
|
|
|
|
|
--- Generate a drawing for the battery icon.
|
|
|
|
-- @tparam number percentage The percentage of battery remaining.
|
|
|
|
-- @tparam gears.color|string color The color of the drawing.
|
|
|
|
-- @treturn cairo.ImageSurface The generated surface for the drawing.
|
2021-11-29 18:53:23 +01:00
|
|
|
function my_battery.draw_battery(percentage, color)
|
2021-07-04 17:24:00 +02:00
|
|
|
local svg_handle = rsvg.Handle.new_from_file(beautiful.icon_battery_outline)
|
2021-11-29 18:53:23 +01:00
|
|
|
if not svg_handle then
|
|
|
|
return
|
|
|
|
end
|
2021-07-04 17:24:00 +02:00
|
|
|
local surface = cairo.ImageSurface.create(cairo.Format.ARGB32, 24, 24)
|
|
|
|
local cr = cairo.Context(surface)
|
|
|
|
svg_handle:render_cairo(cr)
|
|
|
|
|
|
|
|
local max_height = 14
|
|
|
|
local x = 8
|
|
|
|
local width = 8
|
|
|
|
local height = percentage / 100 * max_height
|
|
|
|
local y = 6 + max_height - height
|
|
|
|
|
|
|
|
cr:set_source(gcolor(color))
|
|
|
|
cr:rectangle(x, y, width, height)
|
|
|
|
cr:fill()
|
|
|
|
|
|
|
|
return surface
|
|
|
|
end
|
|
|
|
|
|
|
|
--- Update handler for the battery widget. This is the function called
|
|
|
|
-- by the signal system on battery update.
|
|
|
|
-- @tparam my_battery widget The battery widget to update.
|
|
|
|
-- @tparam UPowerGLib.Device device The UPower device to monitor.
|
2021-11-29 18:53:23 +01:00
|
|
|
function my_battery.update(widget, device)
|
2021-07-04 17:24:00 +02:00
|
|
|
widget.image = my_battery.draw_battery(device.percentage, widget.color)
|
|
|
|
end
|
|
|
|
|
|
|
|
--- Give the widget template for the battery widget.
|
|
|
|
-- (It's a basic `wibox.widget.imagebox` for my battery implementation)
|
2021-11-29 18:53:23 +01:00
|
|
|
function my_battery.widget_template()
|
2021-07-04 17:24:00 +02:00
|
|
|
local widget = imagebox()
|
|
|
|
widget.resize = true
|
|
|
|
|
|
|
|
return widget
|
|
|
|
end
|
|
|
|
|
|
|
|
--- Constructor of my battery widget!
|
|
|
|
-- @tparam table args Table of parameters.
|
|
|
|
-- @tparam screen|number args.screen The screen of the wodget.
|
|
|
|
-- @tparam string args.device_path The path of the UPower device to monitor.
|
|
|
|
-- @tparam gears.color|string args.color Color to use to draw the battery.
|
|
|
|
-- @treturn my_battery The instantiated widget.
|
2021-11-29 18:53:23 +01:00
|
|
|
function my_battery.new(args)
|
2021-07-04 17:24:00 +02:00
|
|
|
local widget = battery_widget {
|
|
|
|
screen = args.screen,
|
|
|
|
device_path = args.device_path,
|
|
|
|
widget_template = my_battery.widget_template(),
|
2021-11-29 18:53:23 +01:00
|
|
|
instant_update = true,
|
2021-07-04 17:24:00 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
widget.color = args.color
|
|
|
|
|
2021-11-29 18:53:23 +01:00
|
|
|
widget:connect_signal("upower::update", function(w, device)
|
2021-07-04 17:24:00 +02:00
|
|
|
my_battery.update(w, device)
|
|
|
|
end)
|
|
|
|
|
|
|
|
widget.tooltip = atooltip {
|
|
|
|
objects = { widget },
|
2021-11-29 18:53:23 +01:00
|
|
|
timer_function = function()
|
|
|
|
return string.format("%3d", widget.device.percentage) .. "%"
|
|
|
|
end,
|
2021-07-04 17:24:00 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return widget
|
|
|
|
end
|
|
|
|
|
2021-11-29 18:53:23 +01:00
|
|
|
function mt:__call(...)
|
2021-07-04 17:24:00 +02:00
|
|
|
return my_battery.new(...)
|
|
|
|
end
|
|
|
|
|
|
|
|
return setmetatable(my_battery, mt)
|