对话类(Dialog Class)
对话框小部件通常用作父窗口顶部的弹出窗口。 Dialog的目标是从用户收集一些数据并将其发送到父窗口。 对话框可以是模态的(它阻止父帧)或无模式(可以绕过对话框)。
PyGTK库的Dialog小部件是一个垂直分割的窗口。 在其顶部,有一个gtk.VBox,其中包含Label或Entry Widgets。 底部称为action_area,其中放置了一个或多个按钮。 两个区域由gtk.HSeparator分隔。
gtk.Dialog类有以下构造函数 -
dlg = gtk.Dialog (Title = None, parent = None, flags = 0, buttons = None)
Where,
Title - 文本是否出现在Dialog小部件的标题栏中。
Parent - 是从弹出对话框的顶层窗口的引用。
Flag - 定义控制Dialog操作的常量。 定义的常数是 -
gtk.DIALOG_MODAL | 如果设置,则对话框将抓取所有键盘事件 |
gtk.DIALOG_DESTROY_WITH_PARENT | 如果设置,则对话框的父对象将被销毁。 |
gtk.DIALOG_NO_SEPARATOR | 如果设置,则按钮上方没有分隔条。 |
什么是按钮?
Button是一个元组对象,包含一对带有股票ID(或文本)的gtk.Button及其响应ID。
响应ID可以是任意数量或预定义的响应ID常量之一 -
- gtk.RESPONSE_NONE
- gtk.RESPONSE_REJECT
- gtk.RESPONSE_ACCEPT
- gtk.RESPONSE_DELETE_EVENT
- gtk.RESPONSE_OK
- gtk.RESPONSE_CANCEL
- gtk.RESPONSE_CLOSE
- gtk.RESPONSE_YES
- gtk.RESPONSE_NO
- gtk.RESPONSE_APPLY
- gtk.RESPONSE_HELP
gtk.Dialog类的重要方法如下 -
add_button() - 在add_button()添加一个按钮,该按钮包含button_text指定的文本(或者一个股票按钮,如果button_text是股票ID)。
response() - 使用response_id中指定的值发出“response”信号
run() - 显示对话框并在发出delete_event时返回response_id。
set_default_response() - 使用指定的response_id作为对话框的默认小部件,设置对话框操作区域中的最后一个小部件。
gtk.Dialog小部件发出以下信号 -
Close | 关闭对话框时会发出此信息。 |
Response | 当激活action_area小部件(按钮“单击”)时,会发出此消息,对话框接收delete_event或应用程序调用response()方法。 |
Dialog小部件的action_area中的两个按钮使用Stock ID gtk.STOCK.CANCEL和gtk.STOCK_OK。 它们与响应ID gtk相关联。 RESPONSE_REJECT和gtk。 分别为RESPONSE_ACCEPT。 按下任何按钮时,对话框将关闭。 run()方法返回相应的响应ID,可用于进一步处理。
以下代码显示顶级gtk.Window,其中包含一个Button。 单击按钮时,会出现一个带有标签和两个按钮的对话框。
例子 (Example)
请注意以下代码 -
import gtk
class PyApp(gtk.Window):
def __init__(self):
super(PyApp, self).__init__()
self.set_title("Dialog Demo")
self.set_default_size(250, 200)
fixed = gtk.Fixed()
btn = gtk.Button("Show")
btn.connect("clicked",self.show_sialog)
fixed.put(btn,100,100)
self.add(fixed)
self.connect("destroy", gtk.main_quit)
self.show_all()
def show_sialog(self, widget, data=None):
dialog = gtk.Dialog("My dialog",
self,
gtk.DIALOG_MODAL | gtk.DIALOG_DESTROY_WITH_PARENT,
(gtk.STOCK_CANCEL, gtk.RESPONSE_REJECT,
gtk.STOCK_OK, gtk.RESPONSE_ACCEPT))
label = gtk.Label("Simple dialog")
dialog.vbox.add(label)
label.show()
res = dialog.run()
print res
dialog.destroy()
if __name__ == '__main__':
PyApp()
gtk.main()
上面的代码产生以下输出 -
预配置的Dialog Widgets
PyGTK API有许多预配置的Dialog小部件 -
- MessageDialog
- AboutDialog
- ColorSelectionDialog
- FontSelectionDialog
- FileChooserDialog
为了演示PyGTK中上述标准对话框的功能,在单击时调用对话框的菜单项的菜单放在以下程序的gtk.Window中。 将列出响应以激活每个菜单项的信号的回调函数。 您还可以了解为每种类型的对话框小部件提供的说明。
例子 (Example)
请注意以下代码 -
import gtk, pango
class PyApp(gtk.Window):
def __init__(self):
super(PyApp, self).__init__()
self.set_title("Dialog Boxes")
self.set_default_size(250, 200)
self.set_position(gtk.WIN_POS_CENTER)
mb = gtk.MenuBar()
menu1 = gtk.Menu()
file = gtk.MenuItem("_File")
file.set_submenu(menu1)
msg = gtk.MenuItem("MessageDialog")
menu1.append(msg)
abt = gtk.MenuItem("AboutDialog")
menu1.append(abt)
colo = gtk.MenuItem("colorDialog")
menu1.append(colo)
font = gtk.MenuItem("FontSelectionDialog")
menu1.append(font)
fl = gtk.MenuItem("FileChooserDialog")
menu1.append(fl)
mb.append(file)
vbox = gtk.VBox(False, 2)
vbox.pack_start(mb, False, False, 0)
self.add(vbox)
self.text = gtk.Label("xnip")
vbox.pack_start(self.text, True, True, 0)
msg.connect("activate",self.on_msgdlg)
abt.connect("activate",self.on_abtdlg)
font.connect("activate",self.on_fntdlg)
colo.connect("activate",self.on_color)
fl.connect("activate", self.on_file)
self.connect("destroy", gtk.main_quit)
self.show_all()
def on_msgdlg(self, widget):
#MessageDialog usage code
def on_abtdlg(self, widget):
#AboutDialog usage code
def on_fntdlg(self,widget):
#FontSelectionDialog usage code
def on_color(self, widget):
#ColorChooserDialog usage cde
Def on_file(self, widget):
#FileChooserDialog usage code
if __name__ == '__main__':
PyApp()
gtk.main()
上面的代码将生成以下输出 -