]> Pileus Git - ~andy/gtk/commitdiff
subsections on Aspect Frames and Paned widgets.
authorBST 1998 Tony Gale <gale@gtk.org>
Sat, 4 Apr 1998 11:31:51 +0000 (11:31 +0000)
committerTony Gale <gale@src.gnome.org>
Sat, 4 Apr 1998 11:31:51 +0000 (11:31 +0000)
Sat Apr  4 12:23:23 BST 1998  Tony Gale  <gale@gtk.org>

        * docs/gtk_tut.sgml: (gtk-crichton-980403-0) subsections on
          Aspect Frames and Paned widgets.

        * examples/paned examples/aspectframe: new examples

13 files changed:
ChangeLog
ChangeLog.pre-2-0
ChangeLog.pre-2-10
ChangeLog.pre-2-2
ChangeLog.pre-2-4
ChangeLog.pre-2-6
ChangeLog.pre-2-8
docs/gtk_tut.sgml
docs/tutorial/gtk_tut.sgml
examples/aspectframe/Makefile [new file with mode: 0644]
examples/aspectframe/aspectframe.c [new file with mode: 0644]
examples/paned/Makefile [new file with mode: 0644]
examples/paned/paned.c [new file with mode: 0644]

index 4b73725934f6a69a99ac0e1c4e1cc169e3b23ebc..923e4d2cd98dda5fbe19f1fe7747afe128ee0a14 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,10 @@
+Sat Apr  4 12:23:23 BST 1998  Tony Gale  <gale@gtk.org>
+
+       * docs/gtk_tut.sgml: (gtk-crichton-980403-0) subsections on
+         Aspect Frames and Paned widgets.
+
+       * examples/paned examples/aspectframe: new examples
+
 Fri Apr  3 23:15:55 1998  Owen Taylor  <owt1@cornell.edu>
 
        * gtk/gtktext.c: Test for need to recompute geometry with
index 4b73725934f6a69a99ac0e1c4e1cc169e3b23ebc..923e4d2cd98dda5fbe19f1fe7747afe128ee0a14 100644 (file)
@@ -1,3 +1,10 @@
+Sat Apr  4 12:23:23 BST 1998  Tony Gale  <gale@gtk.org>
+
+       * docs/gtk_tut.sgml: (gtk-crichton-980403-0) subsections on
+         Aspect Frames and Paned widgets.
+
+       * examples/paned examples/aspectframe: new examples
+
 Fri Apr  3 23:15:55 1998  Owen Taylor  <owt1@cornell.edu>
 
        * gtk/gtktext.c: Test for need to recompute geometry with
index 4b73725934f6a69a99ac0e1c4e1cc169e3b23ebc..923e4d2cd98dda5fbe19f1fe7747afe128ee0a14 100644 (file)
@@ -1,3 +1,10 @@
+Sat Apr  4 12:23:23 BST 1998  Tony Gale  <gale@gtk.org>
+
+       * docs/gtk_tut.sgml: (gtk-crichton-980403-0) subsections on
+         Aspect Frames and Paned widgets.
+
+       * examples/paned examples/aspectframe: new examples
+
 Fri Apr  3 23:15:55 1998  Owen Taylor  <owt1@cornell.edu>
 
        * gtk/gtktext.c: Test for need to recompute geometry with
index 4b73725934f6a69a99ac0e1c4e1cc169e3b23ebc..923e4d2cd98dda5fbe19f1fe7747afe128ee0a14 100644 (file)
@@ -1,3 +1,10 @@
+Sat Apr  4 12:23:23 BST 1998  Tony Gale  <gale@gtk.org>
+
+       * docs/gtk_tut.sgml: (gtk-crichton-980403-0) subsections on
+         Aspect Frames and Paned widgets.
+
+       * examples/paned examples/aspectframe: new examples
+
 Fri Apr  3 23:15:55 1998  Owen Taylor  <owt1@cornell.edu>
 
        * gtk/gtktext.c: Test for need to recompute geometry with
index 4b73725934f6a69a99ac0e1c4e1cc169e3b23ebc..923e4d2cd98dda5fbe19f1fe7747afe128ee0a14 100644 (file)
@@ -1,3 +1,10 @@
+Sat Apr  4 12:23:23 BST 1998  Tony Gale  <gale@gtk.org>
+
+       * docs/gtk_tut.sgml: (gtk-crichton-980403-0) subsections on
+         Aspect Frames and Paned widgets.
+
+       * examples/paned examples/aspectframe: new examples
+
 Fri Apr  3 23:15:55 1998  Owen Taylor  <owt1@cornell.edu>
 
        * gtk/gtktext.c: Test for need to recompute geometry with
