Blame platform-demos/cs/togglebutton.js.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="togglebutton.js" xml:lang="cs">
Packit 1470ea
  <info>
Packit 1470ea
  <title type="text">ToggleButton (JavaScript)</title>
Packit 1470ea
    <link type="guide" xref="beginner.js#buttons"/>
Packit 1470ea
    <revision version="0.1" date="2012-06-16" status="draft"/>
Packit 1470ea
Packit 1470ea
    <credit type="author copyright">
Packit 1470ea
      <name>Taryn Fox</name>
Packit 1470ea
      <email its:translate="no">jewelfox@fursona.net</email>
Packit 1470ea
      <years>2012</years>
Packit 1470ea
    </credit>
Packit 1470ea
Packit 1470ea
    <desc>Zůstane zmáčknuté, dokud na něj znovu nekliknete</desc>
Packit 1470ea
  </info>
Packit 1470ea
Packit 1470ea
  <title>ToggleButton</title>
Packit 1470ea
  <media type="image" mime="image/png" src="media/togglebutton.png"/>
Packit 1470ea
  

ToggleButton (přepínací tlačítko) je podobné jako normální tlačítko (<link xref="button.js">Button</link>), jen s tím rozdílem, že po kliknutí zůstane zmáčknuté. Můžete jej používat ve funkci zapnuto/vypnuto pro řízení věcí, jako třeba káči (<link xref="spinner.js">Spinner</link>) v tomto příkladu.

Packit 1470ea
  

Metoda get_active přepínacího tlačítka vrací true, když je zmáčknuté, a false, když není. Metoda set_active se používá, když chcete změnit jeho stav programově, bez klikání. Když se jeho stav změní ze zmáčknutého na nezmáčknuté nebo naopak, vyšle signál "toggled", který můžete napojit na funkci, která něco udělá.

Packit 1470ea
    <links type="section"/>
Packit 1470ea
Packit 1470ea
  <section id="imports">
Packit 1470ea
    <title>Importované knihovny</title>
Packit 1470ea
    
Packit 1470ea
#!/usr/bin/gjs
Packit 1470ea
Packit 1470ea
const Gio = imports.gi.Gio;
Packit 1470ea
const Gtk = imports.gi.Gtk;
Packit 1470ea
const Lang = imports.lang;
Packit 1470ea
Packit 1470ea
    

Toto jsou knihovny, které potřebujeme naimportovat, aby aplikace běžela. Pamatujte si, že řádek, který GNOME říká, že používáme Gjs, musí být vždy na začátku.

Packit 1470ea
    </section>
Packit 1470ea
Packit 1470ea
  <section id="applicationwindow">
Packit 1470ea
    <title>Vytvoření okna aplikace</title>
Packit 1470ea
    
