|
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="textview.js" xml:lang="cs">
|
|
Packit |
1470ea |
<info>
|
|
Packit |
1470ea |
<title type="text">TextView (JavaScript)</title>
|
|
Packit |
1470ea |
<link type="guide" xref="beginner.js#multiline"/>
|
|
Packit |
1470ea |
<link type="seealso" xref="button.js"/>
|
|
Packit |
1470ea |
<link type="seealso" xref="grid.js"/>
|
|
Packit |
1470ea |
<link type="seealso" xref="GtkApplicationWindow.js"/>
|
|
Packit |
1470ea |
<link type="seealso" xref="label.js"/>
|
|
Packit |
1470ea |
<revision version="0.1" date="2012-06-28" 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>Víceřádkový textový editor</desc>
|
|
Packit |
1470ea |
</info>
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
<title>TextView</title>
|
|
Packit |
1470ea |
<media type="image" mime="image/png" src="media/textviewpenguinchat.png"/>
|
|
Packit |
1470ea |
TextView (textové zobrazení) je ve skutečnosti, nebo alespoň většinou, sada tří vnořených objektů.
|
|
Packit |
1470ea |
<list>
|
|
Packit |
1470ea |
<item>Vespod je <link href="http://www.roojs.org/seed/gir-1.2-gtk-3.0/gjs/Gtk.TextBuffer.html">TextBuffer</link>. Ten uchovává vlastní text. </item>
|
|
Packit |
1470ea |
<item>Uprostřed je <link href="http://www.roojs.org/seed/gir-1.2-gtk-3.0/gjs/Gtk.TextView.html">TextView</link>, což je widget, který umožňuje zobrazit a upravovat text z vyrovnávací paměti. Automaticky mění svoji velikost v závislosti na množství textu v něm. </item>
|
|
Packit |
1470ea |
<item>Protože automatické změny mohou učinit TextView neprakticky použitelným, je běžnou praxí umístit jej do widgetu ScrolledWindow . Navzdory výrazu „window“ v názvu se nejedná o běžně známe okno se záhlavím a tlačítkem <gui>×</gui>, ale o widget, který vložený do aplikace bude fungovat jako okno do lépe zvládnutého zobrazení textu. Když bude text ve vyrovnávací paměti delší, než se vleze, objeví se posuvníky. </item>
|
|
Packit |
1470ea |
</list>
|
|
Packit |
1470ea |
Když chcete změnit text, který je v TextView zobrazen, musíte pracovat s objektem TextBuffer , protože právě v něm je text uložen. To samé platí, když chcete vidět, co někdo do něj napsal. Tato ukázková aplikace umožňuje promluvit si se (smyšleným) tučňákem a kontroluje TextBuffer , aby zjistila, jestli jste někde nenapsali slovo „fish“ (ryba).
|
|
Packit |
1470ea |
<note>Ve skutečném světe populace tučňáků rychle klesá, protože změny klimatu způsobují tání ledovců, na kterých žijí, a zabíjí ryby, které jí. Jestli si chcete v GNOME zahrát (poněkud bláznivou) hru založenou na tomto předpokladu, podívejte se na <link href="http://pingus.seul.org/">Pingus</link>. </note>
|
|
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 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 TextViewExample = new Lang.Class ({
|
|
Packit |
1470ea |
Name: 'TextView 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.jstextview' });
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Připojí 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ě TextViewExample . 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 |
title: "Talk to a Penguin",
|
|
Packit |
1470ea |
default_height: 400,
|
|
Packit |
1470ea |
default_width: 440,
|
|
Packit |
1470ea |
border_width: 20 });
|
|
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="textview">
|
|
Packit |
1470ea |
<title>Vytvoření TextView</title>
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Vytvoří popisek přes který k vám bude promlouvat tučňák
|
|
Packit |
1470ea |
this._penguin = new Gtk.Label ({
|
|
Packit |
1470ea |
height_request: 180,
|
|
Packit |
1470ea |
width_request: 400,
|
|
Packit |
1470ea |
label: "Squaaaak?",
|
|
Packit |
1470ea |
wrap: true });
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
Naším prvním krokem v tomto příkladu bude vytvořit <link xref="label.js">Label</link>, který tučňák používá k proslovům. Pomocí nastavení vlastnosti wrap na true zajistíme, že text se může zalamovat, ale u widgetu TextView použijeme jinou metodu, která nám umožní jemnější řízení.
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Vytvoří textové zobrazení, přes které můžete mluvit na tučňáka
|
|
Packit |
1470ea |
this.buffer = new Gtk.TextBuffer();
|
|
Packit |
1470ea |
this._textView = new Gtk.TextView ({
|
|
Packit |
1470ea |
buffer: this.buffer,
|
|
Packit |
1470ea |
editable: true,
|
|
Packit |
1470ea |
wrap_mode: Gtk.WrapMode.WORD });
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
Jako první krok je vytvořen TextBuffer pro vkládání slov. Po té zde vytvoříme TextView a řekneme mu, že má používat právě vytvořený TextBuffer . Rovněž se nastaví jako upravitelný, protože chceme mít možnost do něj psát nové věci.
|
|
Packit |
1470ea |
Vlastnost wrap_mode dává možnost vybrat si ze čtyř různých <link href="http://www.roojs.org/seed/gir-1.2-gtk-3.0/gjs/Gtk.WrapMode.html">režimů zalamování</link>. Například Gtk.WrapMode.CHAR způsobí zalomení uprostřed slova, když budete pokračovat v psaní za okraj. Většina lidí pravděpodobně použije Gtk.WrapMode.WORD , který automaticky přesune psané slovo na další řádek, když je příliš dlouhé.
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Vytvoří okno s posuvníky pro vložení textového zobrazení, aby
|
|
Packit |
1470ea |
// mohlo posouvat svůj obsah
|
|
Packit |
1470ea |
this._scrolled = new Gtk.ScrolledWindow ({
|
|
Packit |
1470ea |
hscrollbar_policy: Gtk.PolicyType.AUTOMATIC,
|
|
Packit |
1470ea |
vscrollbar_policy: Gtk.PolicyType.AUTOMATIC,
|
|
Packit |
1470ea |
shadow_type: Gtk.ShadowType.ETCHED_IN,
|
|
Packit |
1470ea |
height_request: 180,
|
|
Packit |
1470ea |
width_request: 400, });
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Vloží textové zobrazení do okna s posuvníky
|
|
Packit |
1470ea |
this._scrolled.add_with_viewport (this._textView);
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
Zde vytvoříme okno s posuvníky a nastavíme jej, aby automaticky poskytlo posuvníky, když dostaneme příliš velký obsah, ať už vodorovně nebo svisle. Rovněž získáme hezky vypadající okraj ETCHED_IN (prohnutý). Po té dovnitř vložíme TextView a řekneme oknu s posuvníky, aby nám pro něj poskytlo pohled.
|
|
Packit |
1470ea |
</section>
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
<section id="ui">
|
|
Packit |
1470ea |
<title>Vytvoření zbytku uživatelského rozhraní</title>
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Vytvoří mřížku pro uspořádání widgetů
|
|
Packit |
1470ea |
this._grid = new Gtk.Grid ({
|
|
Packit |
1470ea |
halign: Gtk.Align.CENTER,
|
|
Packit |
1470ea |
valign: Gtk.Align.CENTER });
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Vloží popisek a textové zobrazení do mřížky, jeden nad druhý
|
|
Packit |
1470ea |
this._grid.attach (this._penguin, 0, 0, 1, 1);
|
|
Packit |
1470ea |
this._grid.attach (this._scrolled, 0, 1, 1, 1);
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
První widget <link xref="grid.js">Grid</link>, který jsme vytvořili, má uvnitř jen popisek a okno s posuvníky.
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Vytvoří tlačítko pro odeslání vaší zprávy tučňákovi
|
|
Packit |
1470ea |
this._send = new Gtk.Button ({
|
|
Packit |
1470ea |
halign: Gtk.Align.END,
|
|
Packit |
1470ea |
margin_top: 20,
|
|
Packit |
1470ea |
label: "Send" });
|
|
Packit |
1470ea |
this._send.connect ('clicked', Lang.bind (this, this._chat));
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Vytvoří mřížku pro poddružnou mřížku nahoře a tlačítko dole
|
|
Packit |
1470ea |
this._mainGrid = new Gtk.Grid ({
|
|
Packit |
1470ea |
halign: Gtk.Align.CENTER,
|
|
Packit |
1470ea |
valign: Gtk.Align.CENTER });
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Přidá poddružnou mřížku a tlačítko do hlavní mřížky
|
|
Packit |
1470ea |
this._mainGrid.attach (this._grid, 0, 0, 1, 1);
|
|
Packit |
1470ea |
this._mainGrid.attach (this._send, 0, 1, 1, 1);
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
Vytvoříme widget <link xref="button.js">Button</link>, který odešle vaši zprávu tučňákovi, a mřížku, která bude nahoře obsahovat předchozí mřížku a dole tlačítko. Tlačítko má nahoře okraj, díky čemuž se nelepí na okno s posuvníky.
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Připojí hlavní mřížku do okna
|
|
Packit |
1470ea |
this._window.add (this._mainGrid);
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Zobrazení okno a všechny jeho synovské widgety
|
|
Packit |
1470ea |
this._window.show_all();
|
|
Packit |
1470ea |
},
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
Nakonec připojíme hlavní mřížku do okna, kterému řekneme, aby sebe a vše v něm nastavilo jako viditelné, když se spustí aplikace.
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
</section>
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
<section id="function">
|
|
Packit |
1470ea |
<title>Funkce, která se stará o odpovědi tučňáka</title>
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
_chat: function () {
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Vytvoří náhodné číslo, které určí, co tučňák řekne
|
|
Packit |
1470ea |
this.number = Math.floor ((Math.random() * 3) + 1);
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Řekli jste právě něco?
|
|
Packit |
1470ea |
if (this.buffer.text) {
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Zmínili jste rybu?
|
|
Packit |
1470ea |
if (this.buffer.text.match (/fish/gi)) {
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Tučňák musí zaskřehovat o rybě
|
|
Packit |
1470ea |
if (this.number == 1)
|
|
Packit |
1470ea |
this._penguin.set_label ("FISH!");
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
else if (this.number == 2)
|
|
Packit |
1470ea |
this._penguin.set_label ("Fish fish fish fish. Fish!");
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
else
|
|
Packit |
1470ea |
this._penguin.set_label ("Fish? Fish fish fish. Fish fish. FISH!");
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
}
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Myslím, že jsem se nezmínil o rybě
|
|
Packit |
1470ea |
else {
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Tučňák pokecá o všedních záležitostech tučňáků
|
|
Packit |
1470ea |
if (this.number == 1)
|
|
Packit |
1470ea |
this._penguin.set_label ("SQUAAK!");
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
else if (this.number == 2)
|
|
Packit |
1470ea |
this._penguin.set_label ("Ork ork ork ork squaak. Squaak squaak! *waves flippers*");
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
else
|
|
Packit |
1470ea |
this._penguin.set_label ("Ork ork ork ork ork?");
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
}
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
}
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Vymaže vyrovnávací paměť
|
|
Packit |
1470ea |
this.buffer.text = "";
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Předá zaměření zpět textovému zobrazení, abyste do něj nemuseli znovu klikat
|
|
Packit |
1470ea |
this._textView.has_focus = true;
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
}
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
});
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
Zde používámě některé základní funkce jazyka JavaScript k tomu, aby náš tučňák promluvil. Když na to přijde, tučňáci mají rádi ryby, takže pokud zmíníte rybu, chceme, aby na to tučňák reagoval. K tomu použijeme metodu objektu String , který má JavaScript zabudovaný, vůči this.buffer.text , což vrací obsah našeho objektu TextBuffer .
|
|
Packit |
1470ea |
Protože chceme, aby se náš TextBuffer pokaždé, když kliknete na <gui>Send</gui> vymazal, nastavíme po té this.buffer.text na prázdný řetězec. Pak vrátím zaměření textovému zobrazení, takže můžete pokračovat v psaní, aniž byste na něj před tím museli klikat.
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Spustí aplikaci
|
|
Packit |
1470ea |
let app = new TextViewExample ();
|
|
Packit |
1470ea |
app.application.run (ARGV);
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
Nakonec vytvoříme novou instanci konečné třídy TextViewExample 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 |
const Gtk = imports.gi.Gtk;
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
class TextViewExample {
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Vytvoří vlastní aplikaci
|
|
Packit |
1470ea |
constructor() {
|
|
Packit |
1470ea |
this.application = new Gtk.Application({
|
|
Packit |
1470ea |
application_id: 'org.example.jstextview'
|
|
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 |
title: "Talk to a Penguin",
|
|
Packit |
1470ea |
default_height: 400,
|
|
Packit |
1470ea |
default_width: 440,
|
|
Packit |
1470ea |
border_width: 20 });
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Vytvoří popisek přes který k vám bude promlouvat tučňák
|
|
Packit |
1470ea |
this._penguin = new Gtk.Label ({
|
|
Packit |
1470ea |
height_request: 180,
|
|
Packit |
1470ea |
width_request: 400,
|
|
Packit |
1470ea |
label: "Squaaaak?",
|
|
Packit |
1470ea |
wrap: true });
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Vytvoří textové zobrazení, přes které můžete mluvit na tučňáka
|
|
Packit |
1470ea |
this.buffer = new Gtk.TextBuffer();
|
|
Packit |
1470ea |
this._textView = new Gtk.TextView ({
|
|
Packit |
1470ea |
buffer: this.buffer,
|
|
Packit |
1470ea |
editable: true,
|
|
Packit |
1470ea |
wrap_mode: Gtk.WrapMode.WORD });
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Vytvoří okno s posuvníky pro vložení textového zobrazení, aby
|
|
Packit |
1470ea |
// mohlo posouvat svůj obsah
|
|
Packit |
1470ea |
this._scrolled = new Gtk.ScrolledWindow ({
|
|
Packit |
1470ea |
hscrollbar_policy: Gtk.PolicyType.AUTOMATIC,
|
|
Packit |
1470ea |
vscrollbar_policy: Gtk.PolicyType.AUTOMATIC,
|
|
Packit |
1470ea |
shadow_type: Gtk.ShadowType.ETCHED_IN,
|
|
Packit |
1470ea |
height_request: 180,
|
|
Packit |
1470ea |
width_request: 400, });
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Vloží textové zobrazení do okna s posuvníky
|
|
Packit |
1470ea |
this._scrolled.add_with_viewport (this._textView);
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Vytvoří mřížku pro uspořádní widgetů
|
|
Packit |
1470ea |
this._grid = new Gtk.Grid ({
|
|
Packit |
1470ea |
halign: Gtk.Align.CENTER,
|
|
Packit |
1470ea |
valign: Gtk.Align.CENTER });
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Vloží popisek a textové zobrazení do mřížky, jeden nad druhý
|
|
Packit |
1470ea |
this._grid.attach (this._penguin, 0, 0, 1, 1);
|
|
Packit |
1470ea |
this._grid.attach (this._scrolled, 0, 1, 1, 1);
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Vytvoří tlačítko pro odeslání vaší zprávy tučňákovi
|
|
Packit |
1470ea |
this._send = new Gtk.Button ({
|
|
Packit |
1470ea |
halign: Gtk.Align.END,
|
|
Packit |
1470ea |
margin_top: 20,
|
|
Packit |
1470ea |
label: "Send" });
|
|
Packit |
1470ea |
this._send.connect ('clicked', this._chat.bind(this));
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Vytvoří mřížku pro poddružnou mřížku nahoře a tlačítko dole
|
|
Packit |
1470ea |
this._mainGrid = new Gtk.Grid ({
|
|
Packit |
1470ea |
halign: Gtk.Align.CENTER,
|
|
Packit |
1470ea |
valign: Gtk.Align.CENTER });
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Přidá poddružnou mřížku a tlačítko do hlavní mřížky
|
|
Packit |
1470ea |
this._mainGrid.attach (this._grid, 0, 0, 1, 1);
|
|
Packit |
1470ea |
this._mainGrid.attach (this._send, 0, 1, 1, 1);
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Připojí hlavní mřížku do okna
|
|
Packit |
1470ea |
this._window.add (this._mainGrid);
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Zobrazí okno a všechny jeho synovské widgety
|
|
Packit |
1470ea |
this._window.show_all();
|
|
Packit |
1470ea |
}
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
_chat() {
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Vytvoří náhodné číslo, které určí, co tučňák řekne
|
|
Packit |
1470ea |
this.number = Math.floor ((Math.random() * 3) + 1);
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Řekli jste právě něco?
|
|
Packit |
1470ea |
if (this.buffer.text) {
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Zmínili jste rybu?
|
|
Packit |
1470ea |
if (this.buffer.text.match (/fish/gi)) {
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Tučňák musí zaskřehovat o rybě
|
|
Packit |
1470ea |
if (this.number == 1)
|
|
Packit |
1470ea |
this._penguin.set_label ("FISH!");
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
else if (this.number == 2)
|
|
Packit |
1470ea |
this._penguin.set_label ("Fish fish fish fish. Fish!");
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
else
|
|
Packit |
1470ea |
this._penguin.set_label ("Fish? Fish fish fish. Fish fish. FISH!");
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
}
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Myslím, že jsem se nezmínil o rybě
|
|
Packit |
1470ea |
else {
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Tučňák pokecá o všedních záležitostech tučňáků
|
|
Packit |
1470ea |
if (this.number == 1)
|
|
Packit |
1470ea |
this._penguin.set_label ("SQUAAK!");
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
else if (this.number == 2)
|
|
Packit |
1470ea |
this._penguin.set_label ("Ork ork ork ork squaak. Squaak squaak! *waves flippers*");
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
else
|
|
Packit |
1470ea |
this._penguin.set_label ("Ork ork ork ork ork?");
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
}
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
}
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Vymaže vyrovnávací paměť
|
|
Packit |
1470ea |
this.buffer.text = "";
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Předá zaměření zpět textovému zobrazení, abyste do něj nemuseli znovu klikat
|
|
Packit |
1470ea |
this._textView.has_focus = true;
|
|
Packit |
1470ea |
}
|
|
Packit |
1470ea |
};
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
// Spustí aplikaci
|
|
Packit |
1470ea |
let app = new TextViewExample ();
|
|
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.Button.html">Gtk.Button</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.Label.html">Gtk.Label</link> </item>
|
|
Packit |
1470ea |
<item><link href="http://www.roojs.org/seed/gir-1.2-gtk-3.0/gjs/Gtk.RadioButton.html">Gtk.RadioButton</link> </item>
|
|
Packit |
1470ea |
<item><link href="http://www.roojs.org/seed/gir-1.2-gtk-3.0/gjs/Gtk.ScrolledWindow.html">Gtk.ScrolledWindow</link> </item>
|
|
Packit |
1470ea |
<item><link href="http://www.roojs.org/seed/gir-1.2-gtk-3.0/gjs/Gtk.TextBuffer.html">Gtk.TextBuffer</link> </item>
|
|
Packit |
1470ea |
<item><link href="http://www.roojs.org/seed/gir-1.2-gtk-3.0/gjs/Gtk.TextView.html">Gtk.TextView</link> </item>
|
|
Packit |
1470ea |
</list>
|
|
Packit |
1470ea |
</section>
|
|
Packit |
1470ea |
</page>
|