<?xml version="1.0" encoding="utf-8"?>
<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="messagedialog.c" xml:lang="cs">
<info>
<title type="text">MessageDialog (C)</title>
<link type="guide" xref="c#windows"/>
<link type="seealso" xref="dialog.c"/>
<revision version="0.2" date="2012-08-07" status="draft"/>
<credit type="author copyright">
<name>Monica Kochofar</name>
<email its:translate="no">monicakochofar@gmail.com</email>
<years>2012</years>
</credit>
<desc>Okno se zprávou</desc>
</info>
<title>MessageDialog</title>
<media type="image" mime="image/png" src="media/messagedialog.png"/>
<p>Modální dialogové okno se zprávou, které způsobí, že svět vybuchne.</p>
<note><p>Když chcete aplikaci otestovat, stačí po jejím spuštění kliknout na nabídku <gui>Message Dialog</gui>, která se objeví v horní liště obrazovky.</p></note>
<code mime="text/x-csrc" style="numbered">
#include <gtk/gtk.h>
/* Funkce zpětného volání reagující na signál "response" od uživatele
* v dialogovém okně se zprávou
* Tato funkce se používá ke komunikaci s uživatelem v terminálu
*/
static void
on_response (GtkDialog *dialog,
gint response_id,
gpointer user_data)
{
/* Když kliknutí tlačítko odpoví OK (response_id je -5) */
if (response_id == GTK_RESPONSE_OK)
g_print ("*boom*\n");
/* Když kliknuté tlačítko odpoví CANCEL (response_id je -6) */
else if (response_id == GTK_RESPONSE_CANCEL)
g_print ("good choice\n");
/* Když je dialogové okno zrušeno (například zmáčknutím Esc) */
else if (response_id == GTK_RESPONSE_DELETE_EVENT)
g_print ("dialog closed or cancelled\n");
/* Zlikviduje dialogové okno po té, co se uskutečnila jedna z akcí výše */
gtk_widget_destroy (GTK_WIDGET (dialog));
}
/* Funkce zpětného volání pro signál "activate" náležející widgetu
* SimpleAction message_action
* Tato funkce se použije ke zobrazení dialogového okna se zprávou
*/
static void
message_cb (GSimpleAction *simple,
GVariant *parameter,
gpointer user_data)
{
/* Proměnná parent v tomto případě představuje okno */
GtkWidget *message_dialog;
GtkWindow *parent = user_data;
/* Vytvoří nové dialogové okno se zprávou a nastaví jeho parametry následovně:
* příznaky - zajistí modální režim
* (modální okno brání v interakci s ostatními okny aplikace)
* typ zprávy - nekritická varovná zpráva
* typ tlačítek - použije tlačítka OK a Cancel
* zpráva - text, který uživatel v dialogovém okně uvidí
*/
message_dialog = gtk_message_dialog_new (parent, GTK_DIALOG_MODAL,
GTK_MESSAGE_WARNING,
GTK_BUTTONS_OK_CANCEL,
"This action will cause the universe to stop existing.");
gtk_widget_show_all (message_dialog);
g_signal_connect (GTK_DIALOG (message_dialog), "response",
G_CALLBACK (on_response), NULL);
}
static void
activate (GtkApplication *app,
gpointer user_data)
{
GtkWidget *window;
GtkWidget *label;
GSimpleAction *message_action;
/* Vytvoří okno s názvem a výchozí velikostí */
window = gtk_application_window_new (app);
gtk_window_set_title (GTK_WINDOW (window), "GMenu Example");
gtk_window_set_default_size (GTK_WINDOW (window), 400, 200);
/* Vytvoří popisek a přidá jej do okna */
label = gtk_label_new ("This application goes boom!");
gtk_container_add (GTK_CONTAINER (window), label);
/* Vytvoří novou jednoduchou akci, jako parametr type ji předá NULL. Ten
* bude vždy NULL pro akce vyvolané z nabídky (například kliknutí na tlačítko
* "ok" nebo "cancel")
*/
message_action = g_simple_action_new ("message", NULL);
/* Napojí signál "activate" na příslušnou funkci zpětného volání */
g_signal_connect (message_action, "activate", G_CALLBACK (message_cb),
GTK_WINDOW (window));
/* Přidá message_action do celkové mapy akcí. Mapa akcí je rozhraní, které
* obsahuje řadu pojmenovaných instancí GAction (jako je message_action)
*/
g_action_map_add_action (G_ACTION_MAP (window), G_ACTION (message_action));
gtk_widget_show_all (window);
}
/* Funkce zpětného volání pro signál "activate" od akce "quit"
* ve funkci hned za touto
*/
static void
quit_cb (GSimpleAction *simple,
GVariant *parameter,
gpointer user_data)
{
GApplication *application = user_data;
g_application_quit (application);
}
/* Spouštěcí funkce pro nabídku, kterou vytváříme v této ukázce */
static void
startup (GApplication *app,
gpointer user_data)
{
GMenu *menu;
GSimpleAction *quit_action;
/* Inicializuje GMenu a přidá do něj položku s textem "Message" a akcí
* "win.message". Přidá také další položku s textem "Quit" a akcí
* "app.quit"
*/
menu = g_menu_new ();
g_menu_append (menu, "Message", "win.message");
g_menu_append (menu, "Quit", "app.quit");
/* Vytvoří novou jednoduchou akci pro aplikaci (v tomto případě do je
* akce "quit"
*/
quit_action = g_simple_action_new ("quit", NULL);
/* Zajistí, že právě vytvořená nabídka bude bude pro celou aplikaci */
gtk_application_set_app_menu (GTK_APPLICATION (app), G_MENU_MODEL (menu));
g_signal_connect (quit_action,
"activate",
G_CALLBACK (quit_cb),
app);
g_action_map_add_action (G_ACTION_MAP (app), G_ACTION (quit_action));
}
/* Spouštecí funkce aplikace */
int
main (int argc, char **argv)
{
GtkApplication *app;
int status;
app = gtk_application_new ("org.gtk.example", G_APPLICATION_FLAGS_NONE);
g_signal_connect (app, "activate", G_CALLBACK (activate), NULL);
g_signal_connect (app, "startup", G_CALLBACK (startup), NULL);
status = g_application_run (G_APPLICATION (app), argc, argv);
g_object_unref (app);
return status;
}
</code>
<p>V této ukázce se používá následující:</p>
<list>
<item><p><link href="http://developer.gnome.org/gtk3/3.4/GtkApplication.html">GtkApplication</link></p></item>
<item><p><link href="http://developer.gnome.org/gio/stable/GApplication.html">GApplication</link></p></item>
<item><p><link href="http://developer.gnome.org/gtk3/3.4/GtkWindow.html">GtkWindow</link></p></item>
<item><p><link href="http://developer.gnome.org/gtk3/stable/GtkMessageDialog.html">GtkMessageDialog</link></p></item>
<item><p><link href="http://developer.gnome.org/gio/stable/GSimpleAction.html#g-simple-action-new">GSimpleAction</link></p></item>
<item><p><link href="http://developer.gnome.org/gio/stable/GActionMap.html">GActionMap</link></p></item>
<item><p><link href="http://developer.gnome.org/gio/stable/GMenu.html">GMenu</link></p></item>
</list>
</page>