Packit 1470ea
const ToggleButtonExample = new Lang.Class({
Packit 1470ea
    Name: 'ToggleButton Example',
Packit 1470ea
Packit 1470ea
    // Vytvoří vlastní aplikaci
Packit 1470ea
    _init: function() {
Packit 1470ea
        this.application = new Gtk.Application({
Packit 1470ea
            application_id: 'org.example.jstogglebutton',
Packit 1470ea
            flags: Gio.ApplicationFlags.FLAGS_NONE
Packit 1470ea
        });
Packit 1470ea
Packit 1470ea
    // Napojí signály "activate" a "startup" k funkcím zpětného volání
Packit 1470ea
    this.application.connect('activate', Lang.bind(this, this._onActivate));
Packit 1470ea
    this.application.connect('startup', Lang.bind(this, this._onStartup));
Packit 1470ea
    },
Packit 1470ea
Packit 1470ea
    // Funkce zpětného volání pro signál "activate" zobrazujicí okno při aktivaci
Packit 1470ea
    _onActivate: function() {
Packit 1470ea
        this._window.present();
Packit 1470ea
    },
Packit 1470ea
Packit 1470ea
    // Funkce zpětného volání pro signál "startup" sestavující uživatelské rozhraní
Packit 1470ea
    _onStartup: function() {
Packit 1470ea
        this._buildUI ();
Packit 1470ea
    },
Packit 1470ea
Packit 1470ea
    

Všechen kód této ukázky je ve třídě RadioButtonExample. Výše uvedený kód vytvoří <link href="http://www.roojs.com/seed/gir-1.2-gtk-3.0/gjs/Gtk.Application.html">Gtk.Application</link> pro naše widgety a okno, ve kterém budou.

Packit 1470ea
    
Packit 1470ea
    // Sestaví uživatelské rozhraní aplikace
Packit 1470ea
    _buildUI: function() {
Packit 1470ea
Packit 1470ea
        // Vytvoří okno aplikace
Packit 1470ea
        this._window = new Gtk.ApplicationWindow({
Packit 1470ea
            application: this.application,
Packit 1470ea
            window_position: Gtk.WindowPosition.CENTER,
Packit 1470ea
            default_height: 300,
Packit 1470ea
            default_width: 300,
Packit 1470ea
            border_width: 30,
Packit 1470ea
            title: "ToggleButton Example"});
Packit 1470ea
Packit 1470ea
    

Funkce _buildUI je místo, ze kterého voláme všechen kód, který vytváří uživatelské rozhraní aplikace. Prvním krokem je vytvoření nového <link xref="GtkApplicationWindow.js">Gtk.ApplicationWindow</link>, do kterého vložíme všechny naše widgety.

Packit 1470ea
  </section>
Packit 1470ea
Packit 1470ea
  <section id="togglebutton">
Packit 1470ea
    <title>Vytvoření ToggleButton a dalších widgetů</title>
Packit 1470ea
    
Packit 1470ea
        // Vytvoří káču, kterou přepínací tlačítko zastavuje a spouští
Packit 1470ea
        this._spinner = new Gtk.Spinner ({hexpand: true, vexpand: true});
Packit 1470ea
Packit 1470ea
Packit 1470ea
    

Chceme, aby se tento widget <link xref="spinner.js">Spinner</link> roztáhl svisle i vodorovně a zabral co nejvíce místa uvnitř okna.

Packit 1470ea
Packit 1470ea
    
Packit 1470ea
        // Vytvoří ToggleButton, které spouští a zastavuje káču
Packit 1470ea
        this._toggleButton = new Gtk.ToggleButton ({label: "Start/Stop"});
Packit 1470ea
        this._toggleButton.connect ('toggled', Lang.bind (this, this._onToggle));
Packit 1470ea
Packit 1470ea
Packit 1470ea
    

Vytváření ToggleButton není tak úplně stejné, jako vytváření widgetu <link xref="button.js">Button</link>. Největší rozdíl je v tom, že obsluhujete signál "toggled" místo "clicked". Tento kód napojí funkci _onToggle na tento signál, takže bude zavolána pokaždé, když se přepínací tlačítko přepne.

Packit 1470ea
Packit 1470ea
    
Packit 1470ea
        // Vytvoří mřížku a vše do ní vloží
Packit 1470ea
        this._grid = new Gtk.Grid ({
Packit 1470ea
            row_homogeneous: false,
Packit 1470ea
            row_spacing: 15});
Packit 1470ea
        this._grid.attach (this._spinner, 0, 0, 1, 1);
Packit 1470ea
        this._grid.attach (this._toggleButton, 0, 1, 1, 1);
Packit 1470ea
Packit 1470ea
    

Zde vytvoříme jednoduchý widget <link xref="grid.js">Grid</link> pomocí kterého vše uspořádáme. Následně do něj připojíme káču a přepínací tlačítko.

Packit 1470ea
Packit 1470ea
    
Packit 1470ea
        // Přidá mřížku do okna
Packit 1470ea
        this._window.add (this._grid);
Packit 1470ea
Packit 1470ea
        // Zobrazí okno a všechny jeho synovské widgety
Packit 1470ea
        this._window.show_all();
Packit 1470ea
    },
Packit 1470ea
Packit 1470ea
    

Nyní přidáme mřížku do okna a řekneme oknu, aby zobrazilo sebe a své synovské widgety, až se spustí aplikace.

Packit 1470ea
    </section>
Packit 1470ea
Packit 1470ea
    <section id="toggled">
Packit 1470ea
    <title>Zajištění, že se něco stane, když je ToggleButton přepnut</title>
Packit 1470ea
Packit 1470ea
    
Packit 1470ea
    _onToggle: function() {
Packit 1470ea
Packit 1470ea
        // Spustí nebo zastaví káču
Packit 1470ea
        if (this._toggleButton.get_active ())
Packit 1470ea
            this._spinner.start ();
Packit 1470ea
        else this._spinner.stop ();
Packit 1470ea
Packit 1470ea
    }
Packit 1470ea
Packit 1470ea
});
Packit 1470ea
Packit 1470ea
    

Kdykoliv někdo přepínací tlačítko přepne, tato funkce zkontroluje jeho stav a pak použije get_active a příslušně spustí nebo zastaví káču. Chceme, aby se otáčela, jen když je tlačítko zmáčknuté, tj. get_active vrátí true. V opačném případě ji řekneme, aby se zastavila.

Packit 1470ea
Packit 1470ea
    
Packit 1470ea
// Spustí aplikaci
Packit 1470ea
let app = new ToggleButtonExample ();
Packit 1470ea
app.application.run (ARGV);
Packit 1470ea
Packit 1470ea
    

Nakonec vytvoříme novou instanci konečné třídy RadioButtonExample a aplikaci spustíme.

Packit 1470ea
  </section>
Packit 1470ea
Packit 1470ea
  <section id="complete">
Packit 1470ea
    <title>Úplný kód ukázky</title>
