2008-07-01 22:57:50 +00:00
|
|
|
/* GTK - The GIMP Toolkit
|
1997-11-24 22:37:52 +00:00
|
|
|
* Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
2000-07-26 11:33:08 +00:00
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
1997-11-24 22:37:52 +00:00
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
1998-06-17 08:48:22 +00:00
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
2000-07-26 11:33:08 +00:00
|
|
|
* Lesser General Public License for more details.
|
1997-11-24 22:37:52 +00:00
|
|
|
*
|
2000-07-26 11:33:08 +00:00
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
1998-04-13 02:02:47 +00:00
|
|
|
* License along with this library; if not, write to the
|
|
|
|
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
|
|
* Boston, MA 02111-1307, USA.
|
1997-11-24 22:37:52 +00:00
|
|
|
*/
|
1999-02-24 07:37:18 +00:00
|
|
|
|
|
|
|
/*
|
2000-07-26 11:33:08 +00:00
|
|
|
* Modified by the GTK+ Team and others 1997-2000. See the AUTHORS
|
1999-02-24 07:37:18 +00:00
|
|
|
* file for a list of people on the GTK+ Team. See the ChangeLog
|
|
|
|
* files for a list of changes. These files are distributed with
|
2008-05-28 15:35:43 +00:00
|
|
|
* GTK+ at ftp://ftp.gtk.org/pub/gtk/.
|
1999-02-24 07:37:18 +00:00
|
|
|
*/
|
|
|
|
|
2009-10-21 18:30:04 +00:00
|
|
|
#if !defined (__GTK_H_INSIDE__) && !defined (GTK_COMPILATION)
|
2008-05-28 15:07:04 +00:00
|
|
|
#error "Only <gtk/gtk.h> can be included directly."
|
|
|
|
#endif
|
|
|
|
|
1997-11-24 22:37:52 +00:00
|
|
|
#ifndef __GTK_BOX_H__
|
|
|
|
#define __GTK_BOX_H__
|
|
|
|
|
|
|
|
|
|
|
|
#include <gtk/gtkcontainer.h>
|
|
|
|
|
|
|
|
|
2005-06-21 05:35:43 +00:00
|
|
|
G_BEGIN_DECLS
|
1997-11-24 22:37:52 +00:00
|
|
|
|
|
|
|
|
2000-02-13 08:16:48 +00:00
|
|
|
#define GTK_TYPE_BOX (gtk_box_get_type ())
|
2002-10-07 04:29:52 +00:00
|
|
|
#define GTK_BOX(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_BOX, GtkBox))
|
|
|
|
#define GTK_BOX_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_BOX, GtkBoxClass))
|
|
|
|
#define GTK_IS_BOX(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_BOX))
|
|
|
|
#define GTK_IS_BOX_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_BOX))
|
|
|
|
#define GTK_BOX_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_BOX, GtkBoxClass))
|
1997-11-24 22:37:52 +00:00
|
|
|
|
|
|
|
|
1998-06-17 08:48:22 +00:00
|
|
|
typedef struct _GtkBox GtkBox;
|
1997-11-24 22:37:52 +00:00
|
|
|
typedef struct _GtkBoxClass GtkBoxClass;
|
|
|
|
|
|
|
|
struct _GtkBox
|
|
|
|
{
|
|
|
|
GtkContainer container;
|
Documentation fixes.
Sun Oct 13 18:50:14 2002 Soeren Sandmann <sandmann@daimi.au.dk>
* gtkmenu.c, gtkmenu.sgml, gtkitemfactory.c, gdkwindow.c,
gtkwindow.c, gtkpaned.sgml, gtkdialog.c, gtkbox.h, gtkbutton.sgml,
gtktreemodel.sgml,gtktable.sgml, gtktable.c:
Documentation fixes.
#85719, #90759, #95169, Owen Taylor;
#89221, Yao Zhang, Matthias Clasen;
#95592, Joost Faassen;
#92637, Vitaly Tishkov;
#94616, Ben Martin;
#94772, sbaillie@bigpond.net.au;
2002-10-13 17:17:14 +00:00
|
|
|
|
|
|
|
/*< public >*/
|
2008-06-20 10:57:52 +00:00
|
|
|
GList *GSEAL (children);
|
|
|
|
gint16 GSEAL (spacing);
|
2008-06-20 11:09:49 +00:00
|
|
|
guint GSEAL (homogeneous) : 1;
|
1997-11-24 22:37:52 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
struct _GtkBoxClass
|
|
|
|
{
|
|
|
|
GtkContainerClass parent_class;
|
|
|
|
};
|
|
|
|
|
2010-03-09 22:51:03 +00:00
|
|
|
/**
|
|
|
|
* GtkBoxChild:
|
|
|
|
* @widget: the child widget, packed into the GtkBox.
|
|
|
|
* @padding: the number of extra pixels to put between this child and its
|
|
|
|
* neighbors, set when packed, zero by default.
|
|
|
|
* @expand: flag indicates whether extra space should be given to this child.
|
|
|
|
* Any extra space given to the parent GtkBox is divided up among all children
|
|
|
|
* with this attribute set to %TRUE; set when packed, %TRUE by default.
|
|
|
|
* @fill: flag indicates whether any extra space given to this child due to its
|
|
|
|
* @expand attribute being set is actually allocated to the child, rather than
|
|
|
|
* being used as padding around the widget; set when packed, %TRUE by default.
|
|
|
|
* @pack: one of #GtkPackType indicating whether the child is packed with
|
|
|
|
* reference to the start (top/left) or end (bottom/right) of the GtkBox.
|
|
|
|
* @is_secondary: %TRUE if the child is secondary
|
|
|
|
*
|
|
|
|
* The #GtkBoxChild holds a child widget of #GtkBox and describes how the child
|
|
|
|
* is to be packed into the #GtkBox. All fields of this #GtkBoxChild should be
|
|
|
|
* considered read-only and they should never be set directly by an application.
|
|
|
|
* Use gtk_box_query_child_packing() and gtk_box_set_child_packing() to query
|
|
|
|
* and set the #GtkBoxChild.padding, #GtkBoxChild.expand, #GtkBoxChild.fill and
|
|
|
|
* #GtkBoxChild.pack fields.
|
2010-05-22 04:15:00 +00:00
|
|
|
*
|
|
|
|
* Deprecated: 2.22: Use gtk_container_get_children() instead.
|
2010-03-09 22:51:03 +00:00
|
|
|
*/
|
2010-05-22 04:15:00 +00:00
|
|
|
#if !defined (GTK_DISABLE_DEPRECATED) || defined (GTK_COMPILATION)
|
|
|
|
typedef struct _GtkBoxChild GtkBoxChild;
|
1997-11-24 22:37:52 +00:00
|
|
|
struct _GtkBoxChild
|
|
|
|
{
|
|
|
|
GtkWidget *widget;
|
|
|
|
guint16 padding;
|
|
|
|
guint expand : 1;
|
|
|
|
guint fill : 1;
|
|
|
|
guint pack : 1;
|
2001-07-06 02:10:32 +00:00
|
|
|
guint is_secondary : 1;
|
1997-11-24 22:37:52 +00:00
|
|
|
};
|
2010-05-22 04:15:00 +00:00
|
|
|
#endif
|
1997-11-24 22:37:52 +00:00
|
|
|
|
2008-10-07 07:44:06 +00:00
|
|
|
GType gtk_box_get_type (void) G_GNUC_CONST;
|
2010-05-25 22:55:15 +00:00
|
|
|
GtkWidget* gtk_box_new (GtkOrientation orientation,
|
2008-10-07 07:44:06 +00:00
|
|
|
gboolean homogeneous,
|
|
|
|
gint spacing);
|
|
|
|
|
|
|
|
void gtk_box_pack_start (GtkBox *box,
|
|
|
|
GtkWidget *child,
|
|
|
|
gboolean expand,
|
|
|
|
gboolean fill,
|
|
|
|
guint padding);
|
|
|
|
void gtk_box_pack_end (GtkBox *box,
|
|
|
|
GtkWidget *child,
|
|
|
|
gboolean expand,
|
|
|
|
gboolean fill,
|
|
|
|
guint padding);
|
|
|
|
|
|
|
|
void gtk_box_set_homogeneous (GtkBox *box,
|
|
|
|
gboolean homogeneous);
|
|
|
|
gboolean gtk_box_get_homogeneous (GtkBox *box);
|
|
|
|
void gtk_box_set_spacing (GtkBox *box,
|
|
|
|
gint spacing);
|
|
|
|
gint gtk_box_get_spacing (GtkBox *box);
|
|
|
|
|
|
|
|
void gtk_box_reorder_child (GtkBox *box,
|
|
|
|
GtkWidget *child,
|
|
|
|
gint position);
|
|
|
|
|
|
|
|
void gtk_box_query_child_packing (GtkBox *box,
|
|
|
|
GtkWidget *child,
|
|
|
|
gboolean *expand,
|
|
|
|
gboolean *fill,
|
|
|
|
guint *padding,
|
|
|
|
GtkPackType *pack_type);
|
|
|
|
void gtk_box_set_child_packing (GtkBox *box,
|
|
|
|
GtkWidget *child,
|
|
|
|
gboolean expand,
|
|
|
|
gboolean fill,
|
|
|
|
guint padding,
|
|
|
|
GtkPackType pack_type);
|
|
|
|
|
|
|
|
/* internal API */
|
2008-10-07 09:07:27 +00:00
|
|
|
void _gtk_box_set_old_defaults (GtkBox *box);
|
2008-10-07 07:44:06 +00:00
|
|
|
gboolean _gtk_box_get_spacing_set (GtkBox *box);
|
|
|
|
void _gtk_box_set_spacing_set (GtkBox *box,
|
|
|
|
gboolean spacing_set);
|
1997-11-24 22:37:52 +00:00
|
|
|
|
2005-06-21 05:35:43 +00:00
|
|
|
G_END_DECLS
|
1997-11-24 22:37:52 +00:00
|
|
|
|
|
|
|
#endif /* __GTK_BOX_H__ */
|