lain/alsabar.md

2.9 KiB

<- widgets

Shows and controls alsa volume with a progressbar; provides tooltips, notifications, and color changes at mute/unmute switch.

volume = lain.widgets.alsabar()
  • Left click: Launch alsamixer in your terminal.
  • Right click: Mute/unmute.
  • Scroll wheel: Increase/decrase volume.

The function takes a table as optional argument, which can contain:

Variable Meaning Type Default
timeout Refresh timeout seconds int 4
settings User settings function empty function
width Bar width int 63
height Bar height int 1
ticks Set bar ticks on boolean true
ticks_size Ticks size int 7
vertical Set the bar vertical boolean false
channel Mixer channel string "Master"
step Step at which volume is increased/decreased string "5%"
colors Bar colors table see colors
notifications Notifications settings table see notifications

colors

Variable Meaning Type Default
background Bar backgrund color string beautiful.bg_normal
mute Bar mute color string "#EB8F8F"
unmute Bar unmute color string "#A4CE8A"

notifications

Variable Meaning Type Default
font Notifications font string The one defined in beautiful.font
font_size Notifications font size string "11"
color Notifications color string beautiful.fg_focus
bar_size Wibox height int 18

It's crucial to set notifications.bar_size to your mywibox[s] height.

settings can use the following variables:

Variable Meaning Type Values
volume_now.level Self explained int 0-100
volume_now.status Device status string "on", "off"

output table

Variable Meaning Type
bar The widget awful.widget.progressbar
channel Alsa channel string
step Increase/decrease step string
notify The notification function

You can control the widget with key bindings like these:

-- ALSA volume control
awful.key({ altkey }, "Up",
    function ()
        awful.util.spawn("amixer -q set " .. volume.channel .. " " .. volume.step .. "+")
        volume.notify()
    end),
awful.key({ altkey }, "Down",
    function ()
        awful.util.spawn("amixer -q set " .. volume.channel .. " " .. volume.step .. "-")
        volume.notify()
    end),
awful.key({ altkey }, "m",
    function ()
        awful.util.spawn("amixer -q set " .. volume.channel .. " playback toggle")
        volume.notify()
    end),
awful.key({ altkey, "Control" }, "m",
    function ()
        awful.util.spawn("amixer -q set " .. volume.channel .. " playback 100%")
        volume.notify()
    end),

where altkey = "Mod1".