使用 wnck (python) 确定活动 window/应用程序失败
Determining active window / application with wnck (python) fails
在我的 python-脚本中,我必须确定实际活动的 window / 应用程序以对依赖于远程事件 (lirc) 的应用程序做出反应。所以我试着像 here 描述的那样重新定位它。但是测试代码
import wnck, time
run = True
while run:
try:
time.sleep(1)
screen = wnck.screen_get_default()
#screen.force_update()
print screen.get_active_window().get_name()
print screen.get_previously_active_window()
except KeyboardInterrupt:
run = False
此输出结果
.lirc : python — Konsole
None
.lirc : python — Konsole
None
.lirc : python — Konsole
None
.lirc : python — Konsole
None
.lirc : python — Konsole
None
即使我切换到另一个 window。因此我重复了执行并用 time.sleep(1)
延迟了它。由远程事件 (lirc) 执行,结果相同。只有在 python shell 范围内它才能工作(screen.get_previously_active_window()
有一个 / 正确的结果)。该脚本已在 Kubuntu 16.04 的终端 window (konsole) 中执行。我已测试插入 screen.force_update()
,但没有成功。
我做错了什么?
谢谢
我现在已经用 Xlib 解决了。这样它就可以独立工作。这是一个示例代码:
import Xlib
import Xlib.display
import time
run = True
while run:
try:
time.sleep(1)
display = Xlib.display.Display()
root = display.screen().root
windowID = root.get_full_property(display.intern_atom('_NET_ACTIVE_WINDOW'), Xlib.X.AnyPropertyType).value[0]
window = display.create_resource_object('window', windowID)
print window.get_wm_name()
print window.get_full_property(display.intern_atom('_NET_WM_PID'), Xlib.X.AnyPropertyType).value[0]
print window.get_full_property(display.intern_atom('_NET_WM_NAME'), Xlib.X.AnyPropertyType).value[0]
print window.get_full_property(display.intern_atom('_NET_WM_VISIBLE_NAME'), Xlib.X.AnyPropertyType)
print window.get_wm_class()
except KeyboardInterrupt:
run = False
显示了一些关于 window 的可能信息。在我的最终脚本中,我使用 window.get_wm_class()
.
在我的 python-脚本中,我必须确定实际活动的 window / 应用程序以对依赖于远程事件 (lirc) 的应用程序做出反应。所以我试着像 here 描述的那样重新定位它。但是测试代码
import wnck, time
run = True
while run:
try:
time.sleep(1)
screen = wnck.screen_get_default()
#screen.force_update()
print screen.get_active_window().get_name()
print screen.get_previously_active_window()
except KeyboardInterrupt:
run = False
此输出结果
.lirc : python — Konsole
None
.lirc : python — Konsole
None
.lirc : python — Konsole
None
.lirc : python — Konsole
None
.lirc : python — Konsole
None
即使我切换到另一个 window。因此我重复了执行并用 time.sleep(1)
延迟了它。由远程事件 (lirc) 执行,结果相同。只有在 python shell 范围内它才能工作(screen.get_previously_active_window()
有一个 / 正确的结果)。该脚本已在 Kubuntu 16.04 的终端 window (konsole) 中执行。我已测试插入 screen.force_update()
,但没有成功。
我做错了什么?
谢谢
我现在已经用 Xlib 解决了。这样它就可以独立工作。这是一个示例代码:
import Xlib
import Xlib.display
import time
run = True
while run:
try:
time.sleep(1)
display = Xlib.display.Display()
root = display.screen().root
windowID = root.get_full_property(display.intern_atom('_NET_ACTIVE_WINDOW'), Xlib.X.AnyPropertyType).value[0]
window = display.create_resource_object('window', windowID)
print window.get_wm_name()
print window.get_full_property(display.intern_atom('_NET_WM_PID'), Xlib.X.AnyPropertyType).value[0]
print window.get_full_property(display.intern_atom('_NET_WM_NAME'), Xlib.X.AnyPropertyType).value[0]
print window.get_full_property(display.intern_atom('_NET_WM_VISIBLE_NAME'), Xlib.X.AnyPropertyType)
print window.get_wm_class()
except KeyboardInterrupt:
run = False
显示了一些关于 window 的可能信息。在我的最终脚本中,我使用 window.get_wm_class()
.