summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--volumearc-widget/README.md25
-rw-r--r--volumearc-widget/out.gifbin0 -> 7288 bytes
-rw-r--r--volumearc-widget/volumearc.lua44
3 files changed, 44 insertions, 25 deletions
diff --git a/volumearc-widget/README.md b/volumearc-widget/README.md
index 56f4c7c..702b486 100644
--- a/volumearc-widget/README.md
+++ b/volumearc-widget/README.md
@@ -1,2 +1,25 @@
# Volumearc widget
-:hammer: Work in progress...:construction:
+
+Almost the same as [volumebar widget](https://github.com/streetturtle/awesome-wm-widgets/tree/master/volumebar-widget), but using arcchart:
+
+![screenshot](out.gif)
+
+Supports:
+ - scroll up - increase volume,
+ - scroll down - decrease volume,
+ - left click - mute/unmute.
+
+## Installation
+
+Clone repo, include widget and use it in **rc.lua**:
+
+```lua
+require("volumearc")
+...
+s.mytasklist, -- Middle widget
+ { -- Right widgets
+ layout = wibox.layout.fixed.horizontal,
+ ...
+ volumearc_widget,
+ ...
+```
diff --git a/volumearc-widget/out.gif b/volumearc-widget/out.gif
new file mode 100644
index 0000000..61fa486
--- /dev/null
+++ b/volumearc-widget/out.gif
Binary files differ
diff --git a/volumearc-widget/volumearc.lua b/volumearc-widget/volumearc.lua
index 54e2f4f..6ae5fe9 100644
--- a/volumearc-widget/volumearc.lua
+++ b/volumearc-widget/volumearc.lua
@@ -1,25 +1,20 @@
local awful = require("awful")
+local beautiful = require("beautiful")
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 {
--- {
--- id = "txt",
--- text = "1",
--- font = "Play 5",
--- widget = wibox.widget.textbox
--- },
+local GET_VOLUME_CMD = 'amixer -D pulse sget Master'
+local INC_VOLUME_CMD = 'amixer -D pulse sset Master 5%+'
+local DEC_VOLUME_CMD = 'amixer -D pulse sset Master 5%-'
+local TOG_VOLUME_CMD = 'amixer -D pulse sset Master toggle'
+
+local volumearc = wibox.widget {
max_value = 1,
- rounded_edge = true,
thickness = 2,
start_angle = 4.71238898, -- 2pi*3/4
- forced_height = 16,
- forced_width = 16,
+ forced_height = 17,
+ forced_width = 17,
bg = "#ffffff11",
paddings = 2,
widget = wibox.container.arcchart,
@@ -28,29 +23,30 @@ volumearc_widget = wibox.widget {
end,
}
+volumearc_widget = wibox.container.mirror(volumearc, { horizontal = true })
+
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))
widget.value = volume / 100;
--- widget.txt.text = volume;
if mute == "off" then
- widget.colors = { mute_color }
+ widget.colors = { beautiful.widget_red }
else
- widget.colors = { bar_color }
+ widget.colors = { beautiful.widget_main_color }
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)
+volumearc:connect_signal("button::press", function(_, _, _, button)
+ if (button == 4) then awful.spawn(INC_VOLUME_CMD, false)
+ elseif (button == 5) then awful.spawn(DEC_VOLUME_CMD, false)
+ elseif (button == 1) then awful.spawn(TOG_VOLUME_CMD, false)
end
- spawn.easy_async(request_command, function(stdout, stderr, exitreason, exitcode)
- update_graphic(volumearc_widget, stdout, stderr, exitreason, exitcode)
+ spawn.easy_async(GET_VOLUME_CMD, function(stdout, stderr, exitreason, exitcode)
+ update_graphic(volumearc, stdout, stderr, exitreason, exitcode)
end)
end)
-watch(request_command, 1, update_graphic, volumearc_widget)
+watch(GET_VOLUME_CMD, 1, update_graphic, volumearc)