Blame platform-demos/cs/entry.py.page

Packit 1470ea
Packit 1470ea
<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="entry.py" xml:lang="cs">
Packit 1470ea
  <info>
Packit 1470ea
    <title type="text">Entry (Python)</title>
Packit 1470ea
    <link type="guide" xref="beginner.py#entry"/>
Packit 1470ea
    <link type="seealso" xref="strings.py"/>
Packit 1470ea
    <link type="next" xref="scale.py"/>
Packit 1470ea
    <revision version="0.2" date="2012-06-23" status="draft"/>
Packit 1470ea
Packit 1470ea
    <credit type="author copyright editor">
Packit 1470ea
      <name>Marta Maria Casetti</name>
Packit 1470ea
      <email its:translate="no"/>
Packit 1470ea
      <years>2012</years>
Packit 1470ea
    </credit>
Packit 1470ea
Packit 1470ea
    <credit type="author copyright">
Packit 1470ea
      <name>Sebastian Pölsterl</name>
Packit 1470ea
      <email its:translate="no">sebp@k-d-w.org</email>
Packit 1470ea
      <years>2011</years>
Packit 1470ea
    </credit>
Packit 1470ea
    <desc>Jednořádkové textové vstupní pole</desc>
Packit 1470ea
  </info>
Packit 1470ea
Packit 1470ea
  <title>Entry</title>
Packit 1470ea
  <media type="image" mime="image/png" src="media/entry.png"/>
Packit 1470ea
  

Tato aplikace vás přivítá v terminálu jménem, které zadáte.

Packit 1470ea
Packit 1470ea
  <links type="section"/>
Packit 1470ea
Packit 1470ea
  <section id="code">
Packit 1470ea
  <title>Kód použitý k vygenerování tohoto příkladu</title>
Packit 1470ea
    from gi.repository import Gtk
Packit 1470ea
import sys
Packit 1470ea
Packit 1470ea
Packit 1470ea
class MyWindow(Gtk.ApplicationWindow):
Packit 1470ea
Packit 1470ea
    def __init__(self, app):
Packit 1470ea
        Gtk.Window.__init__(self, title="What is your name?", application=app)
Packit 1470ea
        self.set_default_size(300, 100)
Packit 1470ea
        self.set_border_width(10)
Packit 1470ea
Packit 1470ea
        # Jednořádkové vstupní pole
Packit 1470ea
        name_box = Gtk.Entry()
Packit 1470ea
        # Vyšle signál, když je zmáčknuta klávesa Enter, napojený na
Packit 1470ea
        # funkci zpětného volání cb_activate
Packit 1470ea
        name_box.connect("activate", self.cb_activate)
Packit 1470ea
Packit 1470ea
        # Přidá Gtk.Entry do okna
Packit 1470ea
        self.add(name_box)
Packit 1470ea
Packit 1470ea
    # the content of the entry is used to write in the terminal
Packit 1470ea
    def cb_activate(self, entry):
Packit 1470ea
        # Získá obsah widgetu
Packit 1470ea
        name = entry.get_text()
Packit 1470ea
        # Vypíše jej v hezké podobě do terminálu
Packit 1470ea
        print("Hello " + name + "!")
Packit 1470ea
Packit 1470ea
Packit 1470ea
class MyApplication(Gtk.Application):
Packit 1470ea
Packit 1470ea
    def __init__(self):
Packit 1470ea
        Gtk.Application.__init__(self)
Packit 1470ea
Packit 1470ea
    def do_activate(self):
Packit 1470ea
        win = MyWindow(self)
Packit 1470ea
        win.show_all()
Packit 1470ea
Packit 1470ea
    def do_startup(self):
Packit 1470ea
        Gtk.Application.do_startup(self)
Packit 1470ea
Packit 1470ea
app = MyApplication()
Packit 1470ea
exit_status = app.run(sys.argv)
Packit 1470ea
sys.exit(exit_status)
Packit 1470ea
Packit 1470ea
  </section>
Packit 1470ea
Packit 1470ea
  <section id="methods">
Packit 1470ea
    <title>Užitečné metody pro widget Entry</title>
Packit 1470ea
    

Na řádku 14 je signál "activate" napojen na funkci zpětného volání cb_activate() pomocí widget.connect(signál, funkce_zpětného_volání). Podrobnější vysvětlení viz <link xref="signals-callbacks.py"/>. Mezi signály, které widget Gtk.Entry umí vyslat patří: "activate" (vyšle, když uživatel použije klávesu Enter); "backspace" (vyšle, když uživatel použije klávesu Backspace nebo Shift-Backspace); "copy-clipboard" (Ctrl-c a Ctrl-Insert); "paste-clipboard" (Ctrl-v a Shift-Insert); "delete-from-cursor" (Delete pro mazání znaku; Ctrl-Delete pro mazání slova); "icon-press" (vyšle, když uživatel klikne na aktivovatelné ikoně); "icon-release" (vyšle při uvolnění tlačítka z kliknutí myší na aktivovatelné ikoně); "insert-at-cursor" (vyšle, když uživatel začne vkládat pevný řetězec na pozici kurzoru); "move-cursor" (vyšle, když uživatel začne posouvat kurzor); "populate-popup" (vyšle před zobrazením kontextové nabídky pole; může být použito k přidání položek do ní).

Packit 1470ea
    <list>
Packit 1470ea
      <item>

get_buffer() a set_buffer(vyrovnávací_paměť), kde vyrovnávací_paměť je objekt Gtk.EntryBuffer, můžete použít k získání a nastavení vyrovnávací paměti pro vstupní pole.

</item>
Packit 1470ea
      <item>

get_text() a set_text("nějaký text") můžete použít k získání a nastavení obsahu vstupního pole.

</item>
Packit 1470ea
      <item>

get_text_length() vrací délku textu.

</item>
Packit 1470ea
      <item>

get_text_area() vrací oblast, ve které je textové vstupní pole vykreslováno.

</item>
Packit 1470ea
      <item>

Když nastavíme set_visibility(False), jsou znaky v poli zobrazovány pomocí „neviditelného“ znaku. Je zvolen nejlépe dostupný v aktuálním písmu, ale můžete jej změnit na jiný pomocí set_invisible_char(zn), kde zn je znak v Unikódu. Později lze změnu zvrátit použitím unset_invisbile_char().

</item>
Packit 1470ea
      <item>

set_max_length(int), kde int je celé číslo, zkrátí každý vstup delší než int na požadovanou maximální délku.

</item>
Packit 1470ea
      <item>

Ve výchozím stavu, když zmáčknete klávesu <key>Enter</key>, vyšle Gtk.Entry signál "activate". Pokud byste chtěli aktivovat výchozí widget okna (nastavený pomocí metody set_default(widget) okna), použijte set_activates_default(True).

</item>
Packit 1470ea
      <item>

Pro nastavení rámečku okolo vstupního pole: set_has_frame(True).

</item>
Packit 1470ea
      <item>

set_placeholder_text("nějaký text") nastavuje text, který má být zobrazen ve vstupním poli, když je prázdné a nezaměřené.

</item>
Packit 1470ea
      <item>

set_overwrite_mode(True) a set_overwrite_mode(False) zapíná/vypíná režim přepisování.

</item>
Packit 1470ea
      <item>

Když je nastaveno set_editable(False), nemůže uživatel upravovat text ve widgetu.

</item>
Packit 1470ea
      <item>

set_completion(doplňování), kde doplňování je <link href="http://developer.gnome.org/gtk3/unstable/GtkEntryCompletion.html">Gtk.EntryCompletion</link>, nastaví doplňování, nebo jej naopak zakáže, když je doplňování nastaveno na None.

</item>
Packit 1470ea
      <item>

Widget Entry může na pozadí textu zobrazovat průběh nebo aktivitu. K vyplnění zadané části pruhu používáme set_progress_fraction(část), část je číslo typu float v rozmezí 0.01.0 včetně. set_progress_pulse_step() používáme k nastavení části celkové délky pole, která se má pohybovat jako poletující blok ukazatele průběhu při každém zavolání progress_pulse(). Poslední zmíněná metoda dává najevo, že byl učiněn nějaký pokrok a způsobí, že indikátor ukazatele průběhu vstoupí do aktivního režimu, kdy blok poletuje tam a zpět. Každé zavolání progress_pulse() způsobí, že se blok o kousek posune (o kolik přesně je určeno, jak již bylo řečeno, pomocí set_progress_pulse_step()).

</item>
Packit 1470ea
      <item>

Widget Entry může také zobrazovat ikony. Tyto ikony, které lze aktivovat kliknutí, mohou být nastaveny jako zdroj pro přetahování a mohou mít vysvětlivky. Pro přidání ikony použijte set_icon_from_stock(pozice_ikony, standardní_id) nebo některou z funkcí set_icon_from_pixbuf(pozice_ikony, pixbuf), set_icon_from_icon_name(pozicei_kony, název_ikony), kde pozice_ikony je něco z Gtk.EntryIconPosition.PRIMARY (vytvoří ikonu na začátek vstupního pole) nebo Gtk.EntryIconPosition.SECONDARY (vytvoří ikonu na konci vstupního pole). Pro nastavení vysvětlivky ikoně použijte set_icon_tooltip_text("text vysvětlivky") nebo set_icon_tooltip_markup("text vysvětlivky ve značkovacím jazyce Pango").

</item>
Packit 1470ea
    </list>
Packit 1470ea
  </section>
Packit 1470ea
Packit 1470ea
  <section id="references">
Packit 1470ea
    <title>Odkazy k API</title>
Packit 1470ea
    

V této ukázce se používá následující:

Packit 1470ea
    <list>
Packit 1470ea
      <item>

<link href="http://developer.gnome.org/gtk3/unstable/GtkEntry.html">GtkEntry</link>

</item>
Packit 1470ea
    </list>
Packit 1470ea
  </section>
Packit 1470ea
</page>