- PyGTK 教程
 - PyGTK - 主页
 - PyGTK - 简介
 - PyGTK - 环境
 - PyGTK - 你好世界
 - PyGTK - 重要类
 - PyGTK - 窗口类
 - PyGTK - 按钮类
 - PyGTK - 标签类
 - PyGTK - 入门级
 - PyGTK - 信号处理
 - PyGTK - 事件处理
 - PyGTK - 容器
 - PyGTK - 盒子类
 - PyGTK - ButtonBox 类
 - PyGTK - 对齐类
 - PyGTK - EventBox 类
 - PyGTK - 布局类
 - PyGTK - 组合框类
 - PyGTK - ToggleButton 类
 - PyGTK - CheckButton 类
 - PyGTK - 单选按钮类
 - PyGTK - 菜单栏、菜单和菜单项
 - PyGTK - 工具栏类
 - PyGTK - 调整类
 - PyGTK - 范围类
 - PyGTK - 规模类
 - PyGTK - 滚动条类
 - PyGTK - 对话框类
 - PyGTK - 消息对话框类
 - PyGTK - AboutDialog 类
 - PyGTK - 字体选择对话框
 - PyGTK - 颜色选择对话框
 - PyGTK - 文件选择器对话框
 - PyGTK - 笔记本类
 - PyGTK - 框架类
 - PyGTK - AspectFrame 类
 - PyGTK - TreeView 类
 - PyGTK - 窗格类
 - PyGTK - 状态栏类
 - PyGTK - ProgressBar 类
 - PyGTK - 视口类
 - PyGTK - 滚动窗口类
 - PyGTK - 箭头类
 - PyGTK - 图像类
 - PyGTK - DrawingArea 类
 - PyGTK - SpinButton 类
 - PyGTK - 日历类
 - PyGTK - 剪贴板类
 - PyGTK - 标尺类
 - PyGTK - 超时
 - PyGTK - 拖放
 
- PyGTK 有用资源
 - PyGTK - 快速指南
 - PyGTK - 有用的资源
 - PyGTK - 讨论
 
PyGTK - 对话框类
对话框小部件通常用作父窗口顶部的弹出窗口。对话框的目的是从用户收集一些数据并将其发送到父窗口。对话框可以是模态的(它阻止父框架)或无模式的(对话框框架可以被绕过)。
PyGTK 库的对话框小部件是一个垂直分割的窗口。在其顶部,有一个 gtk.VBox,其中包含标签或条目小部件。底部部分称为action_area,其中放置一个或多个按钮。两个区域由 gtk.HSeparator 分隔。
gtk.Dialog 类具有以下构造函数 -
dlg = gtk.Dialog (Title = None, parent = None, flags = 0, buttons = None)
在哪里,
标题- 是出现在对话框小部件标题栏中的文本。
Parent - 是对弹出对话框的顶层窗口的引用。
Flag - 定义控制对话框操作的常量。定义的常量是 -
| gtk.DIALOG_MODAL | 如果设置,对话框将捕获所有键盘事件 | 
| gtk.DIALOG_DESTROY_WITH_PARENT | 如果设置,则当其父对话框被销毁时,对话框将被销毁。 | 
| gtk.DIALOG_NO_SEPARATOR | 如果设置,则按钮上方没有分隔栏。 | 
什么是按钮?
Button 是一个元组对象,包含成对的 gtk.Button 以及股票 ID(或文本)及其响应 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() - 在action_area中添加一个按钮,其文本由button_text(或库存按钮,如果button_text是库存ID)指定。
response() - 发出“响应”信号,其值在response_id中指定
run() - 显示对话框并在发出delete_event 时返回response_id。
set_default_response() - 将指定response_id的对话框操作区域中的最后一个小部件设置为对话框的默认小部件。
gtk.Dialog 小部件发出以下信号 -
| 关闭 | 当对话框关闭时会发出此消息。 | 
| 回复 | 当激活action_area小部件(“单击”按钮)、对话框收到delete_event或应用程序调用response()方法时,会发出此消息。 | 
对话框小部件的 action_area 中的两个按钮使用股票 ID gtk.STOCK.CANCEL 和 gtk.STOCK_OK。它们与响应 ID gtk 相关联。RESPONSE_REJECT 和 gtk。分别响应_接受。按下任何按钮时,对话框将关闭。run() 方法返回相应的响应 ID,可用于进一步处理。
以下代码显示了一个顶级 gtk.Window,其中有一个按钮。单击按钮时,会出现一个带有标签和两个按钮的对话框。
例子
观察以下代码 -
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()
上面的代码产生以下输出 -
预配置的对话框小部件
PyGTK API 有许多预配置的对话框小部件 -
- 消息对话框
 - 关于对话框
 - 颜色选择对话框
 - 字体选择对话框
 - 文件选择对话框
 
为了演示 PyGTK 中上述标准对话框的功能,在以下程序的 gtk.Window 中放置了一个菜单,其中包含一个菜单项,每个菜单项在单击时都会调用一个对话框。列出了响应激活每个菜单项信号的回调函数。您还可以了解为每种类型的对话框小部件提供的说明。
例子
观察以下代码 -
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("TutorialsPoint")
      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()
上面的代码将生成以下输出 -
