mirror of
https://github.com/swaywm/sway.git
synced 2026-04-23 06:46:27 -04:00
feat: add checking match regexp on focused opacity
This commit is contained in:
parent
a846565d58
commit
7845cbd275
1 changed files with 17 additions and 6 deletions
|
|
@ -9,9 +9,10 @@ import argparse
|
||||||
import i3ipc
|
import i3ipc
|
||||||
import signal
|
import signal
|
||||||
import sys
|
import sys
|
||||||
|
import re
|
||||||
from functools import partial
|
from functools import partial
|
||||||
|
|
||||||
def on_window_focus(not_focused_opacity, focused_opacity, ipc, event):
|
def on_window_focus(not_focused_opacity, focused_opacity, focused_regex, ipc, event):
|
||||||
global prev_focused
|
global prev_focused
|
||||||
global prev_workspace
|
global prev_workspace
|
||||||
|
|
||||||
|
|
@ -19,17 +20,21 @@ def on_window_focus(not_focused_opacity, focused_opacity, ipc, event):
|
||||||
workspace = ipc.get_tree().find_focused().workspace().num
|
workspace = ipc.get_tree().find_focused().workspace().num
|
||||||
|
|
||||||
if focused.id != prev_focused.id: # https://github.com/swaywm/sway/issues/2859
|
if focused.id != prev_focused.id: # https://github.com/swaywm/sway/issues/2859
|
||||||
focused.command("opacity " + focused_opacity)
|
if re.match(focused_regex, focused.app_id):
|
||||||
|
focused.command("opacity " + focused_opacity)
|
||||||
|
else:
|
||||||
|
focused.command("opacity 1")
|
||||||
|
|
||||||
if workspace == prev_workspace:
|
if workspace == prev_workspace:
|
||||||
prev_focused.command("opacity " + not_focused_opacity)
|
prev_focused.command("opacity " + not_focused_opacity)
|
||||||
prev_focused = focused
|
prev_focused = focused
|
||||||
prev_workspace = workspace
|
prev_workspace = workspace
|
||||||
|
|
||||||
|
|
||||||
def restore_opacity(ipc, opacity):
|
def restore_opacity(ipc):
|
||||||
for workspace in ipc.get_tree().workspaces():
|
for workspace in ipc.get_tree().workspaces():
|
||||||
for w in workspace:
|
for w in workspace:
|
||||||
w.command("opacity " + opacity)
|
w.command("opacity 1")
|
||||||
ipc.main_quit()
|
ipc.main_quit()
|
||||||
sys.exit(0)
|
sys.exit(0)
|
||||||
|
|
||||||
|
|
@ -52,6 +57,12 @@ if __name__ == "__main__":
|
||||||
default="1.00",
|
default="1.00",
|
||||||
help="set focused window opacity value in range 0...1",
|
help="set focused window opacity value in range 0...1",
|
||||||
)
|
)
|
||||||
|
parser.add_argument(
|
||||||
|
"--focused-appid",
|
||||||
|
type=str,
|
||||||
|
default=".*",
|
||||||
|
help="set focused window opacity only for app_ids which match this regexp",
|
||||||
|
)
|
||||||
args = parser.parse_args()
|
args = parser.parse_args()
|
||||||
|
|
||||||
ipc = i3ipc.Connection()
|
ipc = i3ipc.Connection()
|
||||||
|
|
@ -64,6 +75,6 @@ if __name__ == "__main__":
|
||||||
else:
|
else:
|
||||||
window.command("opacity " + args.opacity)
|
window.command("opacity " + args.opacity)
|
||||||
for sig in [signal.SIGINT, signal.SIGTERM]:
|
for sig in [signal.SIGINT, signal.SIGTERM]:
|
||||||
signal.signal(sig, lambda signal, frame: restore_opacity(ipc, args.focused_opacity))
|
signal.signal(sig, lambda signal, frame: restore_opacity(ipc))
|
||||||
ipc.on("window::focus", partial(on_window_focus, args.opacity, args.focused_opacity))
|
ipc.on("window::focus", partial(on_window_focus, args.opacity, args.focused_opacity, args.focused_appid))
|
||||||
ipc.main()
|
ipc.main()
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue