PyGTK - klasa paska narzędzi
Klasa Toolbar jest dziedziczona z klasy gtk.Container. Przechowuje i zarządza zestawem przycisków i innych widżetów. Jeden lub więcej poziomych pasków przycisków jest zwykle widocznych tuż pod paskiem menu w oknie najwyższego poziomu. Pasek narzędzi można również umieścić w odłączanym oknie o nazwie HandleBox. Domyślnie przyciski w widżecie gtk.Toolbar są ułożone poziomo. Pionowy pasek narzędzi można skonfigurować, ustawiając właściwość orientacji nagtk.ORIENTATION_VERTICAL.
Pasek narzędzi można skonfigurować tak, aby wyświetlał przyciski z ikonami, tekstem lub jednym i drugim. Stylami wyliczającymi są -
gtk.TOOLBAR_ICONS | Te przyciski wyświetlają tylko ikony na pasku narzędzi. |
gtk.TOOLBAR_TEXT | Te przyciski wyświetlają tylko etykiety tekstowe na pasku narzędzi. |
gtk.TOOLBAR_BOTH | Te przyciski wyświetlają tekst i ikony na pasku narzędzi. |
gtk.TOOLBAR_BOTH_HORIZ | Te przyciski wyświetlają ikony i tekst obok siebie, a nie w pionie. |
Widżet paska narzędzi jest konfigurowany przy użyciu następującego konstruktora -
bar = gtk.Toolbar()
Składniki paska narzędzi Toolbar są instancjami gtk.ToolItem. Elementy mogą być ToolButton, RadioToolButton, ToggleToolButton lub SeparatorToolItem. Aby przypisać ikonę do obiektu ToolItem, można użyć obrazów ze wstępnie zdefiniowanym identyfikatorem stock_ID lub przypisać niestandardowy obraz za pomocą metody set_image ().
Poniższe przykłady pokazują, jak tworzyć różne elementy ToolItem -
ToolButton
newbtn = gtk.ToolButton(gtk.STOCK_NEW)
RadioToolButton
rb1 = gtk.RadioToolButton(None,gtk.STOCK_JUSTIFY_LEFT)
rb2 = gtk.RadioToolButton(rb1,gtk.STOCK_JUSTIFY_RIGHT)
Zauważ, że wiele przycisków opcji jest umieszczonych w tej samej grupie.
SeparatorToolItem
sep = gtk.SeparatorToolItem()
Te elementy są umieszczane na pasku narzędzi przez wywołanie jego insert metoda.
gtk.Toolbar.insert(item, index)
Na przykład,
bar.insert(new,0)
Możesz również przypisać podpowiedź do ToolButton za pomocą metody nethod set_tooltip_text (). Na przykład,New podpowiedź jest przypisana do nowego ToolButton.
newbtn.set_tooltip_text("New")
Przykład
Poniższy kod przedstawia okno najwyższego poziomu z paskiem narzędzi skonfigurowanym tak, aby zawierał normalne narzędzie, elementy radiowe i element separatora.
import gtk
class PyApp(gtk.Window):
def __init__(self):
super(PyApp, self).__init__()
self.set_title("Toolbar Demo")
self.set_default_size(250, 200)
self.set_position(gtk.WIN_POS_CENTER)
toolbar = gtk.Toolbar()
toolbar.set_style(gtk.TOOLBAR_ICONS)
toolbar.set_orientation(gtk.ORIENTATION_HORIZONTAL)
newbtn = gtk.ToolButton(gtk.STOCK_NEW)
newbtn.set_tooltip_text("New")
openbtn = gtk.ToolButton(gtk.STOCK_OPEN)
savebtn = gtk.ToolButton(gtk.STOCK_SAVE)
sep = gtk.SeparatorToolItem()
rb1 = gtk.RadioToolButton(None,gtk.STOCK_JUSTIFY_LEFT)
53
rb2 = gtk.RadioToolButton(rb1,gtk.STOCK_JUSTIFY_RIGHT)
prv = gtk.ToggleToolButton(gtk.STOCK_PRINT_PREVIEW)
quitbtn = gtk.ToolButton(gtk.STOCK_QUIT)
toolbar.insert(newbtn, 0)
toolbar.insert(openbtn, 1)
toolbar.insert(savebtn, 2)
toolbar.insert(sep, 3)
toolbar.insert(rb1,4)
toolbar.insert(rb2,5)
toolbar.insert(prv,6)
toolbar.insert(quitbtn, 7)
quitbtn.connect("clicked", gtk.main_quit)
vbox = gtk.VBox(False, 2)
vbox.pack_start(toolbar, False, False, 0)
self.add(vbox)
self.connect("destroy", gtk.main_quit)
self.show_all()
def on_checked(self, widget, data = None):
state = "Button1 : "+str(self.btn1.get_active())+"
Button2 : "+str(self.btn2.get_active())
self.lbl.set_text(state)
if __name__ == '__main__':
PyApp()
gtk.main()
Powyższy kod wygeneruje następujące dane wyjściowe -