diff options
author | pmakhov <pavel.makhov@savoirfairelinux.com> | 2017-10-04 15:15:50 -0400 |
---|---|---|
committer | pmakhov <pavel.makhov@savoirfairelinux.com> | 2017-10-04 15:15:50 -0400 |
commit | f6fbb8fd35b50dcbbd057ffdeea7e73a0c56aa2b (patch) | |
tree | ebdb69269899b4cc0f3baf81bc47f50369b40632 | |
parent | 7fab9b29599cd4b783431b36d783a8315df1ac91 (diff) |
new volumearc widget!
-rw-r--r-- | volumearc-widget/volumearc.lua | 50 |
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) |