Packit 1470ea
#!/usr/bin/gjs
Packit 1470ea
Packit 1470ea
imports.gi.versions.Gtk = '3.0';
Packit 1470ea
Packit 1470ea
const Gio = imports.gi.Gio;
Packit 1470ea
const Gtk = imports.gi.Gtk;
Packit 1470ea
Packit 1470ea
class ToggleButtonExample {
Packit 1470ea
Packit 1470ea
    // Vytvoří vlastní aplikaci
Packit 1470ea
    constructor() {
Packit 1470ea
        this.application = new Gtk.Application({
Packit 1470ea
            application_id: 'org.example.jstogglebutton',
Packit 1470ea
            flags: Gio.ApplicationFlags.FLAGS_NONE
Packit 1470ea
        });
Packit 1470ea
Packit 1470ea
        // Napojí signály "activate" a "startup" k funkcím zpětného volání
Packit 1470ea
        this.application.connect('activate', this._onActivate.bind(this));
Packit 1470ea
        this.application.connect('startup', this._onStartup.bind(this));
Packit 1470ea
    }
Packit 1470ea
Packit 1470ea
    // Funkce zpětného volání pro signál "activate" zobrazujicí okno při aktivaci
Packit 1470ea
    _onActivate() {
Packit 1470ea
        this._window.present();
Packit 1470ea
    }
Packit 1470ea
Packit 1470ea
    // Funkce zpětného volání pro signál "startup" sestavující uživatelské rozhraní
Packit 1470ea
    _onStartup() {
Packit 1470ea
        this._buildUI();
Packit 1470ea
    }
Packit 1470ea
Packit 1470ea
    // Sestaví uživatelské rozhraní aplikace
Packit 1470ea
    _buildUI() {
Packit 1470ea
Packit 1470ea
        // Vytvoří okno aplikace
Packit 1470ea
        this._window = new Gtk.ApplicationWindow({
Packit 1470ea
            application: this.application,
Packit 1470ea
            window_position: Gtk.WindowPosition.CENTER,
Packit 1470ea
            default_height: 300,
Packit 1470ea
            default_width: 300,
Packit 1470ea
            border_width: 30,
Packit 1470ea
            title: "ToggleButton Example"});
Packit 1470ea
Packit 1470ea
        // Vytvoří káču, kterou přepínací tlačítko zastavuje a spouští
Packit 1470ea
        this._spinner = new Gtk.Spinner ({hexpand: true, vexpand: true});
Packit 1470ea
Packit 1470ea
        // Vytvoří ToggleButton, které spouští a zastavuje káču
Packit 1470ea
        this._toggleButton = new Gtk.ToggleButton ({label: "Start/Stop"});
Packit 1470ea
        this._toggleButton.connect ('toggled', this._onToggle.bind(this));
Packit 1470ea
Packit 1470ea
        // Vytvoří mřížku a vše do ní vloží
Packit 1470ea
        this._grid = new Gtk.Grid ({
Packit 1470ea
            row_homogeneous: false,
Packit 1470ea
            row_spacing: 15});
Packit 1470ea
        this._grid.attach (this._spinner, 0, 0, 1, 1);
Packit 1470ea
        this._grid.attach (this._toggleButton, 0, 1, 1, 1);
Packit 1470ea
Packit 1470ea
        // Přidá mřížku do okna
Packit 1470ea
        this._window.add (this._grid);
Packit 1470ea
Packit 1470ea
        // Zobrazí okno a všechny jeho synovské widgety
Packit 1470ea
        this._window.show_all();
Packit 1470ea
    }
Packit 1470ea
Packit 1470ea
    _onToggle() {
Packit 1470ea
Packit 1470ea
        // Spustí nebo zastaví káču
Packit 1470ea
        if (this._toggleButton.get_active ())
Packit 1470ea
            this._spinner.start ();
Packit 1470ea
        else this._spinner.stop ();
Packit 1470ea
Packit 1470ea
    }
Packit 1470ea
};
Packit 1470ea
Packit 1470ea
// Spustí aplikaci
Packit 1470ea
let app = new ToggleButtonExample ();
Packit 1470ea
app.application.run (ARGV);
Packit 1470ea
Packit 1470ea
  </section>
Packit 1470ea
Packit 1470ea
  <section id="in-depth">
Packit 1470ea
    <title>Dokumentace jdoucí do hloubky</title>
Packit 1470ea
<list>
Packit 1470ea
  <item>

<link href="http://www.roojs.com/seed/gir-1.2-gtk-3.0/gjs/Gtk.Application.html">Gtk.Application</link>

</item>
Packit 1470ea
  <item>

<link href="http://developer.gnome.org/gtk3/stable/GtkApplicationWindow.html">Gtk.ApplicationWindow</link>

</item>
Packit 1470ea
  <item>

<link href="http://www.roojs.org/seed/gir-1.2-gtk-3.0/gjs/Gtk.Grid.html">Gtk.Grid</link>

</item>
Packit 1470ea
  <item>

<link href="http://www.roojs.org/seed/gir-1.2-gtk-3.0/gjs/Gtk.Spinner.html">Gtk.Spinner</link>

</item>
Packit 1470ea
  <item>

<link href="http://www.roojs.org/seed/gir-1.2-gtk-3.0/gjs/Gtk.ToggleButton.html">Gtk.ToggleButton</link>

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