index 4b73725934f6a69a99ac0e1c4e1cc169e3b23ebc..923e4d2cd98dda5fbe19f1fe7747afe128ee0a14 100644 (file)
@@ -1,3 +1,10 @@
+Sat Apr  4 12:23:23 BST 1998  Tony Gale  <gale@gtk.org>
+
+       * docs/gtk_tut.sgml: (gtk-crichton-980403-0) subsections on
+         Aspect Frames and Paned widgets.
+
+       * examples/paned examples/aspectframe: new examples
+
 Fri Apr  3 23:15:55 1998  Owen Taylor  <owt1@cornell.edu>
 
        * gtk/gtktext.c: Test for need to recompute geometry with
index 4b73725934f6a69a99ac0e1c4e1cc169e3b23ebc..923e4d2cd98dda5fbe19f1fe7747afe128ee0a14 100644 (file)
@@ -1,3 +1,10 @@
+Sat Apr  4 12:23:23 BST 1998  Tony Gale  <gale@gtk.org>
+
+       * docs/gtk_tut.sgml: (gtk-crichton-980403-0) subsections on
+         Aspect Frames and Paned widgets.
+
+       * examples/paned examples/aspectframe: new examples
+
 Fri Apr  3 23:15:55 1998  Owen Taylor  <owt1@cornell.edu>
 
        * gtk/gtktext.c: Test for need to recompute geometry with
index 6365508e26f588742c25b125becee6cb7dc74353..4319216073e5c38898b7615bf9c69d4e15789951 100644 (file)
@@ -9,7 +9,7 @@
 <author>Ian Main <tt><htmlurl url="mailto:imain@gtk.org"
                              name="&lt;imain@gtk.org&gt;"></tt>,
 Tony Gale <tt><htmlurl url="mailto:gale@gtk.org"
-                             name="&lt;gale@gtk.org&gt;"></tt
+                             name="&lt;gale@gtk.org&gt;"></tt>
 <date>March 29th, 1998
 
 <!-- ***************************************************************** -->
@@ -3801,9 +3801,9 @@ direction, and the second, the adjustment for the vertical direction.
 These are almost always set to NULL.
 
 <tscreen><verb>
-void gtk_scrolled_window_set_policy      (GtkScrolledWindow *scrolled_window,
-                                          GtkPolicyType      hscrollbar_policy,
-                                                                                 GtkPolicyType      vscrollbar_policy);
+void gtk_scrolled_window_set_policy (GtkScrolledWindow *scrolled_window,
+                                     GtkPolicyType      hscrollbar_policy,
+                                    GtkPolicyType      vscrollbar_policy);
 </verb></tscreen>
 
 This sets the policy to be used with respect to the scrollbars.
@@ -3882,13 +3882,13 @@ int main (int argc, char *argv[])
     /* this simply creates a grid of toggle buttons on the table
      * to demonstrate the scrolled window. */
     for (i = 0; i < 10; i++)
-           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);
-           }
+       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);
+       }
     
     /* Add a "close" button to the bottom of the dialog */
     button = gtk_button_new_with_label ("close");
@@ -3918,6 +3918,274 @@ Try playing with resizing the window.  You'll notice how the scrollbars
 react.  You may also wish to use the gtk_widget_set_usize() call to set the default
 size of the window or other widgets.
 
