scrolledwin.c 3.19 KB
Newer Older
1

2
#include <stdio.h>
3 4
#include <gtk/gtk.h>

Matthias Clasen's avatar
Matthias Clasen committed
5 6
static void destroy( GtkWidget *widget,
                     gpointer   data )
7
{
8
    gtk_main_quit ();
9 10
}

11 12
int main( int   argc,
          char *argv[] )
13 14 15 16 17 18 19 20 21 22 23
{
    static GtkWidget *window;
    GtkWidget *scrolled_window;
    GtkWidget *table;
    GtkWidget *button;
    char buffer[32];
    int i, j;
    
    gtk_init (&argc, &argv);
    
    /* Create a new dialog window for the scrolled window to be
24
     * packed into.  */
25
    window = gtk_dialog_new ();
26 27
    g_signal_connect (G_OBJECT (window), "destroy",
		      G_CALLBACK (destroy), NULL);
28
    gtk_window_set_title (GTK_WINDOW (window), "GtkScrolledWindow example");
29
    gtk_container_set_border_width (GTK_CONTAINER (window), 0);
30
    gtk_widget_set_size_request (window, 300, 300);
31 32 33 34
    
    /* create a new scrolled window. */
    scrolled_window = gtk_scrolled_window_new (NULL, NULL);
    
35
    gtk_container_set_border_width (GTK_CONTAINER (scrolled_window), 10);
36 37 38
    
    /* the policy is one of GTK_POLICY AUTOMATIC, or GTK_POLICY_ALWAYS.
     * GTK_POLICY_AUTOMATIC will automatically decide whether you need
39
     * scrollbars, whereas GTK_POLICY_ALWAYS will always leave the scrollbars
40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
     * there.  The first one is the horizontal scrollbar, the second, 
     * the vertical. */
    gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_window),
                                    GTK_POLICY_AUTOMATIC, GTK_POLICY_ALWAYS);
    /* The dialog window is created with a vbox packed into it. */								
    gtk_box_pack_start (GTK_BOX (GTK_DIALOG(window)->vbox), scrolled_window, 
			TRUE, TRUE, 0);
    gtk_widget_show (scrolled_window);
    
    /* create a table of 10 by 10 squares. */
    table = gtk_table_new (10, 10, FALSE);
    
    /* set the spacing to 10 on x and 10 on y */
    gtk_table_set_row_spacings (GTK_TABLE (table), 10);
    gtk_table_set_col_spacings (GTK_TABLE (table), 10);
    
    /* pack the table into the scrolled window */
57 58
    gtk_scrolled_window_add_with_viewport (
                   GTK_SCROLLED_WINDOW (scrolled_window), table);
59 60 61 62 63
    gtk_widget_show (table);
    
    /* this simply creates a grid of toggle buttons on the table
     * to demonstrate the scrolled window. */
    for (i = 0; i < 10; i++)
64 65 66 67 68 69 70
       for (j = 0; j < 10; j++) {
          sprintf (buffer, "button (%d,%d)\n", i, j);
	  button = gtk_toggle_button_new_with_label (buffer);
	  gtk_table_attach_defaults (GTK_TABLE (table), button,
	                             i, i+1, j, j+1);
          gtk_widget_show (button);
       }
71 72 73
    
    /* Add a "close" button to the bottom of the dialog */
    button = gtk_button_new_with_label ("close");
74 75
    g_signal_connect_swapped (G_OBJECT (button), "clicked",
			      G_CALLBACK (gtk_widget_destroy),
76
			      G_OBJECT (window));
77 78 79
    
    /* this makes it so the button is the default. */
    
80
    gtk_widget_set_can_default (button, TRUE);
81 82 83 84 85 86 87 88 89 90 91
    gtk_box_pack_start (GTK_BOX (GTK_DIALOG (window)->action_area), button, TRUE, TRUE, 0);
    
    /* This grabs this button to be the default button. Simply hitting
     * the "Enter" key will cause this button to activate. */
    gtk_widget_grab_default (button);
    gtk_widget_show (button);
    
    gtk_widget_show (window);
    
    gtk_main();
    
92
    return 0;
93
}