mirror of
https://github.com/swaywm/sway.git
synced 2026-04-23 06:46:27 -04:00
feat: option to set focused window opacity
This commit is contained in:
parent
c6e7cf1ae5
commit
a846565d58
1 changed files with 18 additions and 18 deletions
|
|
@ -11,37 +11,30 @@ import signal
|
||||||
import sys
|
import sys
|
||||||
from functools import partial
|
from functools import partial
|
||||||
|
|
||||||
def on_window_focus(inactive_opacity, ipc, event):
|
def on_window_focus(not_focused_opacity, focused_opacity, ipc, event):
|
||||||
global prev_focused
|
global prev_focused
|
||||||
global prev_workspace
|
global prev_workspace
|
||||||
|
|
||||||
focused_workspace = ipc.get_tree().find_focused()
|
|
||||||
|
|
||||||
if focused_workspace == None:
|
|
||||||
return
|
|
||||||
|
|
||||||
focused = event.container
|
focused = event.container
|
||||||
workspace = focused_workspace.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 1")
|
focused.command("opacity " + focused_opacity)
|
||||||
if workspace == prev_workspace:
|
if workspace == prev_workspace:
|
||||||
prev_focused.command("opacity " + inactive_opacity)
|
prev_focused.command("opacity " + not_focused_opacity)
|
||||||
prev_focused = focused
|
prev_focused = focused
|
||||||
prev_workspace = workspace
|
prev_workspace = workspace
|
||||||
|
|
||||||
|
|
||||||
def remove_opacity(ipc):
|
def restore_opacity(ipc, opacity):
|
||||||
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 1")
|
w.command("opacity " + opacity)
|
||||||
ipc.main_quit()
|
ipc.main_quit()
|
||||||
sys.exit(0)
|
sys.exit(0)
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
transparency_val = "0.80"
|
|
||||||
|
|
||||||
parser = argparse.ArgumentParser(
|
parser = argparse.ArgumentParser(
|
||||||
description="This script allows you to set the transparency of unfocused windows in sway."
|
description="This script allows you to set the transparency of unfocused windows in sway."
|
||||||
)
|
)
|
||||||
|
|
@ -49,8 +42,15 @@ if __name__ == "__main__":
|
||||||
"--opacity",
|
"--opacity",
|
||||||
"-o",
|
"-o",
|
||||||
type=str,
|
type=str,
|
||||||
default=transparency_val,
|
default="0.80",
|
||||||
help="set opacity value in range 0...1",
|
help="set unfocused window opacity value in range 0...1",
|
||||||
|
)
|
||||||
|
parser.add_argument(
|
||||||
|
"--focused-opacity",
|
||||||
|
"-f",
|
||||||
|
type=str,
|
||||||
|
default="1.00",
|
||||||
|
help="set focused window opacity value in range 0...1",
|
||||||
)
|
)
|
||||||
args = parser.parse_args()
|
args = parser.parse_args()
|
||||||
|
|
||||||
|
|
@ -64,6 +64,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: remove_opacity(ipc))
|
signal.signal(sig, lambda signal, frame: restore_opacity(ipc, args.focused_opacity))
|
||||||
ipc.on("window::focus", partial(on_window_focus, args.opacity))
|
ipc.on("window::focus", partial(on_window_focus, args.opacity, args.focused_opacity))
|
||||||
ipc.main()
|
ipc.main()
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue