本文主要是介绍【python】【Linux】PyGTK模块的使用-PyGTK 对话框类 【二十五】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
对话框小部件通常用作父窗口顶部的弹出窗口。对话框的目的是从用户那里收集一些数据并将其发送到父窗口。对话框可以是模式对话框(在其中阻止父框架),也可以是无模式对话框(可以绕过对话框)。
PyGTK库的Dialog小部件是一个垂直分割的窗口。在其顶部,有一个gtk.VBox,其中包装了Label或Entry Widget。底部称为action_area,其中放置一个或多个按钮。gtk.HSeparator将两个区域分隔开。
gtk.Dialog类具有以下构造函数-
dlg = gtk.Dialog (Title = None, parent = None, flags = 0, buttons = None)
哪里,
-
标题 -文本是否出现在对话框小部件的标题栏中。
-
父级 -是对从中弹出对话框的顶级窗口的引用。
-
标志 -定义控制Dialog操作的常量。定义的常量是-
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指定(如果有股票ID,则为股票按钮)。
-
response() -使用response_id中指定的值发出“ response”信号
-
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。分别为RESPONSE_ACCEPT。当按下任何按钮时,对话框关闭。run()方法返回相应的响应ID,该ID可用于进一步处理。
以下代码显示顶层gtk.Window,其中包含一个Button。单击按钮后,将显示一个带有标签和两个按钮的对话框。
例
观察以下代码-
import gtkclass 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 resdialog.destroy()
if __name__ == '__main__':PyApp()gtk.main()
上面的代码产生以下输出
预配置对话框小部件
PyGTK API有许多预配置的对话框小部件-
- 消息对话框
- 关于对话
- ColorSelectionDialog
- FontSelectionDialog
- FileChooserDialog
为了演示上述标准对话框在PyGTK中的功能,将带有菜单项的菜单分别单击时在下面程序的gtk.Window中放置,每个菜单项在单击时都会调用一个对话框。列出了响应激活每个菜单项信号的回调功能。您还可以理解为每种类型的对话框小部件提供的说明。
例
观察以下代码-
import gtk, pangoclass 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 codedef on_abtdlg(self, widget):#AboutDialog usage codedef on_fntdlg(self,widget):#FontSelectionDialog usage codedef on_color(self, widget):#ColorChooserDialog usage cdeDef on_file(self, widget):#FileChooserDialog usage code
if __name__ == '__main__':PyApp()gtk.main()
上面的代码将生成以下输出
这篇关于【python】【Linux】PyGTK模块的使用-PyGTK 对话框类 【二十五】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!