]> Pileus Git - ~andy/gtk/blobdiff - examples/buttons/buttons.c
Use gtk_box_new() instead gtk_[v|h]box_new()
[~andy/gtk] / examples / buttons / buttons.c
index e6eb5561ad94bcdaa062df87c5be174d608b8438..df68fcb42f8342b3f57c68613dbc6aaebb1712ba 100644 (file)
@@ -1,65 +1,51 @@
-/* example-start buttons buttons.c */
 
+#include <stdlib.h>
 #include <gtk/gtk.h>
 
 /* Create a new hbox with an image and a label packed into it
  * and return the box. */
 
-GtkWidget *xpm_label_box( GtkWidget *parent,
-                          gchar     *xpm_filename,
-                          gchar     *label_text )
+static GtkWidget *xpm_label_box( gchar     *xpm_filename,
+                                 gchar     *label_text )
 {
-    GtkWidget *box1;
+    GtkWidget *box;
     GtkWidget *label;
-    GtkWidget *pixmapwid;
-    GdkPixmap *pixmap;
-    GdkBitmap *mask;
-    GtkStyle *style;
+    GtkWidget *image;
 
-    /* Create box for xpm and label */
-    box1 = gtk_hbox_new (FALSE, 0);
-    gtk_container_border_width (GTK_CONTAINER (box1), 2);
+    /* Create box for image and label */
+    box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, FALSE, 0);
+    gtk_container_set_border_width (GTK_CONTAINER (box), 2);
 
-    /* Get the style of the button to get the
-     * background color. */
-    style = gtk_widget_get_style(parent);
-
-    /* Now on to the xpm stuff */
-    pixmap = gdk_pixmap_create_from_xpm (parent->window, &mask,
-                                        &style->bg[GTK_STATE_NORMAL],
-                                        xpm_filename);
-    pixmapwid = gtk_pixmap_new (pixmap, mask);
+    /* Now on to the image stuff */
+    image = gtk_image_new_from_file (xpm_filename);
 
     /* Create a label for the button */
     label = gtk_label_new (label_text);
 
-    /* Pack the pixmap and label into the box */
-    gtk_box_pack_start (GTK_BOX (box1),
-                       pixmapwid, FALSE, FALSE, 3);
-
-    gtk_box_pack_start (GTK_BOX (box1), label, FALSE, FALSE, 3);
+    /* Pack the image and label into the box */
+    gtk_box_pack_start (GTK_BOX (box), image, FALSE, FALSE, 3);
+    gtk_box_pack_start (GTK_BOX (box), label, FALSE, FALSE, 3);
 
-    gtk_widget_show(pixmapwid);
-    gtk_widget_show(label);
+    gtk_widget_show (image);
+    gtk_widget_show (label);
 
-    return(box1);
+    return box;
 }
 
 /* Our usual callback function */
-void callback( GtkWidget *widget,
-               gpointer   data )
+static void callback( GtkWidget *widget,
+                      gpointer   data )
 {
     g_print ("Hello again - %s was pressed\n", (char *) data);
 }
 
-
 int main( int   argc,
           char *argv[] )
 {
     /* GtkWidget is the storage type for widgets */
     GtkWidget *window;
     GtkWidget *button;
-    GtkWidget *box1;
+    GtkWidget *box;
 
     gtk_init (&argc, &argv);
 
@@ -69,33 +55,31 @@ int main( int   argc,
     gtk_window_set_title (GTK_WINDOW (window), "Pixmap'd Buttons!");
 
     /* It's a good idea to do this for all windows. */
-    gtk_signal_connect (GTK_OBJECT (window), "destroy",
-                       GTK_SIGNAL_FUNC (gtk_exit), NULL);
-
-    gtk_signal_connect (GTK_OBJECT (window), "delete_event",
-                       GTK_SIGNAL_FUNC (gtk_exit), NULL);
+    g_signal_connect (G_OBJECT (window), "destroy",
+                     G_CALLBACK (gtk_main_quit), NULL);
 
+    g_signal_connect (G_OBJECT (window), "delete-event",
+                     G_CALLBACK (gtk_main_quit), NULL);
 
     /* Sets the border width of the window. */
-    gtk_container_border_width (GTK_CONTAINER (window), 10);
-    gtk_widget_realize(window);
+    gtk_container_set_border_width (GTK_CONTAINER (window), 10);
 
     /* Create a new button */
     button = gtk_button_new ();
 
     /* Connect the "clicked" signal of the button to our callback */
-    gtk_signal_connect (GTK_OBJECT (button), "clicked",
-                       GTK_SIGNAL_FUNC (callback), (gpointer) "cool button");
+    g_signal_connect (G_OBJECT (button), "clicked",
+                     G_CALLBACK (callback), (gpointer) "cool button");
 
     /* This calls our box creating function */
-    box1 = xpm_label_box(window, "info.xpm", "cool button");
+    box = xpm_label_box ("info.xpm", "cool button");
 
     /* Pack and show all our widgets */
-    gtk_widget_show(box1);
+    gtk_widget_show (box);
 
-    gtk_container_add (GTK_CONTAINER (button), box1);
+    gtk_container_add (GTK_CONTAINER (button), box);
 
-    gtk_widget_show(button);
+    gtk_widget_show (button);
 
     gtk_container_add (GTK_CONTAINER (window), button);
 
@@ -104,6 +88,5 @@ int main( int   argc,
     /* Rest in gtk_main and wait for the fun to begin! */
     gtk_main ();
 
-    return(0);
+    return 0;
 }
-/* example-end */