Диалоговый виджет обычно используется как всплывающее окно поверх родительского окна. Целью диалога является сбор некоторых данных от пользователя и отправка их в родительское окно. Диалог может быть модальным (где он блокирует родительский кадр) или немодальным (диалоговое окно может быть обойдено).
Виджет Dialog библиотеки PyGTK представляет собой окно, разделенное по вертикали. В его верхнем разделе находится gtk.VBox, в который упакованы виджеты Label или Entry. Нижний раздел называется 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 с биржевым идентификатором (или текстом) и идентификаторами его ответов.
Идентификатор ответа может быть любым числом или одной из предопределенных констант идентификатора ответа.
- 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 () — добавляет кнопку с текстом, заданным button_text (или кнопкой акции, если button_text является идентификатором акции) в action_area.
-
response () — испускает сигнал «response» со значением, указанным в response_id
-
run () — отображает диалоговое окно и возвращает response_id, когда delete_event получен.
-
set_default_response () — Устанавливает последний виджет в области действия диалога с указанным response_id в качестве виджета по умолчанию для диалога.
add_button () — добавляет кнопку с текстом, заданным button_text (или кнопкой акции, если button_text является идентификатором акции) в action_area.
response () — испускает сигнал «response» со значением, указанным в response_id
run () — отображает диалоговое окно и возвращает response_id, когда delete_event получен.
set_default_response () — Устанавливает последний виджет в области действия диалога с указанным response_id в качестве виджета по умолчанию для диалога.
Виджет gtk.Dialog испускает следующие сигналы —
близко | Это испускается, когда диалог закрыт. |
отклик | Он выдается, когда активирован виджет action_area (кнопка «нажата»), диалоговое окно получает сообщение delete_event или приложение вызывает метод response (). |
Две кнопки в action_area виджета Dialog используют идентификаторы акций gtk.STOCK.CANCEL и gtk.STOCK_OK. Они связаны с идентификаторами ответов 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 имеет несколько предварительно настроенных виджетов Dialog —
- 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()
Приведенный выше код сгенерирует следующий вывод: