2

在我的 python 脚本中,我必须确定实际的活动窗口/应用程序以对依赖于远程事件(lirc)的应用程序做出反应。所以我试着像这里描述的那样重新定义它。但是测试代码

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) 中执行。我已经测试过 insert screen.force_update(),但没有成功。

我做错了什么?

谢谢

4

1 回答 1

3

我现在用 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().

于 2017-08-28T15:22:30.183 回答