如何测试是否已创建GTK +对话框?

时间:2015-09-04 15:42:10

标签: python testing dialog gtk3 wnck

我已经使用Wnck来检查是否已经创建了一个窗口:

    screen = Wnck.Screen.get_default()
    screen.force_update()  # recommended per Wnck documentation
    window_list = screen.get_windows()

    for window in window_list:
        print(window.get_name())
        if window.has_name():
            if window.get_name() == self.xld_main_window.get_title():
                window_found = True
                break
    assert window_found, 'The Gtk.Window named {window_name} has not been found.'\
        .format(window_name=self.xld_main_window.get_title())

    # clean up Wnck (saves resources, check documentation)
    window = None
    screen = None

但是,由于对话框没有显示在任务列表中,我无法通过这种方式找到它们。检查它们是否显示(和模态/非模态)的适当方法是什么?

2 个答案:

答案 0 :(得分:1)

Wnck.Screen.get_windows方法返回所有窗口,包括对话框。没有区别,因为该函数返回当前映射的任何Wnck.Window。消息来源是这样的:

* The #WnckScreen represents a physical screen. A screen may consist of
* multiple monitors which are merged to form a large screen area. The
* #WnckScreen is at the bottom of the libwnck stack of objects: #WnckWorkspace
* objects exist a #WnckScreen and #WnckWindow objects are displayed on a
* #WnckWorkspace.
*
* The #WnckScreen corresponds to the notion of
* <classname>GdkScreen</classname> in GDK.

GList*
wnck_screen_get_windows (WnckScreen *screen)
{
  g_return_val_if_fail (WNCK_IS_SCREEN (screen), NULL);

  return screen->priv->mapped_windows;
}

其中screen->priv指向包含一些窗口列表(映射,堆叠)的struct,指向活动窗口的指针等。某些WnckWindow可以WNCK_WINDOW_DIALOG设置并成为一个对话框。

WnckWindow类还提供了一个函数transient_is_most_recently_activated(),以便在WnckTaskList中选择时,焦点应该转移到临时子窗口,还是最小化其父窗口的瞬态窗口。例如,要知道更好的My Application窗口有一个最近激活的瞬态:

screen = Wnck.Screen.get_default()
screen.force_update()  # recommended per Wnck documentation
window_list = screen.get_windows()

for window in window_list:
    if window.get_name() == 'My Application':
        print(window.transient_is_most_recently_activated())

下面的脚本将对话框作为其他映射窗口捕获(无论它们是模态还是非模态或它们来自的应用程序)。

import gi
gi.require_version('Gtk', '3.0')
gi.require_version('Wnck', '3.0')
from gi.repository import Gtk, Wnck

class DialogExample(Gtk.Dialog):

    def __init__(self, parent):
        Gtk.Dialog.__init__(self, "My Dialog", parent, 0, #or Gtk.DialogFlags.MODAL
            (Gtk.STOCK_CANCEL, Gtk.ResponseType.CANCEL,
             Gtk.STOCK_OK, Gtk.ResponseType.OK))

        self.set_default_size(100, 100)

        label = Gtk.Label("This is a dialog to display additional information")

        box = self.get_content_area()
        box.add(label)
        self.show_all()

class DialogWindow(Gtk.Window):

    def __init__(self):
        Gtk.Window.__init__(self, title="Dialog Example")
        self.set_border_width(6)
        button = Gtk.Button("Open dialog")
        button.connect("clicked", self.on_button_clicked)
        self.add(button)

    def on_button_clicked(self, widget):
        dialog = DialogExample(self)
        response = dialog.run()

        if response == Gtk.ResponseType.OK:
            print("The OK button was clicked")
        elif response == Gtk.ResponseType.CANCEL:
            print("The Cancel button was clicked")

        screen = Wnck.Screen.get_default()
        screen.force_update()  # recommended per Wnck documentation
        window_list = screen.get_windows()

        for window in window_list:
            print(window.get_name())

        window, window_list = (None,)*2
        screen = None

        dialog.destroy()

win = DialogWindow()
win.connect("delete-event", Gtk.main_quit)
win.show_all()

window = None
screen = None
Gtk.main()

使用Gdk而不是Wnck,你在稍低的级别做同样的事情。

答案 1 :(得分:0)

部分地从SQL UNIQUE Constraintthis answer说明如何打开窗户,你可以这样做:

from gtk import gdk

name = "MyDialog"

root = gdk.get_default_root_window()
matches = []
for id in root.property_get("_NET_CLIENT_LIST"):
    window = gdk.window_foreign_new(id)
    if window and window.property_get("WM_NAME")[2] == name:
        matches.append(window)

for match in matches:
    print(match, match.get_modal_hint())