PyGTK 对话框类
对话框小部件通常用作在父窗口上方的弹出窗口。对话框的目的是收集用户的一些数据并将其发送到父窗口。对话框可以是模态的(阻塞父框架)或非模态的(对话框框架可以被绕过)。
PyGTK库的对话框小部件是垂直分割的窗口。在顶部部分,有一个gtk.VBox,其中装有Label或Entry小部件。底部部分称为action_area,其中放置一个或多个按钮。两个区域由gtk.HSeparator分隔。
gtk.Dialog类具有以下构造函数−
在此处,
- Title - 是对话框小部件标题栏中显示的文本。
-
parent - 是对话框弹出的顶级窗口的引用。
-
flags - 定义控制对话框操作的常量。定义的常量如下 –
gtk.DIALOG_MODAL | 如果设置了该选项,对话框将捕获所有键盘事件 |
---|---|
gtk.DIALOG_DESTROY_WITH_PARENT | 如果设置了该选项,对话框会在其父级被销毁时一同销毁 |
gtk.DIALOG_NO_SEPARATOR | 如果设置了该选项,按钮上方将没有分隔栏 |
什么是按钮
按钮是一个元组对象,包含了gtk.Button的stock 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是stock ID,则为stock按钮)指定的按钮。
-
response() - 以response_id指定的值发出“response”信号。
-
run() - 显示对话框,并在delete_event被触发时返回response_id。
-
set_default_response() - 将对话框动作区的最后一个小部件设置为指定的 response_id 作为对话框的默认小部件。
gtk.Dialog小部件发出以下信号 –
Close | 当对话框关闭时触发此事件。 |
---|---|
Response | 当一个操作区域小部件被激活(按钮”被点击”),对话框接收到删除事件或应用程序调用response()方法时触发此事件。 |
Dialog小部件的action_area中有两个按钮,使用的是Stock IDs gtk.STOCK.CANCEL和gtk.STOCK_OK。它们分别与响应IDs gtk.RESPONSE_REJECT和gtk.RESPONSE_ACCEPT相关联。当任何按钮被按下时,对话框将关闭。run()方法返回相应的响应ID,可以用于进一步处理。
以下代码显示了一个带有按钮的顶级gtk.Window。当按钮被点击时,一个带有标签和两个按钮的对话框出现。
示例
观察以下代码 −
以上代码生成以下输出:
预配置对话框小部件
PyGTK API有许多预配置的对话框小部件-
- MessageDialog(消息对话框)
- AboutDialog(关于对话框)
- ColorSelectionDialog(颜色选择对话框)
- FontSelectionDialog(字体选择对话框)
- FileChooserDialog(文件选择对话框)
为了展示在PyGTK中上述标准对话框的功能,以下程序在一个gtk.Window中放置了一个带有每个菜单项点击时调用对话框的菜单。列出了对应于每个菜单项的激活信号的回调函数。你还可以理解每种类型对话框小部件的说明。
示例
看下面的代码-
上述代码将生成以下输出: