build
debian
demos
docs
examples
Makefile.am
bloatpad.c
builder.c
builder.ui
drawing.c
grid-packing.c
hello-world.c
window-default.c
gdk
gtk
libgail-util
m4macros
modules
perf
po
po-properties
tests
AUTHORS
COPYING
ChangeLog.gtk-async-file-chooser
ChangeLog.gtk-printing
ChangeLog.pre-1-0
ChangeLog.pre-1-2
ChangeLog.pre-2-0
ChangeLog.pre-2-10
ChangeLog.pre-2-12
ChangeLog.pre-2-14
ChangeLog.pre-2-16
ChangeLog.pre-2-2
ChangeLog.pre-2-4
ChangeLog.pre-2-6
ChangeLog.pre-2-8
HACKING
INSTALL.in
MAINTAINERS
Makefile.am
Makefile.decl
NEWS
NEWS.pre-1-0
README.commits
README.in
README.win32
acinclude.m4
autogen.sh
config.h.win32.in
configure.ac
gail-3.0-uninstalled.pc.in
gail-3.0.pc.in
gdk-3.0.pc.in
git.mk
gtk+-3.0-uninstalled.pc.in
gtk+-3.0.pc.in
gtk+-unix-print-3.0.pc.in
gtk+.doap
gtk+.spec.in
gtk-engine-check-abi.sh
gtk-zip.sh.in
makecopyright
makefile.msc
sanitize-la.sh
sanity_check
74 lines
2.3 KiB
C
74 lines
2.3 KiB
C
#include <gtk/gtk.h>
|
|
|
|
static void
|
|
print_hello (GtkWidget *widget,
|
|
gpointer data)
|
|
{
|
|
g_print ("Hello World\n");
|
|
}
|
|
|
|
int
|
|
main (int argc,
|
|
char *argv[])
|
|
{
|
|
GtkWidget *window;
|
|
GtkWidget *grid;
|
|
GtkWidget *button;
|
|
|
|
/* This is called in all GTK applications. Arguments are parsed
|
|
* from the command line and are returned to the application.
|
|
*/
|
|
gtk_init (&argc, &argv);
|
|
|
|
/* create a new window, and set its title */
|
|
window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
|
|
gtk_window_set_title (GTK_WINDOW (window), "Grid");
|
|
g_signal_connect (window, "destroy", G_CALLBACK (gtk_main_quit), NULL);
|
|
gtk_container_set_border_width (GTK_CONTAINER (window), 10);
|
|
|
|
/* Here we construct the container that is going pack our buttons */
|
|
grid = gtk_grid_new ();
|
|
|
|
/* Pack the container in the window */
|
|
gtk_container_add (GTK_CONTAINER (window), grid);
|
|
|
|
button = gtk_button_new_with_label ("Button 1");
|
|
g_signal_connect (button, "clicked", G_CALLBACK (print_hello), NULL);
|
|
|
|
/* Place the first button in the grid cell (0, 0), and make it fill
|
|
* just 1 cell horizontally and vertically (ie no spanning)
|
|
*/
|
|
gtk_grid_attach (GTK_GRID (grid), button, 0, 0, 1, 1);
|
|
|
|
button = gtk_button_new_with_label ("Button 2");
|
|
g_signal_connect (button, "clicked", G_CALLBACK (print_hello), NULL);
|
|
|
|
/* Place the second button in the grid cell (1, 0), and make it fill
|
|
* just 1 cell horizontally and vertically (ie no spanning)
|
|
*/
|
|
gtk_grid_attach (GTK_GRID (grid), button, 1, 0, 1, 1);
|
|
|
|
button = gtk_button_new_with_label ("Quit");
|
|
g_signal_connect (button, "clicked", G_CALLBACK (gtk_main_quit), NULL);
|
|
|
|
/* Place the Quit button in the grid cell (0, 1), and make it
|
|
* span 2 columns.
|
|
*/
|
|
gtk_grid_attach (GTK_GRID (grid), button, 0, 1, 2, 1);
|
|
|
|
/* Now that we are done packing our widgets, we show them all
|
|
* in one go, by calling gtk_widget_show_all() on the window.
|
|
* This call recursively calls gtk_widget_show() on all widgets
|
|
* that are contained in the window, directly or indirectly.
|
|
*/
|
|
gtk_widget_show_all (window);
|
|
|
|
/* All GTK applications must have a gtk_main(). Control ends here
|
|
* and waits for an event to occur (like a key press or a mouse event),
|
|
* until gtk_main_quit() is called.
|
|
*/
|
|
gtk_main ();
|
|
|
|
return 0;
|
|
}
|