Blob Blame History Raw
<?xml version="1.0" encoding="utf-8"?>
<page xmlns="http://projectmallard.org/1.0/" xmlns:its="http://www.w3.org/2005/11/its" xmlns:xi="http://www.w3.org/2001/XInclude" type="guide" style="task" id="treeview_cellrenderertoggle.py" xml:lang="cs">
  <info>
    <title type="text">TreeView s TreeStore (Python)</title>
    <link type="guide" xref="beginner.py#treeview"/>
    <link type="next" xref="widget_drawing.py"/>
    <revision version="0.1" date="2012-06-30" status="draft"/>

    <credit type="author copyright">
      <name>Marta Maria Casetti</name>
      <email its:translate="no">mmcasetti@gmail.com</email>
      <years>2012</years>
    </credit>

    <desc>TreeView zobrazující TreeStore (více komplexní příklad s CellRendererToggle)</desc>
  </info>

  <title>Více komplexní TreeView s TreeStore</title>
  <media type="image" mime="image/png" src="media/treeview_cellrenderertoggle.png"/>
  <p>Tento widget <code>TreeView</code> zobrazuje <code>TreeStore</code> se dvěma sloupci, z nichž jeden je vykreslován jako přepínač.</p>

  <links type="section"/>

  <section id="code">
    <title>Kód použitý k vygenerování tohoto příkladu</title>

    <code mime="text/x-python" style="numbered">from gi.repository import Gtk
from gi.repository import Pango
import sys

books = [["Tolstoy, Leo", ["War and Peace", True], ["Anna Karenina", False]],
         ["Shakespeare, William", ["Hamlet", False],
             ["Macbeth", True], ["Othello", False]],
         ["Tolkien, J.R.R.", ["The Lord of the Rings", False]]]


class MyWindow(Gtk.ApplicationWindow):

    def __init__(self, app):
        Gtk.Window.__init__(self, title="Library", application=app)
        self.set_default_size(250, 100)
        self.set_border_width(10)

        # Data jsou uložena v modelu
        # Vytvoří stromové zobrazení se dvěma sloupci
        self.store = Gtk.TreeStore(str, bool)
        # Naplní model
        for i in range(len(books)):
            # Iterátor piter je vrácen, kdy se připojuje autor v prvním sloupci
            # a hodnota False ve druhém sloupci
            piter = self.store.append(None, [books[i][0], False])
            # Připojí knihy a přidruženou pravdivostní hodnotu jako potomky
            # autora
            j = 1
            while j &lt; len(books[i]):
                self.store.append(piter, books[i][j])
                j += 1

        # TreeView zobrazuje model
        # Vytvoří stromové zobrazení na modelu self.store
        view = Gtk.TreeView()
        view.set_model(self.store)

        # Vykreslovač pro první sloupec - text
        renderer_books = Gtk.CellRendererText()
        # Vytvoří první sloupec
        column_books = Gtk.TreeViewColumn("Books", renderer_books, text=0)
        # A připojí jej do stromového zobrazení
        view.append_column(column_books)

        # Vykreslovat pro druhý sloupec - pravdivostní hodnota jako přepínač
        renderer_in_out = Gtk.CellRendererToggle()
        # Vytvoří druhý sloupec
        column_in_out = Gtk.TreeViewColumn("Out?", renderer_in_out, active=1)
        # A připojí jej do stromového zobrazení
        view.append_column(column_in_out)
        # Napojí signál "toggled" na funkci zpětného volání
        renderer_in_out.connect("toggled", self.on_toggled)

        # Přidá stromové zobrazení do okna
        self.add(view)

    # Funkce zpětného volání pro signál vyslaný od CellRendererToggle
    def on_toggled(self, widget, path):
        # Pravdivostní hodnota vybraného řádku
        current_value = self.store[path][1]
        # Změní pravdivostní hodnotu vybraného řádku v modelu
        self.store[path][1] = not current_value
        # Nová aktuální hodnota!
        current_value = not current_value
        # Jestliže je délka cesty 1 (tj. je vybrán autor)
        if len(path) == 1:
            # Získá iterátor patřící cestě
            piter = self.store.get_iter(path)
            # Získá iterátor patřící jejímu prvnímu potomkovi
            citer = self.store.iter_children(piter)
            # Dokud existují potomoci, mění stav jejich pravdivostních hodnot
            # na hodnotu u autora
            while citer is not None:
                self.store[citer][1] = current_value
                citer = self.store.iter_next(citer)
        # Jestliže délka cesty naní 1 (tj. je vybrána kniha)
        elif len(path) != 1:
            # Získá prvního potomka od rodiče knihy (první kniha autora)
            citer = self.store.get_iter(path)
            piter = self.store.iter_parent(citer)
            citer = self.store.iter_children(piter)
            # Zkontroluje, jestli jsou vybráni všichni potomci
            all_selected = True
            while citer is not None:
                if self.store[citer][1] == False:
                    all_selected = False
                    break
                citer = self.store.iter_next(citer)
            # Pokud ano, je vybrán i autor, jinak ne
            self.store[piter][1] = all_selected


class MyApplication(Gtk.Application):

    def __init__(self):
        Gtk.Application.__init__(self)

    def do_activate(self):
        win = MyWindow(self)
        win.show_all()

    def do_startup(self):
        Gtk.Application.do_startup(self)

app = MyApplication()
exit_status = app.run(sys.argv)
sys.exit(exit_status)
</code>
  </section>

  <section id="methods">
    <title>Užitečné metody pro widget TreeView</title>
    <p>Widget <code>TreeView</code> je navrže okolo návrhu <em>Model/Zobrazení/Ovládání</em>: <em>Model</em> uchovává data, <em>Zobrazení</em> získává upozornění a zobrazuje obsah modelu a konečně <em>Ovládání</em> změní stav modelu a upozorňuje zobrazení na tyto změny. Podrobnější informace a seznam užitečných metod pro stromové zobrazení najdete v <link xref="model-view-controller.py"/>.</p>
    <p>Na řádku 48 je signál <code>"toggled"</code> napojen na funkci zpětného volání <code>on_toggled()</code> pomocí <code><var>widget</var>.connect(<var>signál</var>, <var>funkce zpětného volání</var>)</code>. Podrobnější vysvětlení viz <link xref="signals-callbacks.py"/>.</p>
  </section>

  <section id="references">
    <title>Odkazy k API</title>
    <p>V této ukázce se používá následující:</p>
    <list>
      <item><p><link href="http://developer.gnome.org/gtk3/unstable/GtkTreeView.html">GtkTreeView</link></p></item>
      <item><p><link href="http://developer.gnome.org/gtk3/unstable/GtkTreeModel.html">GtkTreeModel</link></p></item>
      <item><p><link href="http://developer.gnome.org/gtk3/unstable/GtkTreeStore.html">GtkTreeStore</link></p></item>
      <item><p><link href="http://developer.gnome.org/gtk3/unstable/GtkCellRendererText.html">GtkCellRendererText</link></p></item>
      <item><p><link href="http://developer.gnome.org/gtk3/unstable/GtkCellRendererToggle.html">GtkCellRendererToggle</link></p></item>
      <item><p><link href="http://developer.gnome.org/gtk3/unstable/GtkTreeViewColumn.html">GtkTreeViewColumn</link></p></item>
    </list>
  </section>
</page>