+<!-- ----------------------------------------------------------------- -->   
+<sect1> Paned Window Widgets
+<p>
+The paned window widgets are useful when you want to divide an area
+into two parts, with the relative size of the two parts controlled by
+the user. A groove is drawn between the two portions with a handle
+that the user can drag to change the ratio. The division can either
+be horizontal (HPaned) or vertical (VPaned).
+   
+To create a new paned window, call one of:
+   
+<tscreen><verb>
+GtkWidget* gtk_hpaned_new (void)
+GtkWidget* gtk_vpaned_new (void)
+</verb></tscreen>
+
+After creating the paned window widget, you need to add child widgets
+to its two halves. To do this, use the functions:
+   
+<tscreen><verb>
+void gtk_paned_add1 (GtkPaned *paned, GtkWidget *child)
+void gtk_paned_add2 (GtkPaned *paned, GtkWidget *child)
+</verb></tscreen>
+   
+<tt/gtk_paned_add1()/ adds the child widget to the left or top half of
+the paned window. <tt/gtk_paned_add2()/ adds the child widget to the
+right or bottom half of the paned window.
+   
+As an example, we will create part of the user interface of an
+imaginary email program. A window is divided into two portions
+vertically, with the top portion being a list of email messages and
+the bottom portion the text of the email message. Most of the program
+is pretty straightforward. A couple of points to note are: Text can't
+be added to a Text widget until it is realized. This could be done by
+calling <tt/gtk_widget_realize()/, but as a demonstration of an alternate
+technique, we connect a handler to the "realize" signal to add the
+text. Also, we need to add the <tt/GTK_SHRINK/ option to some of the
+items in the table containing the text window and its scrollbars, so
+that when the bottom portion is made smaller, the correct portions
+shrink instead of being pushed off the bottom of the window.
+
+<tscreen><verb>
+/* paned.c */
+
+#include <gtk/gtk.h>
+   
+/* Create the list of "messages" */
+GtkWidget *
+create_list (void)
+{
+
+    GtkWidget *scrolled_window;
+    GtkWidget *list;
+    GtkWidget *list_item;
+   
+    int i;
+    char buffer[16];
+   
+    /* Create a new scrolled window, with scrollbars only if needed */
+    scrolled_window = gtk_scrolled_window_new (NULL, NULL);
+    gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_window),
+                                   GTK_POLICY_AUTOMATIC, 
+                                   GTK_POLICY_AUTOMATIC);
+   
+    /* Create a new list and put it in the scrolled window */
+    list = gtk_list_new ();
+    gtk_container_add (GTK_CONTAINER(scrolled_window), list);
+    gtk_widget_show (list);
+   
+    /* Add some messages to the window */
+    for (i=0; i<10; i++) {
+
+       sprintf(buffer,"Message #%d",i);
+       list_item = gtk_list_item_new_with_label (buffer);
+       gtk_container_add (GTK_CONTAINER(list), list_item);
+       gtk_widget_show (list_item);
+
+    }
+   
+    return scrolled_window;
+}
+   
+/* Add some text to our text widget - this is a callback that is invoked
+when our window is realized. We could also force our window to be
+realized with gtk_widget_realize, but it would have to be part of
+a hierarchy first */
+
+void
+realize_text (GtkWidget *text, gpointer data)
+{
+    gtk_text_freeze (GTK_TEXT (text));
+    gtk_text_insert (GTK_TEXT (text), NULL, &amp;text->style->black, NULL,
+    "From: pathfinder@nasa.gov\n"
+    "To: mom@nasa.gov\n"
+    "Subject: Made it!\n"
+    "\n"
+    "We just got in this morning. The weather has been\n"
+    "great - clear but cold, and there are lots of fun sights.\n"
+    "Sojourner says hi. See you soon.\n"
+    " -Path\n", -1);
+   
+    gtk_text_thaw (GTK_TEXT (text));
+}
+   
+/* Create a scrolled text area that displays a "message" */
+GtkWidget *
+create_text (void)
+{
+    GtkWidget *table;
+    GtkWidget *text;
+    GtkWidget *hscrollbar;
+    GtkWidget *vscrollbar;
+   
+    /* Create a table to hold the text widget and scrollbars */
+    table = gtk_table_new (2, 2, FALSE);
+   
+    /* Put a text widget in the upper left hand corner. Note the use of
+     * GTK_SHRINK in the y direction */
+    text = gtk_text_new (NULL, NULL);
+    gtk_table_attach (GTK_TABLE (table), text, 0, 1, 0, 1,
+                     GTK_FILL | GTK_EXPAND,
+                     GTK_FILL | GTK_EXPAND | GTK_SHRINK, 0, 0);
+    gtk_widget_show (text);
+   
+    /* Put a HScrollbar in the lower left hand corner */
+    hscrollbar = gtk_hscrollbar_new (GTK_TEXT (text)->hadj);
+    gtk_table_attach (GTK_TABLE (table), hscrollbar, 0, 1, 1, 2,
+                     GTK_EXPAND | GTK_FILL, GTK_FILL, 0, 0);
+    gtk_widget_show (hscrollbar);
+   
+    /* And a VScrollbar in the upper right */
+    vscrollbar = gtk_vscrollbar_new (GTK_TEXT (text)->vadj);
+    gtk_table_attach (GTK_TABLE (table), vscrollbar, 1, 2, 0, 1,
+                     GTK_FILL, GTK_EXPAND | GTK_FILL | GTK_SHRINK, 0, 0);
+    gtk_widget_show (vscrollbar);
+   
+    /* Add a handler to put a message in the text widget when it is realized */
+    gtk_signal_connect (GTK_OBJECT (text), "realize",
+                       GTK_SIGNAL_FUNC (realize_text), NULL);
+   
+    return table;
+}
+   
+int
+main (int argc, char *argv[])
+{
+    GtkWidget *window;
+    GtkWidget *vpaned;
+    GtkWidget *list;
+    GtkWidget *text;
+
+    gtk_init (&amp;argc, &amp;argv);
+   
+    window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
+    gtk_window_set_title (GTK_WINDOW (window), "Paned Windows");
+    gtk_signal_connect (GTK_OBJECT (window), "destroy",
+                       GTK_SIGNAL_FUNC (gtk_main_quit), NULL);
+    gtk_container_border_width (GTK_CONTAINER (window), 10);
+   
+    /* create a vpaned widget and add it to our toplevel window */
+   
+    vpaned = gtk_vpaned_new ();
+    gtk_container_add (GTK_CONTAINER(window), vpaned);
+    gtk_widget_show (vpaned);
+   
+    /* Now create the contents of the two halves of the window */
+   
+    list = create_list ();
+    gtk_paned_add1 (GTK_PANED(vpaned), list);
+    gtk_widget_show (list);
+   
+    text = create_text ();
+    gtk_paned_add2 (GTK_PANED(vpaned), text);
+    gtk_widget_show (text);
+    gtk_widget_show (window);
+    gtk_main ();
+    return 0;
+}
+
+</verb></tscreen>
+
+<!-- ----------------------------------------------------------------- -->   
+<sect1> Aspect Frames
+<p>
+The aspect frame widget is like a frame widget, except that it also
+enforces the aspect ratio (that is, the ratio of the width to the
+height) of the child widget to have a certain value, adding extra
+space if necessary. This is useful, for instance, if you want to
+preview a larger image. The size of the preview should vary when
+the user resizes the window, but the aspect ratio needs to always match
+the original image.
+   
+To create a new aspect frame, use:
+   
+<tscreen><verb>
+GtkWidget* gtk_aspect_frame_new         (const gchar *label,
+                                       gfloat xalign,
+                                       gfloat yalign,
+                                       gfloat ratio,
+                                       gint obey_child)
+</verb></tscreen>
+   
+<tt/xalign/ and <tt/yalign/ specifiy alignment as with Alignment
+widgets. If <tt/obey_child/ is true, the aspect ratio of a child
+widget will match the aspect ratio of the ideal size it requests.
+Otherwise, it is given by <tt/ratio/.
+   
+To change the options of an existing aspect frame, you can use:
+   
+<tscreen><verb>
+void gtk_aspect_frame_set (GtkAspectFrame *aspect_frame,
+                          gfloat xalign,
+                          gfloat yalign,
+                          gfloat ratio,
+                          gint obey_child)
+</verb></tscreen>
+   
+<p>
+As an example, the following program uses an AspectFrame to
+present a drawing area whose aspect ratio will always be 2:1, no
+matter how the user resizes the top-level window.
+   
+<tscreen><verb>
+/* aspectframe.c */
+
+#include <gtk/gtk.h>
+   
+int
+main (int argc, char *argv[])
+{
+    GtkWidget *window;
+    GtkWidget *aspect_frame;
+    GtkWidget *drawing_area;
+    gtk_init (&amp;argc, &amp;argv);
+   
+    window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
+    gtk_window_set_title (GTK_WINDOW (window), "Aspect Frame");
+    gtk_signal_connect (GTK_OBJECT (window), "destroy",
+    GTK_SIGNAL_FUNC (gtk_main_quit), NULL);
+    gtk_container_border_width (GTK_CONTAINER (window), 10);
+   
+    /* Create an aspect_frame and add it to our toplevel window */
+   
+    aspect_frame = gtk_aspect_frame_new ("2x1", /* label */
+                                         0.5, /* center x */
+                                         0.5, /* center y */
+                                         2, /* xsize/ysize = 2 */
+                                         FALSE /* ignore child's aspect */);
+   
+    gtk_container_add (GTK_CONTAINER(window), aspect_frame);
+    gtk_widget_show (aspect_frame);
+   
+    /* Now add a child widget to the aspect frame */
+   
+    drawing_area = gtk_drawing_area_new ();
+   
+    /* Ask for a 200x200 window, but the AspectFrame will give us a 200x100
+     * window since we are forcing a 2x1 aspect ratio */
+    gtk_widget_set_usize (drawing_area, 200, 200);
+    gtk_container_add (GTK_CONTAINER(aspect_frame), drawing_area);
+    gtk_widget_show (drawing_area);
+   
+    gtk_widget_show (window);
+    gtk_main ();
+    return 0;
+}  
+</verb></tscreen>
+                              
 <!-- ***************************************************************** -->
 <sect> List Widgets
 <!-- ***************************************************************** -->
@@ -4751,7 +5019,7 @@ int main (int argc, char *argv[])
     gtk_widget_set_usize( GTK_WIDGET (window), 200, 100);
     gtk_window_set_title(GTK_WINDOW (window), "GTK Menu Test");
     gtk_signal_connect(GTK_OBJECT (window), "delete_event",
-                       (GtkSignalFunc) gtk_exit, NULL);
+                       (GtkSignalFunc) gtk_main_quit, NULL);
 
     /* Init the menu-widget, and remember -- never
      * gtk_show_widget() the menu widget!! 
index 6365508e26f588742c25b125becee6cb7dc74353..4319216073e5c38898b7615bf9c69d4e15789951 100644 (file)
@@ -9,7 +9,7 @@
 <author>Ian Main <tt><htmlurl url="mailto:imain@gtk.org"
                              name="&lt;imain@gtk.org&gt;"></tt>,
 Tony Gale <tt><htmlurl url="mailto:gale@gtk.org"
-                             name="&lt;gale@gtk.org&gt;"></tt
+                             name="&lt;gale@gtk.org&gt;"></tt>
 <date>March 29th, 1998
 
 <!-- ***************************************************************** -->
@@ -3801,9 +3801,9 @@ direction, and the second, the adjustment for the vertical direction.
 These are almost always set to NULL.
 
 <tscreen><verb>
-void gtk_scrolled_window_set_policy      (GtkScrolledWindow *scrolled_window,
-                                          GtkPolicyType      hscrollbar_policy,
-                                                                                 GtkPolicyType      vscrollbar_policy);
+void gtk_scrolled_window_set_policy (GtkScrolledWindow *scrolled_window,
+                                     GtkPolicyType      hscrollbar_policy,
+                                    GtkPolicyType      vscrollbar_policy);
 </verb></tscreen>
 
 This sets the policy to be used with respect to the scrollbars.
@@ -3882,13 +3882,13 @@ int main (int argc, char *argv[])
     /* this simply creates a grid of toggle buttons on the table
      * to demonstrate the scrolled window. */
     for (i = 0; i < 10; i++)
