Один виджет RadioButton предлагает функциональность, аналогичную CheckButton. Однако, когда в одном контейнере присутствует несколько переключателей, пользователю предоставляется взаимоисключающий выбор, чтобы выбрать один из доступных вариантов. Если все переключатели в контейнере принадлежат к одной и той же группе, то при выборе одной из них другие автоматически отменяются.
Ниже приведен конструктор класса gtk.RadioButton:
gtk.RadioButton(group = None, Label = None, unerline = None)
Чтобы создать группу кнопок, укажите group = None для первой кнопки-переключателя, а для последующих опций укажите объект первой кнопки как группу.
Как и в случае ToggleButton и CheckButton, RadioButton также испускает переключенный сигнал . В приведенном ниже примере три объекта виджета gtk.RadioButton помещаются в VBox. Все они подключены к функции обратного вызова on_selected () для обработки переключенного сигнала.
Функция обратного вызова идентифицирует метку исходного виджета RadioButton и отображает ее на метке, помещенной в VBox.
пример
Соблюдайте следующий код —
import gtk class PyApp(gtk.Window): def __init__(self): super(PyApp, self).__init__() self.set_title("Radio Button") self.set_default_size(250, 200) self.set_position(gtk.WIN_POS_CENTER) vbox = gtk.VBox() btn1 = gtk.RadioButton(None, "Button 1") btn1.connect("toggled", self.on_selected) btn2 = gtk.RadioButton(btn1,"Button 2") btn2.connect("toggled", self.on_selected) btn3 = gtk.RadioButton(btn1,"Button 3") btn3.connect("toggled", self.on_selected) self.lbl = gtk.Label() vbox.add(btn1) vbox.add(btn2) vbox.add(btn3) vbox.add(self.lbl) self.add(vbox) self.connect("destroy", gtk.main_quit) self.show_all() def on_selected(self, widget, data=None): self.lbl.set_text(widget.get_label()+" is selected") if __name__ == '__main__': PyApp() gtk.main()
Приведенный выше код сгенерирует следующий вывод: