Merge pull request #635 from ardadem/pr-amixer2

[modules] New amixer module with input support
This commit is contained in:
tobi-wan-kenobi 2020-05-28 08:20:28 +02:00 committed by GitHub
commit 006a1d05a9
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 103 additions and 0 deletions

View file

@ -0,0 +1,87 @@
"""get volume level or control it
Parameters:
* amixer.device: Device to use (default is Master,0)
* amixer.percent_change: How much to change volume by when scrolling on the module (default is 4%)
contributed by `zetxx <https://github.com/zetxx>`_ - many thanks!
"""
import re
import core.module
import core.widget
import core.input
import util.cli
import util.format
class Module(core.module.Module):
def __init__(self, config, theme):
super().__init__(config, theme, core.widget.Widget(self.volume))
self._level = "n/a"
self._muted = True
self._device = self.parameter("device", "Master,0")
self._change = util.format.asint(
self.parameter("percent_change", "4%").strip("%"), 0, 100
)
events = [
{
"type": "mute",
"action": self.toggle,
"button": core.input.LEFT_MOUSE,
},
{
"type": "volume",
"action": self.increase_volume,
"button": core.input.WHEEL_UP,
},
{
"type": "volume",
"action": self.decrease_volume,
"button": core.input.WHEEL_DOWN,
},
]
for event in events:
core.input.register(self, button=event["button"], cmd=event["action"])
def toggle(self, event):
self.set_parameter("toggle")
def increase_volume(self, event):
self.set_parameter("{}%+".format(self._change))
def decrease_volume(self, event):
self.set_parameter("{}%-".format(self._change))
def set_parameter(self, parameter):
util.cli.execute("amixer -q set {} {}".format(self._device, parameter))
def volume(self, widget):
if self._level == "n/a":
return self._level
m = re.search(r"([\d]+)\%", self._level)
self._muted = True
if m:
if m.group(1) != "0" and "[on]" in self._level:
self._muted = False
return "{}%".format(m.group(1))
else:
return "0%"
def update(self):
try:
self._level = util.cli.execute(
"amixer get {}".format(self._device)
)
except Exception as e:
self._level = "n/a"
def state(self, widget):
if self._muted:
return ["warning", "muted"]
return ["unmuted"]
# vim: tabstop=8 expandtab shiftwidth=4 softtabstop=4

View file

@ -72,6 +72,14 @@
"prefix": "audio" "prefix": "audio"
} }
}, },
"amixer2": {
"muted": {
"prefix": "audio(mute)"
},
"unmuted": {
"prefix": "audio"
}
},
"pasource": { "pasource": {
"muted": { "muted": {
"prefix": "mic(mute)" "prefix": "mic(mute)"

View file

@ -73,6 +73,10 @@
"muted": { "prefix": "" }, "muted": { "prefix": "" },
"unmuted": { "prefix": "" } "unmuted": { "prefix": "" }
}, },
"amixer2": {
"muted": { "prefix": "" },
"unmuted": { "prefix": "" }
},
"pasource": { "pasource": {
"muted": { "prefix": "" }, "muted": { "prefix": "" },
"unmuted": { "prefix": "" } "unmuted": { "prefix": "" }

View file

@ -55,6 +55,10 @@
"muted": { "prefix": "\uf3b9" }, "muted": { "prefix": "\uf3b9" },
"unmuted": { "prefix": "\uf3ba" } "unmuted": { "prefix": "\uf3ba" }
}, },
"amixer2": {
"muted": { "prefix": "\uf3b9" },
"unmuted": { "prefix": "\uf3ba" }
},
"pasource": { "pasource": {
"muted": { "prefix": "\uf395" }, "muted": { "prefix": "\uf395" },
"unmuted": { "prefix": "\uf2ec" } "unmuted": { "prefix": "\uf2ec" }