| GTK+ Reference Manual | |||
|---|---|---|---|
| <<< Prev | Home | Up | Next >>> | 
GtkLayout — Infinite scrollable area containing child widgets and/or custom drawing
#include <gtk/gtk.h> struct GtkLayout; GtkWidget* gtk_layout_new (GtkAdjustment *hadjustment, GtkAdjustment *vadjustment); void gtk_layout_put (GtkLayout *layout, GtkWidget *child_widget, gint x, gint y); void gtk_layout_move (GtkLayout *layout, GtkWidget *child_widget, gint x, gint y); void gtk_layout_set_size (GtkLayout *layout, guint width, guint height); void gtk_layout_get_size (GtkLayout *layout, guint *width, guint *height); void gtk_layout_freeze (GtkLayout *layout); void gtk_layout_thaw (GtkLayout *layout); GtkAdjustment* gtk_layout_get_hadjustment (GtkLayout *layout); GtkAdjustment* gtk_layout_get_vadjustment (GtkLayout *layout); void gtk_layout_set_hadjustment (GtkLayout *layout, GtkAdjustment *adjustment); void gtk_layout_set_vadjustment (GtkLayout *layout, GtkAdjustment *adjustment);
GObject +----GtkObject +----GtkWidget +----GtkContainer +----GtkLayout
"hadjustment" GtkAdjustment : Read / Write "height" guint : Read / Write "vadjustment" GtkAdjustment : Read / Write "width" guint : Read / Write
"set-scroll-adjustments" void user_function (GtkLayout *layout, GtkAdjustment *arg1, GtkAdjustment *arg2, gpointer user_data);
GtkLayout is similar to GtkDrawingArea in that it's a "blank slate" and doesn't do anything but paint a blank background by default. It's different in that it supports scrolling natively (you can add it to a GtkScrolledWindow), and it can contain child widgets, since it's a GtkContainer. However if you're just going to draw, a GtkDrawingArea is a better choice since it has lower overhead.
When handling expose events on a GtkLayout, you must draw to GTK_LAYOUT (layout)->bin_window, rather than to GTK_WIDGET (layout)->window, as you would for a drawing area.
GtkWidget* gtk_layout_new (GtkAdjustment *hadjustment, GtkAdjustment *vadjustment);
Creates a new GtkLayout. Unless you have a specific adjustment you'd like the layout to use for scrolling, pass NULL for hadjustment and vadjustment.
| hadjustment : | horizontal scroll adjustment, or NULL | 
| vadjustment : | vertical scroll adjustment, or NULL | 
| Returns : | a new GtkLayout | 
void gtk_layout_put (GtkLayout *layout, GtkWidget *child_widget, gint x, gint y);
Adds child_widget to layout, at position (x,y). layout becomes the new parent container of child_widget.
| layout : | |
| child_widget : | child widget | 
| x : | X position of child widget | 
| y : | Y position of child widget | 
void gtk_layout_move (GtkLayout *layout, GtkWidget *child_widget, gint x, gint y);
Moves a current child of layout to a new position.
| layout : | |
| child_widget : | a current child of layout | 
| x : | X position to move to | 
| y : | Y position to move to | 
void gtk_layout_set_size (GtkLayout *layout, guint width, guint height);
Sets the size of the scrollable area of the layout.
| layout : | |
| width : | width of entire scrollable area | 
| height : | height of entire scrollable area | 
void gtk_layout_get_size (GtkLayout *layout, guint *width, guint *height);
Gets the size that has been set on the layout, and that determines the total extents of the layout's scrollbar area. See gtk_layout_set_size().
| layout : | |
| width : | location to store the width set on layout, or NULL | 
| height : | location to store the height set on layout, or NULL | 
void gtk_layout_freeze (GtkLayout *layout);
gtk_layout_freeze is deprecated and should not be used in newly-written code.
This is a deprecated function, it doesn't do anything useful.
| layout : | 
void gtk_layout_thaw (GtkLayout *layout);
gtk_layout_thaw is deprecated and should not be used in newly-written code.
This is a deprecated function, it doesn't do anything useful.
| layout : | 
GtkAdjustment* gtk_layout_get_hadjustment (GtkLayout *layout);
This function should only be called after the layout has been placed in a GtkScrolledWindow or otherwise configured for scrolling. It returns the GtkAdjustment used for communication between the horizontal scrollbar and layout.
See GtkScrolledWindow, GtkScrollbar, GtkAdjustment for details.
| layout : | |
| Returns : | horizontal scroll adjustment | 
GtkAdjustment* gtk_layout_get_vadjustment (GtkLayout *layout);
This function should only be called after the layout has been placed in a GtkScrolledWindow or otherwise configured for scrolling. It returns the GtkAdjustment used for communication between the vertical scrollbar and layout.
See GtkScrolledWindow, GtkScrollbar, GtkAdjustment for details.
| layout : | |
| Returns : | vertical scroll adjustment | 
void gtk_layout_set_hadjustment (GtkLayout *layout, GtkAdjustment *adjustment);
Sets the horizontal scroll adjustment for the layout.
See GtkScrolledWindow, GtkScrollbar, GtkAdjustment for details.
| layout : | |
| adjustment : | new scroll adjustment | 
void gtk_layout_set_vadjustment (GtkLayout *layout, GtkAdjustment *adjustment);
Sets the vertical scroll adjustment for the layout.
See GtkScrolledWindow, GtkScrollbar, GtkAdjustment for details.
| layout : | |
| adjustment : | new scroll adjustment | 
| "hadjustment" (GtkAdjustment : Read / Write) | The GtkAdjustment for the horizontal position. | 
| "height" (guint : Read / Write) | The height of the layout. | 
| "vadjustment" (GtkAdjustment : Read / Write) | The GtkAdjustment for the vertical position. | 
| "width" (guint : Read / Write) | The width of the layout. | 
void user_function (GtkLayout *layout, GtkAdjustment *arg1, GtkAdjustment *arg2, gpointer user_data);
| layout : | the object which received the signal. | 
| arg1 : | 
 | 
| arg2 : | 
 | 
| user_data : | user data set when the signal handler was connected. | 
| <<< Prev | Home | Up | Next >>> | 
| GtkVPaned | GtkNotebook | ||