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 -