mirror of
https://github.com/brl/mutter.git
synced 2024-12-28 05:42:14 +00:00
Update the ClutterBox API and structure
ClutterBox is meant to work like the HTML boxing model: it has a margin and a backgrdound color, and every child actor is added with a pack type and a padding. The ClutterBoxChild structure holds the child actor, the padding, the packing type and the allocated coordinates for the actor.
This commit is contained in:
parent
b3c8ff186c
commit
54b77d12cd
@ -22,7 +22,8 @@ enum
|
||||
{
|
||||
PROP_0,
|
||||
|
||||
PROP_SPACING
|
||||
PROP_MARGIN,
|
||||
PROP_COLOR
|
||||
};
|
||||
|
||||
static void clutter_container_iface_init (ClutterContainerIface *iface);
|
||||
@ -38,7 +39,7 @@ static void
|
||||
clutter_box_add (ClutterContainer *container,
|
||||
ClutterActor *actor)
|
||||
{
|
||||
clutter_box_pack_start (CLUTTER_BOX (container), actor);
|
||||
clutter_box_pack_defaults (CLUTTER_BOX (container), actor);
|
||||
}
|
||||
|
||||
static void
|
||||
@ -149,6 +150,8 @@ clutter_box_paint (ClutterActor *actor)
|
||||
|
||||
cogl_push_matrix ();
|
||||
|
||||
cogl_color (&box->color);
|
||||
|
||||
for (l = box->children; l; l = l->next)
|
||||
{
|
||||
ClutterBoxChild *child = l->data;
|
||||
@ -216,8 +219,11 @@ clutter_box_set_property (GObject *gobject,
|
||||
|
||||
switch (prop_id)
|
||||
{
|
||||
case PROP_SPACING:
|
||||
box->spacing = g_value_get_uint (value);
|
||||
case PROP_COLOR:
|
||||
clutter_box_set_color (box, g_value_get_boxed (value));
|
||||
break;
|
||||
case PROP_MARGIN:
|
||||
clutter_box_set_margin (box, g_value_get_boxed (value));
|
||||
break;
|
||||
default:
|
||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (gobject, prop_id, pspec);
|
||||
@ -235,8 +241,19 @@ clutter_box_get_property (GObject *gobject,
|
||||
|
||||
switch (prop_id)
|
||||
{
|
||||
case PROP_SPACING:
|
||||
g_value_set_uint (value, box->spacing);
|
||||
case PROP_MARGIN:
|
||||
{
|
||||
ClutterMargin margin;
|
||||
clutter_box_get_margin (box, &margin);
|
||||
g_value_set_boxed (value, &margin);
|
||||
}
|
||||
break;
|
||||
case PROP_COLOR:
|
||||
{
|
||||
ClutterColor color;
|
||||
clutter_box_get_color (box, &color);
|
||||
g_value_set_boxed (value, &color);
|
||||
}
|
||||
break;
|
||||
default:
|
||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (gobject, prop_id, pspec);
|
||||
@ -262,12 +279,34 @@ clutter_box_class_init (ClutterBoxClass *klass)
|
||||
klass->pack_child = clutter_box_pack_child_unimplemented;
|
||||
klass->unpack_child = clutter_box_unpack_child_unimplemented;
|
||||
|
||||
/**
|
||||
* ClutterBox:margin:
|
||||
*
|
||||
* The margin between the inner border of a #ClutterBox and its
|
||||
* children.
|
||||
*
|
||||
* Since: 0.4
|
||||
*/
|
||||
g_object_class_install_property (gobject_class,
|
||||
PROP_SPACING,
|
||||
g_param_spec_uint ("spacing",
|
||||
"Spacing",
|
||||
"Space between each child actor",
|
||||
0, G_MAXUINT, 0,
|
||||
PROP_MARGIN,
|
||||
g_param_spec_boxed ("margin",
|
||||
"Margin",
|
||||
"Margin between the inner border of a box and its children",
|
||||
CLUTTER_TYPE_MARGIN,
|
||||
CLUTTER_PARAM_READWRITE));
|
||||
/**
|
||||
* ClutterBox:color:
|
||||
*
|
||||
* The background color of a #ClutterBox.
|
||||
*
|
||||
* Since: 0.4
|
||||
*/
|
||||
g_object_class_install_property (gobject_class,
|
||||
PROP_COLOR,
|
||||
g_param_spec_boxed ("color",
|
||||
"Color",
|
||||
"Background color of a box",
|
||||
CLUTTER_TYPE_COLOR,
|
||||
CLUTTER_PARAM_READWRITE));
|
||||
}
|
||||
|
||||
@ -282,17 +321,19 @@ clutter_box_init (ClutterBox *box)
|
||||
*/
|
||||
|
||||
/**
|
||||
* clutter_box_pack_start:
|
||||
* clutter_box_pack:
|
||||
* @box: a #ClutterBox
|
||||
* @actor: a #ClutterActor
|
||||
*
|
||||
* Packs @actor into @box
|
||||
* Packs @actor into @box.
|
||||
*
|
||||
* Since: 0.4
|
||||
*/
|
||||
void
|
||||
clutter_box_pack_start (ClutterBox *box,
|
||||
ClutterActor *actor)
|
||||
clutter_box_pack (ClutterBox *box,
|
||||
ClutterActor *actor,
|
||||
ClutterPackType pack_type,
|
||||
const ClutterPadding *padding)
|
||||
{
|
||||
ClutterBoxChild *child;
|
||||
|
||||
@ -301,11 +342,12 @@ clutter_box_pack_start (ClutterBox *box,
|
||||
|
||||
child = g_slice_new (ClutterBoxChild);
|
||||
child->actor = actor;
|
||||
child->pack_type = CLUTTER_PACK_START;
|
||||
child->pack_type = pack_type;
|
||||
memcpy (&(child->padding), padding, sizeof (ClutterPadding));
|
||||
|
||||
CLUTTER_BOX_GET_CLASS (box)->pack_child (box, child);
|
||||
|
||||
box->children = g_list_append (box->children, child);
|
||||
box->children = g_list_prepend (box->children, child);
|
||||
clutter_actor_set_parent (actor, CLUTTER_ACTOR (box));
|
||||
|
||||
if (CLUTTER_ACTOR_IS_VISIBLE (CLUTTER_ACTOR (box)))
|
||||
@ -313,34 +355,25 @@ clutter_box_pack_start (ClutterBox *box,
|
||||
}
|
||||
|
||||
/**
|
||||
* clutter_box_pack_end:
|
||||
* clutter_box_pack_defaults:
|
||||
* @box: a #ClutterBox
|
||||
* @actor: a #ClutterActor
|
||||
*
|
||||
* Packs @actor into @box
|
||||
* Packs @actor into @box, using the default settings for the
|
||||
* pack type and padding.
|
||||
*
|
||||
* Since: 0.4
|
||||
*/
|
||||
void
|
||||
clutter_box_pack_end (ClutterBox *box,
|
||||
clutter_box_pack_defaults (ClutterBox *box,
|
||||
ClutterActor *actor)
|
||||
{
|
||||
ClutterBoxChild *child;
|
||||
ClutterPadding padding = { 0, };
|
||||
|
||||
g_return_if_fail (CLUTTER_IS_BOX (box));
|
||||
g_return_if_fail (CLUTTER_IS_ACTOR (actor));
|
||||
|
||||
child = g_slice_new (ClutterBoxChild);
|
||||
child->actor = actor;
|
||||
child->pack_type = CLUTTER_PACK_END;
|
||||
|
||||
box->children = g_list_append (box->children, child);
|
||||
clutter_actor_set_parent (actor, CLUTTER_ACTOR (box));
|
||||
|
||||
CLUTTER_BOX_GET_CLASS (box)->pack_child (box, child);
|
||||
|
||||
if (CLUTTER_ACTOR_IS_VISIBLE (CLUTTER_ACTOR (box)))
|
||||
clutter_actor_queue_redraw (CLUTTER_ACTOR (box));
|
||||
clutter_box_pack (box, actor, CLUTTER_PACK_START, &padding);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -374,7 +407,18 @@ clutter_box_query_child (ClutterBox *box,
|
||||
if (child)
|
||||
{
|
||||
child->actor = actor;
|
||||
|
||||
child->pack_type = box_child->pack_type;
|
||||
|
||||
child->child_coords.x1 = box_child->child_coords.x1;
|
||||
child->child_coords.y1 = box_child->child_coords.y1;
|
||||
child->child_coords.x2 = box_child->child_coords.x2;
|
||||
child->child_coords.y2 = box_child->child_coords.y2;
|
||||
|
||||
child->padding.top = box_child->padding.top;
|
||||
child->padding.right = box_child->padding.right;
|
||||
child->padding.bottom = box_child->padding.bottom;
|
||||
child->padding.left = box_child->padding.left;
|
||||
}
|
||||
|
||||
return TRUE;
|
||||
@ -414,49 +458,226 @@ clutter_box_query_nth_child (ClutterBox *box,
|
||||
if (child)
|
||||
{
|
||||
child->actor = box_child->actor;
|
||||
|
||||
child->pack_type = box_child->pack_type;
|
||||
|
||||
child->child_coords.x1 = box_child->child_coords.x1;
|
||||
child->child_coords.y1 = box_child->child_coords.y1;
|
||||
child->child_coords.x2 = box_child->child_coords.x2;
|
||||
child->child_coords.y2 = box_child->child_coords.y2;
|
||||
|
||||
child->padding.top = box_child->padding.top;
|
||||
child->padding.right = box_child->padding.right;
|
||||
child->padding.bottom = box_child->padding.bottom;
|
||||
child->padding.left = box_child->padding.left;
|
||||
}
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
/**
|
||||
* clutter_box_get_spacing:
|
||||
* clutter_box_get_margin:
|
||||
* @box: a #ClutterBox
|
||||
* @margin: return location for a #ClutterMargin
|
||||
*
|
||||
* Gets the value set using clutter_box_set_spacing().
|
||||
*
|
||||
* Return value: the spacing between children of the box
|
||||
* Gets the value set using clutter_box_set_margin().
|
||||
*
|
||||
* Since: 0.4
|
||||
*/
|
||||
guint
|
||||
clutter_box_get_spacing (ClutterBox *box)
|
||||
void
|
||||
clutter_box_get_margin (ClutterBox *box,
|
||||
ClutterMargin *margin)
|
||||
{
|
||||
g_return_val_if_fail (CLUTTER_IS_BOX (box), 0);
|
||||
g_return_if_fail (CLUTTER_IS_BOX (box));
|
||||
g_return_if_fail (margin != NULL);
|
||||
|
||||
return box->spacing;
|
||||
margin->top = box->margin.top;
|
||||
margin->right = box->margin.right;
|
||||
margin->bottom = box->margin.bottom;
|
||||
margin->left = box->margin.left;
|
||||
}
|
||||
|
||||
/**
|
||||
* clutter_box_set_spacing:
|
||||
* clutter_box_set_margin:
|
||||
* @box: a #ClutterBox
|
||||
* @spacing: the spacing between children
|
||||
* @margin: a #ClutterMargin, or %NULL to unset the margin
|
||||
*
|
||||
* Sets the spacing, in pixels, between the children of @box.
|
||||
* Sets the margin, in #ClutterUnit<!-- -->s, between the inner border
|
||||
* of the box and the children of the box.
|
||||
*
|
||||
* Since: 0.4
|
||||
*/
|
||||
void
|
||||
clutter_box_set_spacing (ClutterBox *box,
|
||||
guint spacing)
|
||||
const ClutterMargin *margin)
|
||||
{
|
||||
g_return_if_fail (CLUTTER_IS_BOX (box));
|
||||
|
||||
if (box->spacing != spacing)
|
||||
if (margin)
|
||||
{
|
||||
box->spacing = spacing;
|
||||
box->margin.top = margin->top;
|
||||
box->margin.right = margin->right;
|
||||
box->margin.bottom = margin->bottom;
|
||||
box->margin.left = margin->left;
|
||||
}
|
||||
else
|
||||
{
|
||||
box->margin.top = 0;
|
||||
box->margin.right = 0;
|
||||
box->margin.bottom = 0;
|
||||
box->margin.left = 0;
|
||||
}
|
||||
|
||||
g_object_notify (G_OBJECT (box), "spacing");
|
||||
if (CLUTTER_ACTOR_IS_VISIBLE (CLUTTER_ACTOR (box)))
|
||||
clutter_actor_queue_redraw (CLUTTER_ACTOR (box));
|
||||
|
||||
g_object_notify (G_OBJECT (box), "margin");
|
||||
}
|
||||
|
||||
/**
|
||||
* clutter_box_get_color:
|
||||
* @box: a #ClutterBox
|
||||
* @color: return location for the color
|
||||
*
|
||||
* Gets the background color of the box set with clutter_box_set_color().
|
||||
*
|
||||
* Since: 0.4
|
||||
*/
|
||||
void
|
||||
clutter_box_get_color (ClutterBox *box,
|
||||
ClutterColor *color)
|
||||
{
|
||||
g_return_if_fail (CLUTTER_IS_BOX (box));
|
||||
g_return_if_fail (color != NULL);
|
||||
|
||||
color->red = box->color.red;
|
||||
color->green = box->color.green;
|
||||
color->blue = box->color.blue;
|
||||
color->alpha = box->color.alpha;
|
||||
}
|
||||
|
||||
/**
|
||||
* clutter_box_set_color:
|
||||
* @box: a #ClutterBox
|
||||
* @color: the background color of the box
|
||||
*
|
||||
* Sets the background color of the box.
|
||||
*
|
||||
* Since: 0.4
|
||||
*/
|
||||
void
|
||||
clutter_box_set_color (ClutterBox *box,
|
||||
const ClutterColor *color)
|
||||
{
|
||||
g_return_if_fail (CLUTTER_IS_BOX (box));
|
||||
g_return_if_fail (color != NULL);
|
||||
|
||||
box->color.red = color->red;
|
||||
box->color.green = color->green;
|
||||
box->color.blue = color->blue;
|
||||
box->color.alpha = color->alpha;
|
||||
|
||||
if (CLUTTER_ACTOR_IS_VISIBLE (CLUTTER_ACTOR (box)))
|
||||
clutter_actor_queue_redraw (CLUTTER_ACTOR (box));
|
||||
|
||||
g_object_notify (G_OBJECT (box), "color");
|
||||
}
|
||||
|
||||
/**
|
||||
* clutter_box_remove_all:
|
||||
* @box: a #ClutterBox
|
||||
*
|
||||
* Removes all children actors from the #ClutterBox
|
||||
*
|
||||
* Since: 0.4
|
||||
*/
|
||||
void
|
||||
clutter_box_remove_all (ClutterBox *box)
|
||||
{
|
||||
GList *children;
|
||||
|
||||
g_return_if_fail (CLUTTER_IS_BOX (box));
|
||||
|
||||
children = box->children;
|
||||
while (children)
|
||||
{
|
||||
ClutterBoxChild *child = children->data;
|
||||
children = children->next;
|
||||
|
||||
clutter_container_remove_actor (CLUTTER_CONTAINER (box), child->actor);
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Boxed types
|
||||
*/
|
||||
|
||||
static void
|
||||
clutter_margin_free (ClutterMargin *margin)
|
||||
{
|
||||
if (G_LIKELY (margin))
|
||||
{
|
||||
g_slice_free (ClutterMargin, margin);
|
||||
}
|
||||
}
|
||||
|
||||
static ClutterMargin *
|
||||
clutter_margin_copy (const ClutterMargin *margin)
|
||||
{
|
||||
ClutterMargin *copy;
|
||||
|
||||
g_return_val_if_fail (margin != NULL, NULL);
|
||||
|
||||
copy = g_slice_new (ClutterMargin);
|
||||
*copy = *margin;
|
||||
|
||||
return copy;
|
||||
}
|
||||
|
||||
GType
|
||||
clutter_margin_get_type (void)
|
||||
{
|
||||
static GType gtype = 0;
|
||||
|
||||
if (G_UNLIKELY (gtype == 0))
|
||||
gtype = g_boxed_type_register_static (g_intern_static_string ("ClutterMargin"),
|
||||
(GBoxedCopyFunc) clutter_margin_copy,
|
||||
(GBoxedFreeFunc) clutter_margin_free);
|
||||
|
||||
return gtype;
|
||||
}
|
||||
|
||||
static void
|
||||
clutter_padding_free (ClutterPadding *padding)
|
||||
{
|
||||
if (G_LIKELY (padding))
|
||||
{
|
||||
g_slice_free (ClutterPadding, padding);
|
||||
}
|
||||
}
|
||||
|
||||
static ClutterPadding *
|
||||
clutter_padding_copy (const ClutterPadding *padding)
|
||||
{
|
||||
ClutterPadding *copy;
|
||||
|
||||
g_return_val_if_fail (padding != NULL, NULL);
|
||||
|
||||
copy = g_slice_new (ClutterPadding);
|
||||
*copy = *padding;
|
||||
|
||||
return copy;
|
||||
}
|
||||
|
||||
GType
|
||||
clutter_padding_get_type (void)
|
||||
{
|
||||
static GType gtype = 0;
|
||||
|
||||
if (G_UNLIKELY (gtype == 0))
|
||||
gtype = g_boxed_type_register_static (g_intern_static_string ("ClutterPadding"),
|
||||
(GBoxedCopyFunc) clutter_padding_copy,
|
||||
(GBoxedFreeFunc) clutter_padding_free);
|
||||
|
||||
return gtype;
|
||||
}
|
||||
|
@ -2,6 +2,7 @@
|
||||
#define __CLUTTER_BOX_H__
|
||||
|
||||
#include <clutter/clutter-actor.h>
|
||||
#include <clutter/clutter-types.h>
|
||||
|
||||
G_BEGIN_DECLS
|
||||
|
||||
@ -36,11 +37,22 @@ struct _ClutterBox
|
||||
|
||||
/*< private >*/
|
||||
|
||||
/* list of ClutterBoxChild structures */
|
||||
/* We need to put these in the instance structure, since this
|
||||
* is an abstract class meant to be subclassed; think of these
|
||||
* as "protected" attributes of the ClutterBox class
|
||||
*/
|
||||
|
||||
/* Allocation of the box */
|
||||
ClutterActorBox allocation;
|
||||
|
||||
/* List of ClutterBoxChild structures */
|
||||
GList *children;
|
||||
|
||||
/* spacing between child actors */
|
||||
guint spacing;
|
||||
/* Background color of the box */
|
||||
ClutterColor color;
|
||||
|
||||
/* Margin between the inner border of the box and the children */
|
||||
ClutterMargin margin;
|
||||
};
|
||||
|
||||
struct _ClutterBoxClass
|
||||
@ -67,7 +79,9 @@ struct _ClutterBoxClass
|
||||
/**
|
||||
* ClutterBoxChild:
|
||||
* @actor: the child #ClutterActor
|
||||
* @pack_type: the type of packing used
|
||||
* @child_coords: the original coordinates of the child
|
||||
* @pack_type: the type of packing used by the child
|
||||
* @padding: the padding around the child
|
||||
*
|
||||
* Packing data for children of a #ClutterBox.
|
||||
*
|
||||
@ -76,18 +90,27 @@ struct _ClutterBoxClass
|
||||
struct _ClutterBoxChild
|
||||
{
|
||||
ClutterActor *actor;
|
||||
|
||||
ClutterActorBox child_coords;
|
||||
ClutterPackType pack_type;
|
||||
ClutterPadding padding;
|
||||
};
|
||||
|
||||
GType clutter_box_get_type (void) G_GNUC_CONST;
|
||||
void clutter_box_set_spacing (ClutterBox *box,
|
||||
guint spacing);
|
||||
guint clutter_box_get_spacing (ClutterBox *box);
|
||||
void clutter_box_pack_start (ClutterBox *box,
|
||||
ClutterActor *actor);
|
||||
void clutter_box_pack_end (ClutterBox *box,
|
||||
void clutter_box_set_color (ClutterBox *box,
|
||||
const ClutterColor *color);
|
||||
void clutter_box_get_color (ClutterBox *box,
|
||||
ClutterColor *color);
|
||||
void clutter_box_set_margin (ClutterBox *box,
|
||||
const ClutterMargin *margin);
|
||||
void clutter_box_get_margin (ClutterBox *box,
|
||||
ClutterMargin *margin);
|
||||
void clutter_box_pack (ClutterBox *box,
|
||||
ClutterActor *actor,
|
||||
ClutterPackType pack_type,
|
||||
const ClutterPadding *padding);
|
||||
void clutter_box_pack_defaults (ClutterBox *box,
|
||||
ClutterActor *actor);
|
||||
void clutter_box_remove_all (ClutterBox *box);
|
||||
gboolean clutter_box_query_child (ClutterBox *box,
|
||||
ClutterActor *actor,
|
||||
ClutterBoxChild *child);
|
||||
|
@ -35,6 +35,8 @@ G_BEGIN_DECLS
|
||||
|
||||
#define CLUTTER_TYPE_GEOMETRY (clutter_geometry_get_type ())
|
||||
#define CLUTTER_TYPE_KNOT (clutter_knot_get_type ())
|
||||
#define CLUTTER_TYPE_MARGIN (clutter_margin_get_type ())
|
||||
#define CLUTTER_TYPE_PADDING (clutter_padding_get_type ())
|
||||
#define CLUTTER_TYPE_VERTEX (clutter_vertex_get_type ())
|
||||
|
||||
/**
|
||||
@ -71,6 +73,8 @@ typedef enum { /*< prefix=CLUTTER_GRAVITY >*/
|
||||
|
||||
typedef struct _ClutterGeometry ClutterGeometry;
|
||||
typedef struct _ClutterKnot ClutterKnot;
|
||||
typedef struct _ClutterMargin ClutterMargin;
|
||||
typedef struct _ClutterPadding ClutterPadding;
|
||||
typedef struct _ClutterVertex ClutterVertex;
|
||||
|
||||
/**
|
||||
@ -164,6 +168,48 @@ typedef enum { /*< prefix=CLUTTER_ROTATE >*/
|
||||
CLUTTER_ROTATE_CCW
|
||||
} ClutterRotateDirection;
|
||||
|
||||
/**
|
||||
* ClutterMargin:
|
||||
* @top: top margin
|
||||
* @right: right margin
|
||||
* @bottom: bottom margin
|
||||
* @left: left margin
|
||||
*
|
||||
* Margins from the inner borders of a container
|
||||
*
|
||||
* Since: 0.4
|
||||
*/
|
||||
struct _ClutterMargin
|
||||
{
|
||||
ClutterUnit top;
|
||||
ClutterUnit right;
|
||||
ClutterUnit bottom;
|
||||
ClutterUnit left;
|
||||
};
|
||||
|
||||
GType clutter_margin_get_type (void) G_GNUC_CONST;
|
||||
|
||||
/**
|
||||
* ClutterPadding
|
||||
* @top: top padding
|
||||
* @right: right padding
|
||||
* @bottom: bottom padding
|
||||
* @left: left padding
|
||||
*
|
||||
* Padding of the children of a container
|
||||
*
|
||||
* Since: 0.4
|
||||
*/
|
||||
struct _ClutterPadding
|
||||
{
|
||||
ClutterUnit top;
|
||||
ClutterUnit right;
|
||||
ClutterUnit bottom;
|
||||
ClutterUnit left;
|
||||
};
|
||||
|
||||
GType clutter_padding_get_type (void) G_GNUC_CONST;
|
||||
|
||||
G_END_DECLS
|
||||
|
||||
#endif /* __CLUTTER_TYPES_H__ */
|
||||
|
@ -78,7 +78,7 @@ main (int argc, char *argv[])
|
||||
rect = clutter_rectangle_new_with_color (&label_color);
|
||||
clutter_actor_set_size (rect, 100, 100);
|
||||
|
||||
clutter_box_pack_start (CLUTTER_BOX (hbox), rect);
|
||||
clutter_box_pack_defaults (CLUTTER_BOX (hbox), rect);
|
||||
clutter_actor_show (rect);
|
||||
|
||||
g_debug (G_STRLOC ": rect[%d][%d] - (x:%d, y:%d, w:%d, h:%d)",
|
||||
|
Loading…
Reference in New Issue
Block a user