mirror of
https://github.com/brl/mutter.git
synced 2025-01-12 04:34:40 +00:00
actor: Remove default layout-manager
It's creating more issues than what it's trying to solve. At least for the time being, let's not set one.
This commit is contained in:
parent
bd348625c7
commit
8ebf46d74c
@ -480,7 +480,6 @@ struct _ClutterActorPrivate
|
|||||||
queued without an effect. */
|
queued without an effect. */
|
||||||
guint is_dirty : 1;
|
guint is_dirty : 1;
|
||||||
guint bg_color_set : 1;
|
guint bg_color_set : 1;
|
||||||
guint has_overridden_allocate : 1;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
enum
|
enum
|
||||||
@ -1970,18 +1969,10 @@ clutter_actor_set_allocation_internal (ClutterActor *self,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static inline void
|
static inline void
|
||||||
clutter_actor_maybe_layout_children (ClutterActor *self,
|
clutter_actor_maybe_layout_children (ClutterActor *self)
|
||||||
gboolean check_allocate)
|
|
||||||
{
|
{
|
||||||
ClutterActorPrivate *priv = self->priv;
|
ClutterActorPrivate *priv = self->priv;
|
||||||
|
|
||||||
/* see the comment in clutter_actor_real_allocate() and in
|
|
||||||
* clutter_actor_set_allocation() for why this is currently
|
|
||||||
* necessary
|
|
||||||
*/
|
|
||||||
if (check_allocate && priv->has_overridden_allocate)
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (priv->n_children != 0 &&
|
if (priv->n_children != 0 &&
|
||||||
priv->layout_manager != NULL)
|
priv->layout_manager != NULL)
|
||||||
{
|
{
|
||||||
@ -2026,19 +2017,8 @@ clutter_actor_real_allocate (ClutterActor *self,
|
|||||||
* so that people connecting to properties will be able to get valid
|
* so that people connecting to properties will be able to get valid
|
||||||
* data out of the sub-tree of the scene graph that has this actor at
|
* data out of the sub-tree of the scene graph that has this actor at
|
||||||
* the root.
|
* the root.
|
||||||
*
|
|
||||||
* XXX - the default behaviour for actor subclasses with a layout
|
|
||||||
* management policy for their children is to override allocate() and
|
|
||||||
* chain up; this means that we cannot call clutter_layout_manager_allocate()
|
|
||||||
* unconditionally here, because it will lead to a double allocation. hence
|
|
||||||
* the nasty check on the allocate() vfunc.
|
|
||||||
*
|
|
||||||
* if an actor wants to override the allocate() vfunc and still delegate
|
|
||||||
* to the actor's layout manager, then it can either call the layout manager
|
|
||||||
* allocate() method by itself, or use clutter_actor_set_allocation()
|
|
||||||
* instead.
|
|
||||||
*/
|
*/
|
||||||
clutter_actor_maybe_layout_children (self, TRUE);
|
clutter_actor_maybe_layout_children (self);
|
||||||
|
|
||||||
if (changed)
|
if (changed)
|
||||||
g_signal_emit (self, actor_signals[ALLOCATION_CHANGED], 0,
|
g_signal_emit (self, actor_signals[ALLOCATION_CHANGED], 0,
|
||||||
@ -6095,21 +6075,6 @@ clutter_actor_init (ClutterActor *self)
|
|||||||
priv->last_paint_volume_valid = TRUE;
|
priv->last_paint_volume_valid = TRUE;
|
||||||
|
|
||||||
priv->transform_valid = FALSE;
|
priv->transform_valid = FALSE;
|
||||||
|
|
||||||
/* we need to create the default layout manager here, because
|
|
||||||
* constructed() may not end up being called, if for instance
|
|
||||||
* somebody forgot to chain up
|
|
||||||
*/
|
|
||||||
priv->layout_manager = clutter_fixed_layout_new ();
|
|
||||||
g_object_ref_sink (priv->layout_manager);
|
|
||||||
clutter_layout_manager_set_container (priv->layout_manager,
|
|
||||||
CLUTTER_CONTAINER (self));
|
|
||||||
g_signal_connect (priv->layout_manager, "layout-changed",
|
|
||||||
G_CALLBACK (on_layout_manager_changed),
|
|
||||||
self);
|
|
||||||
|
|
||||||
priv->has_overridden_allocate =
|
|
||||||
CLUTTER_ACTOR_GET_CLASS (self)->allocate != clutter_actor_real_allocate;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -7567,13 +7532,8 @@ clutter_actor_set_allocation (ClutterActor *self,
|
|||||||
* so that people connecting to properties will be able to get valid
|
* so that people connecting to properties will be able to get valid
|
||||||
* data out of the sub-tree of the scene graph that has this actor at
|
* data out of the sub-tree of the scene graph that has this actor at
|
||||||
* the root.
|
* the root.
|
||||||
*
|
|
||||||
* XXX - unlike the default ClutterActor::allocate(), we let any
|
|
||||||
* layout manager delegate layout our children, if any. the rationale
|
|
||||||
* for this being that only newly written code will call this function
|
|
||||||
* and will be able to avoid the double allocation.
|
|
||||||
*/
|
*/
|
||||||
clutter_actor_maybe_layout_children (self, FALSE);
|
clutter_actor_maybe_layout_children (self);
|
||||||
|
|
||||||
if (changed)
|
if (changed)
|
||||||
g_signal_emit (self, actor_signals[ALLOCATION_CHANGED], 0,
|
g_signal_emit (self, actor_signals[ALLOCATION_CHANGED], 0,
|
||||||
@ -14970,6 +14930,7 @@ clutter_actor_set_layout_manager (ClutterActor *self,
|
|||||||
}
|
}
|
||||||
|
|
||||||
clutter_actor_queue_relayout (self);
|
clutter_actor_queue_relayout (self);
|
||||||
|
|
||||||
g_object_notify_by_pspec (G_OBJECT (self), obj_props[PROP_LAYOUT_MANAGER]);
|
g_object_notify_by_pspec (G_OBJECT (self), obj_props[PROP_LAYOUT_MANAGER]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user