📜  PyGTK-对话框类

📅  最后修改于: 2020-11-08 07:54:51             🧑  作者: Mango


对话框小部件通常用作父窗口顶部的弹出窗口。对话框的目的是从用户那里收集一些数据并将其发送到父窗口。对话框可以是模式对话框(在其中阻止父框架),也可以是无模式对话框(可以绕过对话框)。

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 If set, the dialog grabs all the keyboard events
gtk.DIALOG_DESTROY_WITH_PARENT If set, the dialog is destroyed when its parent is.
gtk.DIALOG_NO_SEPARATOR If set, there is no separator bar above the buttons.

什么是按钮?

Button是一个元组对象,包含带有股票ID(或文本)及其响应ID的gtk.Button对。

响应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指定的文本的按钮(如果stock_button为股票ID,则为股票按钮)。

  • response() -使用response_id中指定的值发出“ response”信号

  • run() -显示对话框并在发出delete_event时返回response_id。

  • set_default_response() -使用指定的response_id将对话框的操作区域中的最后一个小部件设置为对话框的默认小部件。

gtk.Dialog小部件发出以下信号-

Close This is emitted when the dialog is closed.
Response This is emitted when an action_area widget is activated (button “clicked”), the dialog receives a delete_event or the application calls the response() method.

对话框小部件的action_area中的两个按钮使用股票ID gtk.STOCK.CANCEL和gtk.STOCK_OK。它们与响应ID gtk相关联。 RESPONSE_REJECT和gtk。分别为RESPONSE_ACCEPT。当按下任何按钮时,对话框关闭。 run()方法返回相应的响应ID,该ID可用于进一步处理。

以下代码显示顶层gtk.Window,其中包含一个Button。单击按钮后,将显示一个对话框,其中包含标签和两个按钮。

观察以下代码-

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有许多预配置的对话框小部件-

  • 消息对话框
  • 关于对话
  • 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()

上面的代码将生成以下输出-

对话方块