ProgressBar (JavaScript) Taryn Fox jewelfox@fursona.net 2012 Lišta, která pomocí animací znázorňuje průběh ProgressBar Zmáčknutí libovolné klávesy zastaví a spustí tento ProgressBar.

Tento PrograssBar ze zastavuje a spouští zmáčknutím libovolné klávesy.

#!/usr/bin/gjs imports.gi.versions.Gtk = '3.0'; const Gio = imports.gi.Gio; const GLib = imports.gi.GLib; const Gtk = imports.gi.Gtk; class ProgressBarExample { // Vytvoří vlastní aplikaci constructor() { this.application = new Gtk.Application({ application_id: 'org.example.jsprogressbar', flags: Gio.ApplicationFlags.FLAGS_NONE }); // Napojí signály "activate" a "startup" k funkcím zpětného volání this.application.connect('activate', this._onActivate.bind(this)); this.application.connect('startup', this._onStartup.bind(this)); } // Funkce zpětného volání pro signál "activate" zobrazujicí okno při aktivaci _onActivate() { this._window.present(); } // Funkce zpětného volání pro signál "startup" sestavující uživatelské rozhraní _onStartup() { this._buildUI(); } // Sestaví uživatelské rozhraní aplikace _buildUI() { // Vytvoří okno aplikace this._window = new Gtk.ApplicationWindow({ application: this.application, window_position: Gtk.WindowPosition.CENTER, default_height: 20, default_width: 220, title: "ProgressBar Example"}); // Vytvoří ukazatel průběhu this.progressBar = new Gtk.ProgressBar (); this._window.add(this.progressBar); // Spustí funkci, která pulzuje ukazatelem průběhu každých 100 milisekund this.sourceID = GLib.timeout_add(GLib.PRIORITY_DEFAULT, 100, this._barPulse.bind(this)); // Napojí událost zmáčknutí klávesy na funkci, která přepíná pulzování ukazatele průběhu this._window.connect("key-press-event", this._onKeyPress.bind(this)); // Zobrazí okno a všechny jeho synovské widgety this._window.show_all(); } // Pulzuje ukazatelem průběhu (pokud nebyl zakázán zmáčknutím klávesy) _barPulse() { this.progressBar.pulse(); return true; } // Spustí a zastaví ukazatel průběhu při zmáčknátí klávesy _onKeyPress() { if (this.sourceID == 0) this.sourceID = GLib.timeout_add(GLib.PRIORITY_DEFAULT, 100, this._barPulse.bind(this)); else { GLib.source_remove(this.sourceID); this.sourceID = 0; } } }; // Spustí aplikaci let app = new ProgressBarExample (); app.application.run (ARGV);

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

GLib

Gtk.Application

Gtk.ApplicationWindow

Gtk.ProgressBar