diff options
| author | pmakhov <pavel.makhov@savoirfairelinux.com> | 2017-10-09 16:20:20 -0400 | 
|---|---|---|
| committer | pmakhov <pavel.makhov@savoirfairelinux.com> | 2017-10-09 16:20:20 -0400 | 
| commit | 4057e5c379f48c02f8997e307c607a9d4f0b5b85 (patch) | |
| tree | e6790c0c2bb12a30e0f18b0475f2cd04b87b93fd /volumearc-widget | |
| parent | ecc10522591d4501533c968ba3e7d1c3e7b59a26 (diff) | |
volumearc widget
Diffstat (limited to 'volumearc-widget')
| -rw-r--r-- | volumearc-widget/README.md | 25 | ||||
| -rw-r--r-- | volumearc-widget/out.gif | bin | 0 -> 7288 bytes | |||
| -rw-r--r-- | volumearc-widget/volumearc.lua | 44 | 
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: + + + +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 Binary files differnew file mode 100644 index 0000000..61fa486 --- /dev/null +++ b/volumearc-widget/out.gif 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)  | 
