- PyGTK 教程
- PyGTK - 首页
- PyGTK - 简介
- PyGTK - 环境
- PyGTK - Hello World
- PyGTK - 重要类
- PyGTK - 窗口类
- PyGTK - 按钮类
- PyGTK - 标签类
- PyGTK - 输入框类
- PyGTK - 信号处理
- PyGTK - 事件处理
- PyGTK - 容器
- PyGTK - 箱式容器类
- PyGTK - 按钮盒类
- PyGTK - 对齐类
- PyGTK - 事件盒类
- PyGTK - 布局类
- PyGTK - 组合框类
- PyGTK - 切换按钮类
- PyGTK - 复选框类
- PyGTK - 单选按钮类
- PyGTK - 菜单栏、菜单和菜单项
- PyGTK - 工具栏类
- PyGTK - 调整类
- PyGTK - 范围类
- PyGTK - 刻度类
- PyGTK - 滚动条类
- PyGTK - 对话框类
- PyGTK - 消息对话框类
- PyGTK - 关于对话框类
- PyGTK - 字体选择对话框
- PyGTK - 颜色选择对话框
- PyGTK - 文件选择对话框
- PyGTK - 笔记本类
- PyGTK - 框架类
- PyGTK - 带边框的框架类
- PyGTK - 树形视图类
- PyGTK - 分割窗格类
- PyGTK - 状态栏类
- PyGTK - 进度条类
- PyGTK - 视口类
- PyGTK - 滚动窗口类
- PyGTK - 箭头类
- PyGTK - 图片类
- PyGTK - 绘图区域类
- PyGTK - 旋转按钮类
- 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)
其中,
标题 - 是出现在对话框小部件标题栏中的文本。
父级 - 是对对话框弹出的顶级窗口的引用。
标志 - 定义控制对话框操作的常量。定义的常量为:
| gtk.DIALOG_MODAL | 如果设置,则对话框捕获所有键盘事件 |
| gtk.DIALOG_DESTROY_WITH_PARENT | 如果设置,则当父级被销毁时,对话框也会被销毁。 |
| gtk.DIALOG_NO_SEPARATOR | 如果设置,则按钮上方没有分隔线。 |
什么是按钮?
按钮是一个元组对象,包含 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 中指定值的“response”信号。
run() - 显示对话框并在 delete_event 发出时返回 response_id。
set_default_response() - 将对话框 action_area 中的最后一个小部件设置为具有指定 response_id 作为对话框的默认小部件。
gtk.Dialog 小部件发出以下信号:
| 关闭 | 当对话框关闭时发出。 |
| 响应 | 当 action_area 小部件被激活(按钮“单击”)、对话框接收 delete_event 或应用程序调用 response() 方法时发出。 |
对话框小部件 action_area 中的两个按钮使用库存 ID gtk.STOCK.CANCEL 和 gtk.STOCK_OK。它们分别与响应 ID gtk.RESPONSE_REJECT 和 gtk.RESPONSE_ACCEPT 关联。按下任何按钮时,对话框都会关闭。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 有许多预配置的对话框小部件:
- MessageDialog
- AboutDialog
- ColorSelectionDialog
- FontSelectionDialog
- FileChooserDialog
为了演示 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()
以上代码将生成以下输出: