summaryrefslogtreecommitdiff
path: root/volumearc-widget
diff options
context:
space:
mode:
authorpmakhov <pavel.makhov@savoirfairelinux.com>2017-10-04 15:15:50 -0400
committerpmakhov <pavel.makhov@savoirfairelinux.com>2017-10-04 15:15:50 -0400
commitf6fbb8fd35b50dcbbd057ffdeea7e73a0c56aa2b (patch)
treeebdb69269899b4cc0f3baf81bc47f50369b40632 /volumearc-widget
parent7fab9b29599cd4b783431b36d783a8315df1ac91 (diff)
new volumearc widget!
Diffstat (limited to 'volumearc-widget')
-rw-r--r--volumearc-widget/volumearc.lua50
1 files changed, 50 insertions, 0 deletions
diff --git a/volumearc-widget/volumearc.lua b/volumearc-widget/volumearc.lua
new file mode 100644
index 0000000..2c1044b
--- /dev/null
+++ b/volumearc-widget/volumearc.lua
@@ -0,0 +1,50 @@
+local awful = require("awful")
+local spawn = require("awful.spawn")
+local watch = require("awful.widget.watch")
+local wibox = require("wibox")
+
+local request_command = 'amixer -D pulse sget Master'
+local bar_color = "#74aeab"
+local mute_color = "#ff0000"
+
+volumearc_widget = wibox.widget {
+ max_value = 1,
+ rounded_edge = true,
+ thickness = 2,
+ start_angle = 4.71238898, -- 2pi*3/4
+ forced_height = 16,
+ forced_width = 16,
+ bg = "#ffffff11",
+ paddings = 2,
+ widget = wibox.container.arcchart,
+ set_value = function(self, value)
+ self.value = value
+ end,
+}
+
+local update_graphic = function(widget, stdout, _, _, _)
+ local mute = string.match(stdout, "%[(o%D%D?)%]")
+ local volume = string.match(stdout, "(%d?%d?%d)%%")
+ volume = tonumber(string.format("% 3d", volume))
+
+ if mute == "off" then
+ widget.colors = { mute_color }
+ widget.value = volume / 100;
+ else
+ widget.colors = { bar_color }
+ widget.value = volume / 100;
+ end
+end
+
+volumearc_widget:connect_signal("button::press", function(_, _, _, button)
+ if (button == 4) then awful.spawn("amixer -D pulse sset Master 5%+", false)
+ elseif (button == 5) then awful.spawn("amixer -D pulse sset Master 5%-", false)
+ elseif (button == 1) then awful.spawn("amixer -D pulse sset Master toggle", false)
+ end
+
+ spawn.easy_async(request_command, function(stdout, stderr, exitreason, exitcode)
+ update_graphic(volumearc_widget, stdout, stderr, exitreason, exitcode)
+ end)
+end)
+
+watch(request_command, 1, update_graphic, volumearc_widget)