在我的python脚本中,我必须确定实际的活动窗口/应用程序,以响应依赖于远程事件(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
即使我切换到另一个窗口。因此,我重复执行并将其延迟time.sleep(1)
。由远程事件(lirc)执行,结果是相同的。只有在python shell中它才能使用(screen.get_previously_active_window()
有一个/正确的结果)。该脚本已在Kubuntu 16.04的终端窗口(konsole)中执行。我已经测试过插入screen.force_update()
,但没有成功。
我做错了什么?
由于
答案 0 :(得分:1)
我现在用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.get_wm_class()
。