-           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);
-           }
+       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);
+       }
     
     /* Add a "close" button to the bottom of the dialog */
     button = gtk_button_new_with_label ("close");
@@ -3918,6 +3918,274 @@ Try playing with resizing the window.  You'll notice how the scrollbars
 react.  You may also wish to use the gtk_widget_set_usize() call to set the default
 size of the window or other widgets.
 
+<!-- ----------------------------------------------------------------- -->   
+<sect1> Paned Window Widgets
+<p>
+The paned window widgets are useful when you want to divide an area
+into two parts, with the relative size of the two parts controlled by
+the user. A groove is drawn between the two portions with a handle
+that the user can drag to change the ratio. The division can either
+be horizontal (HPaned) or vertical (VPaned).
+   
+To create a new paned window, call one of:
+   
+<tscreen><verb>
+GtkWidget* gtk_hpaned_new (void)
+GtkWidget* gtk_vpaned_new (void)
+</verb></tscreen>
+
+After creating the paned window widget, you need to add child widgets
+to its two halves. To do this, use the functions:
+   
+<tscreen><verb>
+void gtk_paned_add1 (GtkPaned *paned, GtkWidget *child)
+void gtk_paned_add2 (GtkPaned *paned, GtkWidget *child)
+</verb></tscreen>
+   
+<tt/gtk_paned_add1()/ adds the child widget to the left or top half of
+the paned window. <tt/gtk_paned_add2()/ adds the child widget to the
+right or bottom half of the paned window.
+   
+As an example, we will create part of the user interface of an
+imaginary email program. A window is divided into two portions
+vertically, with the top portion being a list of email messages and
+the bottom portion the text of the email message. Most of the program
+is pretty straightforward. A couple of points to note are: Text can't
+be added to a Text widget until it is realized. This could be done by
+calling <tt/gtk_widget_realize()/, but as a demonstration of an alternate
+technique, we connect a handler to the "realize" signal to add the
+text. Also, we need to add the <tt/GTK_SHRINK/ option to some of the
+items in the table containing the text window and its scrollbars, so
+that when the bottom portion is made smaller, the correct portions
+shrink instead of being pushed off the bottom of the window.
+
+<tscreen><verb>
+/* paned.c */
+
+#include <gtk/gtk.h>
+   
+/* Create the list of "messages" */
+GtkWidget *
+create_list (void)
+{
+
+    GtkWidget *scrolled_window;
+    GtkWidget *list;
+    GtkWidget *list_item;
+   
+    int i;
+    char buffer[16];
+   
+    /* Create a new scrolled window, with scrollbars only if needed */
+    scrolled_window = gtk_scrolled_window_new (NULL, NULL);
+    gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_window),
+                                   GTK_POLICY_AUTOMATIC, 
+                                   GTK_POLICY_AUTOMATIC);
+   
+    /* Create a new list and put it in the scrolled window */
+    list = gtk_list_new ();
+    gtk_container_add (GTK_CONTAINER(scrolled_window), list);
+    gtk_widget_show (list);
+   
+    /* Add some messages to the window */
+    for (i=0; i<10; i++) {
+
+       sprintf(buffer,"Message #%d",i);
+       list_item = gtk_list_item_new_with_label (buffer);
+       gtk_container_add (GTK_CONTAINER(list), list_item);
+       gtk_widget_show (list_item);
+
+    }
+   
+    return scrolled_window;
+}
+   
+/* Add some text to our text widget - this is a callback that is invoked
+when our window is realized. We could also force our window to be
+realized with gtk_widget_realize, but it would have to be part of
+a hierarchy first */
+
+void
+realize_text (GtkWidget *text, gpointer data)
+{
+    gtk_text_freeze (GTK_TEXT (text));
+    gtk_text_insert (GTK_TEXT (text), NULL, &amp;text->style->black, NULL,
+    "From: pathfinder@nasa.gov\n"
+    "To: mom@nasa.gov\n"
+    "Subject: Made it!\n"
+    "\n"
+    "We just got in this morning. The weather has been\n"
+    "great - clear but cold, and there are lots of fun sights.\n"
+    "Sojourner says hi. See you soon.\n"
+    " -Path\n", -1);
+   
+    gtk_text_thaw (GTK_TEXT (text));
+}
+   
+/* Create a scrolled text area that displays a "message" */
+GtkWidget *
+create_text (void)
+{
+    GtkWidget *table;
+    GtkWidget *text;
+    GtkWidget *hscrollbar;
+    GtkWidget *vscrollbar;
+   
+    /* Create a table to hold the text widget and scrollbars */
+    table = gtk_table_new (2, 2, FALSE);
+   
+    /* Put a text widget in the upper left hand corner. Note the use of
+     * GTK_SHRINK in the y direction */
+    text = gtk_text_new (NULL, NULL);
+    gtk_table_attach (GTK_TABLE (table), text, 0, 1, 0, 1,
+                     GTK_FILL | GTK_EXPAND,
+                     GTK_FILL | GTK_EXPAND | GTK_SHRINK, 0, 0);
+    gtk_widget_show (text);
+   
+    /* Put a HScrollbar in the lower left hand corner */
+    hscrollbar = gtk_hscrollbar_new (GTK_TEXT (text)->hadj);
+    gtk_table_attach (GTK_TABLE (table), hscrollbar, 0, 1, 1, 2,
+                     GTK_EXPAND | GTK_FILL, GTK_FILL, 0, 0);
+    gtk_widget_show (hscrollbar);
+   
+    /* And a VScrollbar in the upper right */
+    vscrollbar = gtk_vscrollbar_new (GTK_TEXT (text)->vadj);
+    gtk_table_attach (GTK_TABLE (table), vscrollbar, 1, 2, 0, 1,
+                     GTK_FILL, GTK_EXPAND | GTK_FILL | GTK_SHRINK, 0, 0);
+    gtk_widget_show (vscrollbar);
+   
+    /* Add a handler to put a message in the text widget when it is realized */
+    gtk_signal_connect (GTK_OBJECT (text), "realize",
+                       GTK_SIGNAL_FUNC (realize_text), NULL);
+   
+    return table;
+}
+   
+int
+main (int argc, char *argv[])
+{
+    GtkWidget *window;
+    GtkWidget *vpaned;
+    GtkWidget *list;
+    GtkWidget *text;
+
+    gtk_init (&amp;argc, &amp;argv);
+   
+    window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
+    gtk_window_set_title (GTK_WINDOW (window), "Paned Windows");
+    gtk_signal_connect (GTK_OBJECT (window), "destroy",
+                       GTK_SIGNAL_FUNC (gtk_main_quit), NULL);
+    gtk_container_border_width (GTK_CONTAINER (window), 10);
+   
+    /* create a vpaned widget and add it to our toplevel window */
+   
+    vpaned = gtk_vpaned_new ();
+    gtk_container_add (GTK_CONTAINER(window), vpaned);
+    gtk_widget_show (vpaned);
+   
+    /* Now create the contents of the two halves of the window */
+   
+    list = create_list ();
+    gtk_paned_add1 (GTK_PANED(vpaned), list);
+    gtk_widget_show (list);
+   
+    text = create_text ();
+    gtk_paned_add2 (GTK_PANED(vpaned), text);
+    gtk_widget_show (text);
+    gtk_widget_show (window);
+    gtk_main ();
+    return 0;
+}
+
+</verb></tscreen>
+
+<!-- ----------------------------------------------------------------- -->   
+<sect1> Aspect Frames
+<p>
+The aspect frame widget is like a frame widget, except that it also
+enforces the aspect ratio (that is, the ratio of the width to the
+height) of the child widget to have a certain value, adding extra
+space if necessary. This is useful, for instance, if you want to
+preview a larger image. The size of the preview should vary when
+the user resizes the window, but the aspect ratio needs to always match
+the original image.
+   
+To create a new aspect frame, use:
+   
+<tscreen><verb>
+GtkWidget* gtk_aspect_frame_new         (const gchar *label,
+                                       gfloat xalign,
+                                       gfloat yalign,
+                                       gfloat ratio,
+                                       gint obey_child)
+</verb></tscreen>
+   
+<tt/xalign/ and <tt/yalign/ specifiy alignment as with Alignment
+widgets. If <tt/obey_child/ is true, the aspect ratio of a child
+widget will match the aspect ratio of the ideal size it requests.
+Otherwise, it is given by <tt/ratio/.
+   
+To change the options of an existing aspect frame, you can use:
+   
+<tscreen><verb>
+void gtk_aspect_frame_set (GtkAspectFrame *aspect_frame,
+                          gfloat xalign,
+                          gfloat yalign,
+                          gfloat ratio,
+                          gint obey_child)
+</verb></tscreen>
+   
+<p>
+As an example, the following program uses an AspectFrame to
+present a drawing area whose aspect ratio will always be 2:1, no
+matter how the user resizes the top-level window.
+   
+<tscreen><verb>
+/* aspectframe.c */
+
+#include <gtk/gtk.h>
+   
+int
+main (int argc, char *argv[])
+{
+    GtkWidget *window;
+    GtkWidget *aspect_frame;
+    GtkWidget *drawing_area;
+    gtk_init (&amp;argc, &amp;argv);
+   
+    window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
+    gtk_window_set_title (GTK_WINDOW (window), "Aspect Frame");
+    gtk_signal_connect (GTK_OBJECT (window), "destroy",
+    GTK_SIGNAL_FUNC (gtk_main_quit), NULL);
+    gtk_container_border_width (GTK_CONTAINER (window), 10);
+   
+    /* Create an aspect_frame and add it to our toplevel window */
+   
+    aspect_frame = gtk_aspect_frame_new ("2x1", /* label */
+                                         0.5, /* center x */
+                                         0.5, /* center y */
+                                         2, /* xsize/ysize = 2 */
+                                         FALSE /* ignore child's aspect */);
+   
+    gtk_container_add (GTK_CONTAINER(window), aspect_frame);
+    gtk_widget_show (aspect_frame);
+   
+    /* Now add a child widget to the aspect frame */
+   
+    drawing_area = gtk_drawing_area_new ();
+   
+    /* Ask for a 200x200 window, but the AspectFrame will give us a 200x100
+     * window since we are forcing a 2x1 aspect ratio */
+    gtk_widget_set_usize (drawing_area, 200, 200);
+    gtk_container_add (GTK_CONTAINER(aspect_frame), drawing_area);
+    gtk_widget_show (drawing_area);
+   
+    gtk_widget_show (window);
+    gtk_main ();
+    return 0;
+}  
+</verb></tscreen>
+                              
 <!-- ***************************************************************** -->
 <sect> List Widgets
 <!-- ***************************************************************** -->
