在我的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中,它才会接缝工作(在那里,screen.get_previously_active_window()有一个/正确的结果)。脚本已在Kubuntu 16.04的终端窗口(konsole)内执行。我已经测试过插入screen.force_update(),但没有成功。
我做错什么了?
谢谢
发布于 2017-08-28 15:22:30
我现在用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()。
https://stackoverflow.com/questions/45862824
复制相似问题