[layout] Update Box

* Use ::layout-changed to queue a relayout when the layout changes

* Destroy the Box children when destroying the Box

* Allow getting the layout manager from the Box
This commit is contained in:
Emmanuele Bassi 2009-09-14 11:28:34 +01:00
parent d096a3c791
commit 4e8d8bbc15
2 changed files with 70 additions and 6 deletions

View File

@ -24,6 +24,8 @@ struct _ClutterBoxPrivate
ClutterLayoutManager *manager; ClutterLayoutManager *manager;
GList *children; GList *children;
guint changed_id;
}; };
enum enum
@ -257,16 +259,58 @@ clutter_box_real_allocate (ClutterActor *actor,
} }
static void static void
clutter_box_dispose (GObject *gobject) clutter_box_destroy (ClutterActor *actor)
{ {
ClutterBoxPrivate *priv = CLUTTER_BOX (gobject)->priv; ClutterBoxPrivate *priv = CLUTTER_BOX (actor)->priv;
GList *l;
for (l = priv->children; l != NULL; l = l->next)
clutter_actor_destroy (l->data);
CLUTTER_ACTOR_CLASS (clutter_box_parent_class)->destroy (actor);
}
static void
on_layout_changed (ClutterLayoutManager *manager,
ClutterActor *self)
{
clutter_actor_queue_relayout (self);
}
static void
set_layout_manager (ClutterBox *self,
ClutterLayoutManager *manager)
{
ClutterBoxPrivate *priv = self->priv;
if (priv->manager != NULL) if (priv->manager != NULL)
{ {
if (priv->changed_id != 0)
g_signal_handler_disconnect (priv->manager, priv->changed_id);
g_object_unref (priv->manager); g_object_unref (priv->manager);
priv->manager = NULL; priv->manager = NULL;
priv->changed_id = 0;
} }
if (manager != NULL)
{
priv->manager = g_object_ref_sink (manager);
priv->changed_id =
g_signal_connect (priv->manager, "layout-changed",
G_CALLBACK (on_layout_changed),
self);
}
}
static void
clutter_box_dispose (GObject *gobject)
{
ClutterBox *self = CLUTTER_BOX (gobject);
set_layout_manager (self, NULL);
G_OBJECT_CLASS (clutter_box_parent_class)->dispose (gobject); G_OBJECT_CLASS (clutter_box_parent_class)->dispose (gobject);
} }
@ -276,13 +320,12 @@ clutter_box_set_property (GObject *gobject,
const GValue *value, const GValue *value,
GParamSpec *pspec) GParamSpec *pspec)
{ {
ClutterBoxPrivate *priv = CLUTTER_BOX (gobject)->priv; ClutterBox *self = CLUTTER_BOX (gobject);
switch (prop_id) switch (prop_id)
{ {
case PROP_LAYOUT_MANAGER: case PROP_LAYOUT_MANAGER:
priv->manager = g_value_get_object (value); set_layout_manager (self, g_value_get_object (value));
g_object_ref_sink (priv->manager);
break; break;
default: default:
@ -325,6 +368,7 @@ clutter_box_class_init (ClutterBoxClass *klass)
actor_class->allocate = clutter_box_real_allocate; actor_class->allocate = clutter_box_real_allocate;
actor_class->paint = clutter_box_real_paint; actor_class->paint = clutter_box_real_paint;
actor_class->pick = clutter_box_real_pick; actor_class->pick = clutter_box_real_pick;
actor_class->destroy = clutter_box_destroy;
gobject_class->set_property = clutter_box_set_property; gobject_class->set_property = clutter_box_set_property;
gobject_class->get_property = clutter_box_get_property; gobject_class->get_property = clutter_box_get_property;
@ -367,3 +411,21 @@ clutter_box_new (ClutterLayoutManager *manager)
"layout-manager", manager, "layout-manager", manager,
NULL); NULL);
} }
/**
* clutter_box_get_layout_manager:
* @box: a #ClutterBox
*
* Retrieves the #ClutterLayoutManager instance used by @box
*
* Return value: a #ClutterLayoutManager
*
* Since: 1.2
*/
ClutterLayoutManager *
clutter_box_get_layout_manager (ClutterBox *box)
{
g_return_val_if_fail (CLUTTER_IS_BOX (box), NULL);
return box->priv->manager;
}

View File

@ -38,6 +38,8 @@ GType clutter_box_get_type (void) G_GNUC_CONST;
ClutterActor * clutter_box_new (ClutterLayoutManager *manager); ClutterActor * clutter_box_new (ClutterLayoutManager *manager);
ClutterLayoutManager *clutter_box_get_layout_manager (ClutterBox *box);
G_END_DECLS G_END_DECLS
#endif /* __CLUTTER_BOX_H__ */ #endif /* __CLUTTER_BOX_H__ */