Home / LinuxUser / 2002 / 02 / GUI-Programme erstellen mit Glade

Newsletter abonnieren

Lies uns auf...

Folge LinuxCommunity auf Twitter

Top-Beiträge

Mandriva gibt Distribution in die Hände der Community
(268 Punkte bei 24 Stimmen)
Neues vom Systemd
(161 Punkte bei 4 Stimmen)
Mandriva in Nöten
(161 Punkte bei 4 Stimmen)

Heftarchiv

LinuxUser Heftarchiv

EasyLinux Heftarchiv

Ubuntu User Heftarchiv

Ubuntu User Heftarchiv

Partner-Links:

Shopping
Topsuche
 
Yatego Deutschlands größte Shoppingmall. 10000 Shops,
3.5 Mio Artikel. Alle Bestseller, Servertechnik und Technik Themenwelten.

Notebooks und Netzwerkhardware bei Mercateo günstig kaufen.
Internet Telefonie mit VoIP Telefonen von Gigaset
Das B2B Portal www.Linx.de informiert über Produkte und Dienstleistungen.
Günstige Digitalkameras finden Sie im Preisvergleich.

Lichtung im GTK-Wald

GUI-Programme erstellen mit Glade

Das GUI des GUI-Builders

Ist Glade einmal installiert, startet es mit glade &. Daraufhin erscheinen drei Fenster: das Projekt-, das Paletten- und das Eigenschaftsfenster.

Abbildung 1: Glade auf einen Blick

Ersteres (links oben in Abbildung 1) bildet die Schaltzentrale, über die sich das aktuelle GUI-Projekt speichern oder ein vorhandenes laden lässt, aber auch die zwei anderen Fenster sowie der ebenfalls in Abbildung 1 gezeigte Widget-Baum zu öffnen sind. Hier können auch Projektoptionen – etwa Projektname, Programmiersprache, Verzeichnis- und Dateinamen – geändert werden.

Das Palettenfenster stellt die Widgets zur Verfügung, aus denen man die Bedieneroberfläche aufbaut. Sie sind in zwei Kategorien unterteilt: GTK+ Basic und GTK+ Additional. Wird Glade mit GNOME-Support installiert, gibt es noch eine dritte namens Gnome.

Die Namen und die aktuellen Eigenschaften eines angeklickten Widgets werden im Eigenschaftsfenster angezeigt. In dessen Karteikarte Signale können Handler-Funktionen an die verschiedenen Ereignissen des aktuellen Widgets gebunden werden.

Der Widget-Baum liefert eine Übersicht über die gesamte Widget-Struktur eines Projekts. Außerdem genügt es, auf eines der in ihm dargestellten Widgets zu klicken, damit dessen Attribute im Eigenschaftsfenster angezeigt werden.

Hello World!

Damit all dies nicht zu theoretisch bleibt, entwickeln wir im folgenden eine sehr einfache "Hallo-Welt"-Applikation (Abbildung 4). Sie besteht aus nur einem Fenster mit einem Knopf, der mit dem originellen Label Hello World! beschriftet ist. Wird der Button angeklickt, gibt die Applikation den Text "Hello World!" in der Konsole aus, aus der sie aufgerufen wurde. Den kompletten Quelltext finden Sie auf der Heft-CD oder unter [3].

Wie jede GUI-Applikation braucht auch diese ein Hauptfenster, in das die übrigen Widgets eingefügt werden: Klickt man auf das Window-Icon in der oberen linken Ecke des Palettenfensters, zeichnet Glade ein neues Fenster, in das man andere Widgets von der Palette hinzufügen kann. Im Eigenschaftsfenster legt man dann den Namen des Fensters, dessen Überschrift, Position usw. fest.

Wichtig ist dabei die Karteikarte Signale (Abbildung 2): Hier wird das Signal delete_event an den Handler on_hello_window_delete_event() gebunden. Dieser sorgt dafür, dass das Programm ordentlich beendet wird, wenn der spätere User das Symbol zum Fensterschließen drückt. Vergessen Sie nach der Angabe des Signalnamens nicht, den Knopf Hinzufügen anzuklicken, damit die Verbindung zwischen Signal und Handler tatsächlich hergestellt wird.

Abbildung 2: Verknüpfen von Ereignissen und Handler-Funktionen

Insbesondere am Anfang kennt man noch nicht alle Signale zu einem bestimmten Widget. Dem hilft der Knopf mit der Beschriftung ... neben dem Feld zur Eingabe von Signalnamen ab. Ein Klick darauf, und schon listet ein Dialog wie in Abbildung 3 rechts die Signale zu den jeweiligen Widgets nach Klassen geordnet auf. Sie lassen sich nun per Mausklick auswählen.

Bislang ist das Hauptfenster unserer Applikation aber noch leer. Das lässt sich schnell ändern: Man klickt einmal auf das Knopf-Symbol im Palettenfenster, anschließend auf die leere Fensterschablone – und voilá: Ein Knopf erblickt das Licht der Welt. Im Eigenschaftsfenster stellt man die Knopf-Eigenschaften beliebig ein. Wichtig ist hier, das Signal clicked anzubinden (Abbildung 3).

Abbildung 3: Wird der Button geklickt, muss ein Handler arbeiten

Einem Freund empfehlen    Druckansicht Bookmark and Share
Kommentare

Hits
Wertung: 0 Punkte (0 Stimmen)

Schlecht Gut

Infos zur Publikation

Infos zur Publikation

LinuxUser 06/2012

Aktuelle Ausgabe kaufen:

Heft bestellen Heft als PDF kaufen

LinuxUser erscheint monatlich und kostet in der Nomedia-Ausgabe EUR 5,50 und mit DVD EUR 8,50. Weitere Informationen zum Heft finden Sie auf der LinuxUser-Homepage.

Im LinuxUser-Probeabo erhalten Sie drei Ausgaben für 3 Euro. Das Jahresabo (ab EUR 56,10) können Sie im LNM-Shop bestellen.

Tipp der Woche

Adobe AIR
Adobe-AIR-Programme installieren und (manuell) starten
Tim Schürmann, 14.05.2012 13:09, 0 Kommentare

Es gibt sie noch: neue Anwendungen, die Adobes Integrated Runtime voraussetzen. Aktuellstes und vermutlich auch größtes Beispiel ist das Adventure Botanicula

Aktuelle Fragen

gibt es ein Kommandozeilen Tool, um ein X11-Fenster in ein Anderes einzubetten?
GoaSkin , 21.05.2012 16:44, 0 Antworten
Das XEmbed-Protokoll ist u.A. dazu gedacht, dass man eine X11-Anwendung in eine andere wie ein Wi...
Apache2, Options -Indexes geht nicht
no no, 12.05.2012 19:01, 8 Antworten
Habe in apache2.conf folgendes stehen: Options -Indexes ...
LInux auf Dell LS H500
Andreas Endresl, 09.05.2012 08:54, 2 Antworten
Habe einen alten Dell Latitude LS H500 nur mit ext. Floppy und CD es geht nur immer eines von den...
Datenwiederherstellung unter Ubuntu 12.04 mit "Simple Backup" nach Umzug von Linux Mint
Christian Lottmann, 07.05.2012 13:33, 0 Antworten
Vor dem Umzug auf Ubuntu 12.04 habe ich unter Linux MInt mit "Simple Backup" voll (15.4.2012) und...
DKMS für den propritären NVIDIA-Treiber
Commander Data, 26.04.2012 22:02, 2 Antworten
Hallo an die Gemeinde. Ich habe hier ein interessantes Stück openSuSE gefunden. http://forums.op...