[clutter/wip/apocalypses/apocalypse-1: 14/43] actor: Store the fixed sizes into LayoutInfo
- From: Emmanuele Bassi <ebassi src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [clutter/wip/apocalypses/apocalypse-1: 14/43] actor: Store the fixed sizes into LayoutInfo
- Date: Wed, 7 Dec 2011 18:14:32 +0000 (UTC)
commit 62c1b41b1f05f5976735340a487ce0ea05841212
Author: Emmanuele Bassi <ebassi linux intel com>
Date: Thu Nov 24 14:13:29 2011 +0000
actor: Store the fixed sizes into LayoutInfo
Remove four more floats from ClutterActorPrivate.
The fixed minimum and natural sizes should be stored inside the
ClutterLayoutInfo structure, along with the fixed position.
clutter/clutter-actor-private.h | 9 ++
clutter/clutter-actor.c | 200 ++++++++++++++++++++++++++++-----------
2 files changed, 152 insertions(+), 57 deletions(-)
---
diff --git a/clutter/clutter-actor-private.h b/clutter/clutter-actor-private.h
index e02eefe..ec9433c 100644
--- a/clutter/clutter-actor-private.h
+++ b/clutter/clutter-actor-private.h
@@ -119,6 +119,10 @@ typedef struct _ClutterLayoutInfo ClutterLayoutInfo;
* @y_expand: whether the actor should expand vertically
* @x_align: the horizontal alignment, if the actor expands horizontally
* @y_align: the vertical alignment, if the actor expands vertically
+ * @min_width: the minimum width, set using clutter_actor_set_min_width()
+ * @min_height: the minimum height, set using clutter_actor_set_min_height()
+ * @natural_width: the natural width, set using clutter_actor_set_natural_width()
+ * @natural_height: the natural height, set using clutter_actor_set_natural_height()
*
* Ancillary layout information for an actor.
*/
@@ -135,6 +139,11 @@ struct _ClutterLayoutInfo
guint x_align : 4;
guint y_align : 4;
+
+ float min_width;
+ float min_height;
+ float natural_width;
+ float natural_height;
};
const ClutterLayoutInfo * _clutter_actor_get_layout_info_or_defaults (ClutterActor *self);
diff --git a/clutter/clutter-actor.c b/clutter/clutter-actor.c
index 3df24d9..e1883f0 100644
--- a/clutter/clutter-actor.c
+++ b/clutter/clutter-actor.c
@@ -393,11 +393,6 @@ struct _ClutterActorPrivate
guint cached_height_age;
guint cached_width_age;
- gfloat request_min_width;
- gfloat request_min_height;
- gfloat request_natural_width;
- gfloat request_natural_height;
-
ClutterActorBox allocation;
ClutterAllocationFlags allocation_flags;
@@ -3617,19 +3612,39 @@ clutter_actor_get_property (GObject *object,
break;
case PROP_MIN_WIDTH:
- g_value_set_float (value, priv->request_min_width);
+ {
+ const ClutterLayoutInfo *info;
+
+ info = _clutter_actor_get_layout_info_or_defaults (actor);
+ g_value_set_float (value, info->min_width);
+ }
break;
case PROP_MIN_HEIGHT:
- g_value_set_float (value, priv->request_min_height);
+ {
+ const ClutterLayoutInfo *info;
+
+ info = _clutter_actor_get_layout_info_or_defaults (actor);
+ g_value_set_float (value, info->min_height);
+ }
break;
case PROP_NATURAL_WIDTH:
- g_value_set_float (value, priv->request_natural_width);
+ {
+ const ClutterLayoutInfo *info;
+
+ info = _clutter_actor_get_layout_info_or_defaults (actor);
+ g_value_set_float (value, info->natural_width);
+ }
break;
case PROP_NATURAL_HEIGHT:
- g_value_set_float (value, priv->request_natural_height);
+ {
+ const ClutterLayoutInfo *info;
+
+ info = _clutter_actor_get_layout_info_or_defaults (actor);
+ g_value_set_float (value, info->natural_height);
+ }
break;
case PROP_MIN_WIDTH_SET:
@@ -6190,32 +6205,64 @@ clutter_actor_get_preferred_width (ClutterActor *self,
gfloat *min_width_p,
gfloat *natural_width_p)
{
- ClutterActorClass *klass;
+ float request_min_width, request_natural_width;
+ SizeRequest *cached_size_request;
+ const ClutterLayoutInfo *info;
ClutterActorPrivate *priv;
gboolean found_in_cache;
- SizeRequest *cached_size_request;
g_return_if_fail (CLUTTER_IS_ACTOR (self));
- klass = CLUTTER_ACTOR_GET_CLASS (self);
priv = self->priv;
- found_in_cache = FALSE;
- cached_size_request = &priv->width_requests[0];
+ info = _clutter_actor_get_layout_info_or_defaults (self);
+
+ /* we shortcircuit the case of a fixed size set using set_width() */
+ if (priv->min_width_set && priv->natural_width_set)
+ {
+ if (min_width_p != NULL)
+ *min_width_p = info->min_width;
+
+ if (natural_width_p != NULL)
+ *natural_width_p = info->natural_width;
+
+ return;
+ }
+
+ /* the remaining cases are:
+ *
+ * - either min_width or natural_width have been set
+ * - neither min_width or natural_width have been set
+ *
+ * in both cases, we go through the cache (and through the actor in case
+ * of cache misses) and determine the authoritative value depending on
+ * the *_set flags.
+ */
if (!priv->needs_width_request)
- found_in_cache = _clutter_actor_get_cached_size_request (for_height,
- priv->width_requests,
- &cached_size_request);
+ {
+ found_in_cache =
+ _clutter_actor_get_cached_size_request (for_height,
+ priv->width_requests,
+ &cached_size_request);
+ }
+ else
+ {
+ /* if the actor needs a width request we use the first slot */
+ found_in_cache = FALSE;
+ cached_size_request = &priv->width_requests[0];
+ }
if (!found_in_cache)
{
gfloat min_width, natural_width;
+ ClutterActorClass *klass;
min_width = natural_width = 0;
CLUTTER_NOTE (LAYOUT, "Width request for %.2f px", for_height);
+ klass = CLUTTER_ACTOR_GET_CLASS (self);
klass->get_preferred_width (self, for_height,
&min_width,
&natural_width);
@@ -6231,21 +6278,25 @@ clutter_actor_get_preferred_width (ClutterActor *self,
cached_size_request->for_size = for_height;
cached_size_request->age = priv->cached_width_age;
- priv->cached_width_age ++;
+ priv->cached_width_age += 1;
priv->needs_width_request = FALSE;
}
if (!priv->min_width_set)
- priv->request_min_width = cached_size_request->min_size;
+ request_min_width = cached_size_request->min_size;
+ else
+ request_min_width = info->min_width;
if (!priv->natural_width_set)
- priv->request_natural_width = cached_size_request->natural_size;
+ request_natural_width = cached_size_request->natural_size;
+ else
+ request_natural_width = info->natural_width;
if (min_width_p)
- *min_width_p = priv->request_min_width;
+ *min_width_p = request_min_width;
if (natural_width_p)
- *natural_width_p = priv->request_natural_width;
+ *natural_width_p = request_natural_width;
}
/**
@@ -6275,32 +6326,63 @@ clutter_actor_get_preferred_height (ClutterActor *self,
gfloat *min_height_p,
gfloat *natural_height_p)
{
- ClutterActorClass *klass;
+ float request_min_height, request_natural_height;
+ SizeRequest *cached_size_request;
+ const ClutterLayoutInfo *info;
ClutterActorPrivate *priv;
gboolean found_in_cache;
- SizeRequest *cached_size_request;
g_return_if_fail (CLUTTER_IS_ACTOR (self));
- klass = CLUTTER_ACTOR_GET_CLASS (self);
priv = self->priv;
- found_in_cache = FALSE;
- cached_size_request = &priv->height_requests[0];
+ info = _clutter_actor_get_layout_info_or_defaults (self);
+
+ /* we shortcircuit the case of a fixed size set using set_height() */
+ if (priv->min_height_set && priv->natural_height_set)
+ {
+ if (min_height_p != NULL)
+ *min_height_p = info->min_height;
+
+ if (natural_height_p != NULL)
+ *natural_height_p = info->natural_height;
+
+ return;
+ }
+
+ /* the remaining cases are:
+ *
+ * - either min_height or natural_height have been set
+ * - neither min_height or natural_height have been set
+ *
+ * in both cases, we go through the cache (and through the actor in case
+ * of cache misses) and determine the authoritative value depending on
+ * the *_set flags.
+ */
if (!priv->needs_height_request)
- found_in_cache = _clutter_actor_get_cached_size_request (for_width,
- priv->height_requests,
- &cached_size_request);
+ {
+ found_in_cache =
+ _clutter_actor_get_cached_size_request (for_width,
+ priv->height_requests,
+ &cached_size_request);
+ }
+ else
+ {
+ found_in_cache = FALSE;
+ cached_size_request = &priv->height_requests[0];
+ }
if (!found_in_cache)
{
gfloat min_height, natural_height;
+ ClutterActorClass *klass;
min_height = natural_height = 0;
CLUTTER_NOTE (LAYOUT, "Height request for %.2f px", for_width);
+ klass = CLUTTER_ACTOR_GET_CLASS (self);
klass->get_preferred_height (self, for_width,
&min_height,
&natural_height);
@@ -6311,37 +6393,30 @@ clutter_actor_get_preferred_height (ClutterActor *self,
if (natural_height < min_height)
natural_height = min_height;
- if (!priv->min_height_set)
- {
- priv->request_min_height = min_height;
- }
-
- if (!priv->natural_height_set)
- {
- priv->request_natural_height = natural_height;
- }
-
cached_size_request->min_size = min_height;
cached_size_request->natural_size = natural_height;
cached_size_request->for_size = for_width;
cached_size_request->age = priv->cached_height_age;
- priv->cached_height_age ++;
-
+ priv->cached_height_age += 1;
priv->needs_height_request = FALSE;
}
if (!priv->min_height_set)
- priv->request_min_height = cached_size_request->min_size;
+ request_min_height = cached_size_request->min_size;
+ else
+ request_min_height = info->min_height;
if (!priv->natural_height_set)
- priv->request_natural_height = cached_size_request->natural_size;
+ request_natural_height = cached_size_request->natural_size;
+ else
+ request_natural_height = info->natural_height;
if (min_height_p)
- *min_height_p = priv->request_min_height;
+ *min_height_p = request_min_height;
if (natural_height_p)
- *natural_height_p = priv->request_natural_height;
+ *natural_height_p = request_natural_height;
}
/**
@@ -6520,7 +6595,6 @@ static void
clutter_actor_adjust_allocation (ClutterActor *self,
ClutterActorBox *allocation)
{
- ClutterActorPrivate *priv = self->priv;
ClutterActorBox adj_allocation;
float alloc_width, alloc_height;
float min_width, min_height;
@@ -6915,6 +6989,7 @@ clutter_actor_set_min_width (ClutterActor *self,
{
ClutterActorPrivate *priv = self->priv;
ClutterActorBox old = { 0, };
+ ClutterLayoutInfo *info;
/* if we are setting the size on a top-level actor and the
* backend only supports static top-levels (e.g. framebuffers)
@@ -6925,14 +7000,16 @@ clutter_actor_set_min_width (ClutterActor *self,
clutter_feature_available (CLUTTER_FEATURE_STAGE_STATIC))
return;
- if (priv->min_width_set && min_width == priv->request_min_width)
+ info = _clutter_actor_get_layout_info (self);
+
+ if (priv->min_width_set && min_width == info->min_width)
return;
g_object_freeze_notify (G_OBJECT (self));
clutter_actor_store_old_geometry (self, &old);
- priv->request_min_width = min_width;
+ info->min_width = min_width;
g_object_notify_by_pspec (G_OBJECT (self), obj_props[PROP_MIN_WIDTH]);
clutter_actor_set_min_width_set (self, TRUE);
@@ -6950,6 +7027,7 @@ clutter_actor_set_min_height (ClutterActor *self,
{
ClutterActorPrivate *priv = self->priv;
ClutterActorBox old = { 0, };
+ ClutterLayoutInfo *info;
/* if we are setting the size on a top-level actor and the
* backend only supports static top-levels (e.g. framebuffers)
@@ -6960,14 +7038,16 @@ clutter_actor_set_min_height (ClutterActor *self,
clutter_feature_available (CLUTTER_FEATURE_STAGE_STATIC))
return;
- if (priv->min_height_set && min_height == priv->request_min_height)
+ info = _clutter_actor_get_layout_info (self);
+
+ if (priv->min_height_set && min_height == info->min_height)
return;
g_object_freeze_notify (G_OBJECT (self));
clutter_actor_store_old_geometry (self, &old);
- priv->request_min_height = min_height;
+ info->min_height = min_height;
g_object_notify_by_pspec (G_OBJECT (self), obj_props[PROP_MIN_HEIGHT]);
clutter_actor_set_min_height_set (self, TRUE);
@@ -6984,6 +7064,7 @@ clutter_actor_set_natural_width (ClutterActor *self,
{
ClutterActorPrivate *priv = self->priv;
ClutterActorBox old = { 0, };
+ ClutterLayoutInfo *info;
/* if we are setting the size on a top-level actor and the
* backend only supports static top-levels (e.g. framebuffers)
@@ -6994,15 +7075,16 @@ clutter_actor_set_natural_width (ClutterActor *self,
clutter_feature_available (CLUTTER_FEATURE_STAGE_STATIC))
return;
- if (priv->natural_width_set &&
- natural_width == priv->request_natural_width)
+ info = _clutter_actor_get_layout_info (self);
+
+ if (priv->natural_width_set && natural_width == info->natural_width)
return;
g_object_freeze_notify (G_OBJECT (self));
clutter_actor_store_old_geometry (self, &old);
- priv->request_natural_width = natural_width;
+ info->natural_width = natural_width;
g_object_notify_by_pspec (G_OBJECT (self), obj_props[PROP_NATURAL_WIDTH]);
clutter_actor_set_natural_width_set (self, TRUE);
@@ -7019,6 +7101,7 @@ clutter_actor_set_natural_height (ClutterActor *self,
{
ClutterActorPrivate *priv = self->priv;
ClutterActorBox old = { 0, };
+ ClutterLayoutInfo *info;
/* if we are setting the size on a top-level actor and the
* backend only supports static top-levels (e.g. framebuffers)
@@ -7029,15 +7112,16 @@ clutter_actor_set_natural_height (ClutterActor *self,
clutter_feature_available (CLUTTER_FEATURE_STAGE_STATIC))
return;
- if (priv->natural_height_set &&
- natural_height == priv->request_natural_height)
+ info = _clutter_actor_get_layout_info (self);
+
+ if (priv->natural_height_set && natural_height == info->natural_height)
return;
g_object_freeze_notify (G_OBJECT (self));
clutter_actor_store_old_geometry (self, &old);
- priv->request_natural_height = natural_height;
+ info->natural_height = natural_height;
g_object_notify_by_pspec (G_OBJECT (self), obj_props[PROP_NATURAL_HEIGHT]);
clutter_actor_set_natural_height_set (self, TRUE);
@@ -13407,6 +13491,8 @@ static const ClutterLayoutInfo default_layout_info = {
FALSE, /* y-expand */
CLUTTER_ACTOR_ALIGN_FILL, /* x-align */
CLUTTER_ACTOR_ALIGN_FILL, /* y-align */
+ 0.f, 0.f, /* min_width, natural_width */
+ 0.f, 0.f, /* natual_width, natural_height */
};
static void
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]