@@ -4751,7 +5019,7 @@ int main (int argc, char *argv[])
     gtk_widget_set_usize( GTK_WIDGET (window), 200, 100);
     gtk_window_set_title(GTK_WINDOW (window), "GTK Menu Test");
     gtk_signal_connect(GTK_OBJECT (window), "delete_event",
-                       (GtkSignalFunc) gtk_exit, NULL);
+                       (GtkSignalFunc) gtk_main_quit, NULL);
 
     /* Init the menu-widget, and remember -- never
      * gtk_show_widget() the menu widget!! 
diff --git a/examples/aspectframe/Makefile b/examples/aspectframe/Makefile
new file mode 100644 (file)
index 0000000..fe8b11e
--- /dev/null
@@ -0,0 +1,8 @@
+
+CC = gcc
+
+aspectframe: aspectframe.c 
+       $(CC) `gtk-config --cflags` `gtk-config --libs` aspectframe.c -o aspectframe
+
+clean: 
+       rm -f *.o aspectframe
diff --git a/examples/aspectframe/aspectframe.c b/examples/aspectframe/aspectframe.c
new file mode 100644 (file)
index 0000000..0376bf9
--- /dev/null
@@ -0,0 +1,43 @@
+/* aspectframe.c */
+
+#include <gtk/gtk.h>
+   
+int
+main (int argc, char *argv[])
+{
+    GtkWidget *window;
+    GtkWidget *aspect_frame;
+    GtkWidget *drawing_area;
+    gtk_init (&argc, &argv);
+   
+    window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
+    gtk_window_set_title (GTK_WINDOW (window), "Aspect Frame");
+    gtk_signal_connect (GTK_OBJECT (window), "destroy",
+    GTK_SIGNAL_FUNC (gtk_main_quit), NULL);
+    gtk_container_border_width (GTK_CONTAINER (window), 10);
+   
+    /* Create an aspect_frame and add it to our toplevel window */
+   
+    aspect_frame = gtk_aspect_frame_new ("2x1", /* label */
+                                         0.5, /* center x */
+                                         0.5, /* center y */
+                                         2, /* xsize/ysize = 2 */
+                                         FALSE /* ignore child's aspect */);
+   
+    gtk_container_add (GTK_CONTAINER(window), aspect_frame);
+    gtk_widget_show (aspect_frame);
+   
+    /* Now add a child widget to the aspect frame */
+   
+    drawing_area = gtk_drawing_area_new ();
+   
+    /* Ask for a 200x200 window, but the AspectFrame will give us a 200x100
+     * window since we are forcing a 2x1 aspect ratio */
+    gtk_widget_set_usize (drawing_area, 200, 200);
+    gtk_container_add (GTK_CONTAINER(aspect_frame), drawing_area);
+    gtk_widget_show (drawing_area);
+   
+    gtk_widget_show (window);
+    gtk_main ();
+    return 0;
+}
diff --git a/examples/paned/Makefile b/examples/paned/Makefile
new file mode 100644 (file)
index 0000000..7e2c010
--- /dev/null
@@ -0,0 +1,8 @@
+
+CC = gcc
+
+paned: paned.c 
+       $(CC) `gtk-config --cflags` `gtk-config --libs` paned.c -o paned
+
+clean: 
+       rm -f *.o paned
diff --git a/examples/paned/paned.c b/examples/paned/paned.c
new file mode 100644 (file)
index 0000000..46b7c6e
--- /dev/null
@@ -0,0 +1,136 @@
+/* paned.c */
+
+#include <gtk/gtk.h>
+   
+/* Create the list of "messages" */
+GtkWidget *
+create_list (void)
+{
+
+    GtkWidget *scrolled_window;
+    GtkWidget *list;
+    GtkWidget *list_item;
+   
+    int i;
+    char buffer[16];
+   
+    /* Create a new scrolled window, with scrollbars only if needed */
+    scrolled_window = gtk_scrolled_window_new (NULL, NULL);
+    gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_window),
+                                   GTK_POLICY_AUTOMATIC, 
+                                   GTK_POLICY_AUTOMATIC);
+   
+    /* Create a new list and put it in the scrolled window */
+    list = gtk_list_new ();
+    gtk_container_add (GTK_CONTAINER(scrolled_window), list);
+    gtk_widget_show (list);
+   
+    /* Add some messages to the window */
+    for (i=0; i<10; i++) {
+
+       sprintf(buffer,"Message #%d",i);
+       list_item = gtk_list_item_new_with_label (buffer);
+       gtk_container_add (GTK_CONTAINER(list), list_item);
+       gtk_widget_show (list_item);
+
+    }
+   
+    return scrolled_window;
+}
+   
+/* Add some text to our text widget - this is a callback that is invoked
+when our window is realized. We could also force our window to be
+realized with gtk_widget_realize, but it would have to be part of
+a hierarchy first */
+
+void
+realize_text (GtkWidget *text, gpointer data)
+{
+    gtk_text_freeze (GTK_TEXT (text));
+    gtk_text_insert (GTK_TEXT (text), NULL, &text->style->black, NULL,
+    "From: pathfinder@nasa.gov\n"
+    "To: mom@nasa.gov\n"
+    "Subject: Made it!\n"
+    "\n"
+    "We just got in this morning. The weather has been\n"
+    "great - clear but cold, and there are lots of fun sights.\n"
+    "Sojourner says hi. See you soon.\n"
+    " -Path\n", -1);
+   
+    gtk_text_thaw (GTK_TEXT (text));
+}
+   
+/* Create a scrolled text area that displays a "message" */
+GtkWidget *
+create_text (void)
+{
+    GtkWidget *table;
+    GtkWidget *text;
+    GtkWidget *hscrollbar;
+    GtkWidget *vscrollbar;
+   
+    /* Create a table to hold the text widget and scrollbars */
+    table = gtk_table_new (2, 2, FALSE);
+   
+    /* Put a text widget in the upper left hand corner. Note the use of
+     * GTK_SHRINK in the y direction */
+    text = gtk_text_new (NULL, NULL);
+    gtk_table_attach (GTK_TABLE (table), text, 0, 1, 0, 1,
+                     GTK_FILL | GTK_EXPAND,
+                     GTK_FILL | GTK_EXPAND | GTK_SHRINK, 0, 0);
+    gtk_widget_show (text);
+   
+    /* Put a HScrollbar in the lower left hand corner */
+    hscrollbar = gtk_hscrollbar_new (GTK_TEXT (text)->hadj);
+    gtk_table_attach (GTK_TABLE (table), hscrollbar, 0, 1, 1, 2,
+                     GTK_EXPAND | GTK_FILL, GTK_FILL, 0, 0);
+    gtk_widget_show (hscrollbar);
+   
+    /* And a VScrollbar in the upper right */
+    vscrollbar = gtk_vscrollbar_new (GTK_TEXT (text)->vadj);
+    gtk_table_attach (GTK_TABLE (table), vscrollbar, 1, 2, 0, 1,
+                     GTK_FILL, GTK_EXPAND | GTK_FILL | GTK_SHRINK, 0, 0);
+    gtk_widget_show (vscrollbar);
+   
+    /* Add a handler to put a message in the text widget when it is realized */
+    gtk_signal_connect (GTK_OBJECT (text), "realize",
+                       GTK_SIGNAL_FUNC (realize_text), NULL);
+   
+    return table;
+}
+   
+int
+main (int argc, char *argv[])
+{
+    GtkWidget *window;
+    GtkWidget *vpaned;
+    GtkWidget *list;
+    GtkWidget *text;
+
+    gtk_init (&argc, &argv);
+   
+    window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
+    gtk_window_set_title (GTK_WINDOW (window), "Paned Windows");
+    gtk_signal_connect (GTK_OBJECT (window), "destroy",
+                       GTK_SIGNAL_FUNC (gtk_main_quit), NULL);
+    gtk_container_border_width (GTK_CONTAINER (window), 10);
+   
+    /* create a vpaned widget and add it to our toplevel window */
+   
+    vpaned = gtk_vpaned_new ();
+    gtk_container_add (GTK_CONTAINER(window), vpaned);
+    gtk_widget_show (vpaned);
+   
+    /* Now create the contents of the two halves of the window */
+   
+    list = create_list ();
+    gtk_paned_add1 (GTK_PANED(vpaned), list);
+    gtk_widget_show (list);
+   
+    text = create_text ();
+    gtk_paned_add2 (GTK_PANED(vpaned), text);
+    gtk_widget_show (text);
+    gtk_widget_show (window);
+    gtk_main ();
+    return 0;
+}