2006-12-14 Emmanuele Bassi <ebassi@openedhand.com>

* clutter/clutter-color.h:
	* clutter/clutter-color.c: Expose clutter_color_copy()
	and clutter_color_free() for the python bindings, so that
	they can manager the conversion automatically; use the
	slice allocator when copying/freeing a ClutterColor.
This commit is contained in:
Emmanuele Bassi 2006-12-14 22:19:08 +00:00
parent 4d168e81fa
commit 9118c2ef99
9 changed files with 182 additions and 53 deletions

View File

@ -1,3 +1,23 @@
2006-12-14 Emmanuele Bassi <ebassi@openedhand.com>
* clutter/clutter-color.h:
* clutter/clutter-color.c: Expose clutter_color_copy()
and clutter_color_free() for the python bindings, so that
they can manager the conversion automatically; use the
slice allocator when copying/freeing a ClutterColor.
2006-12-13 Emmanuele Bassi <ebassi@openedhand.com>
* clutter/clutter-color.h:
* clutter/clutter-color.c: Add clutter_color_equal(),
a function for comparing two colors.
* clutter/clutter-rectangle.c:
(clutter_rectangle_set_color),
(clutter_rectangle_set_border_color): Unset the border if
the color of the rectangle and the color of the border are
the same.
2006-12-13 Emmanuele Bassi <ebassi@openedhand.com> 2006-12-13 Emmanuele Bassi <ebassi@openedhand.com>
* clutter/clutter-actor.c: * clutter/clutter-actor.c:

View File

@ -416,16 +416,73 @@ clutter_color_parse (const gchar *color,
return FALSE; return FALSE;
} }
static ClutterColor * /**
clutter_color_copy (ClutterColor *color) * clutter_color_equal:
* @a: a #ClutterColor
* @b: a #ClutterColor
*
* Compares two #ClutterColor<!-- -->s and checks if they are the same.
*
* Return: %TRUE if the two colors are the same.
*
* Since: 0.2
*/
gboolean
clutter_color_equal (const ClutterColor *a,
const ClutterColor *b)
{ {
ClutterColor *result = g_new0 (ClutterColor, 1); g_return_val_if_fail (a != NULL, FALSE);
g_return_val_if_fail (b != NULL, FALSE);
if (a == b)
return TRUE;
return (a->red == b->red &&
a->green == b->green &&
a->blue == b->blue &&
a->alpha == b->alpha);
}
/**
* clutter_color_copy:
* @color: a #ClutterColor
*
* Makes a copy of the color structure. The result must be
* freed using clutter_color_free().
*
* Return value: an allocated copy of @color.
*
* Since: 0.2
*/
ClutterColor *
clutter_color_copy (const ClutterColor *color)
{
ClutterColor *result;
g_return_val_if_fail (color != NULL, NULL);
result = g_slice_new (ClutterColor);
*result = *color; *result = *color;
return result; return result;
} }
/**
* clutter_color_free:
* @color: a #ClutterColor
*
* Frees a color structure created with clutter_color_copy().
*
* Since: 0.2
*/
void
clutter_color_free (ClutterColor *color)
{
g_return_if_fail (color != NULL);
g_slice_free (ClutterColor, color);
}
GType GType
clutter_color_get_type (void) clutter_color_get_type (void)
{ {
@ -434,6 +491,6 @@ clutter_color_get_type (void)
if (!our_type) if (!our_type)
our_type = g_boxed_type_register_static ("ClutterColor", our_type = g_boxed_type_register_static ("ClutterColor",
(GBoxedCopyFunc) clutter_color_copy, (GBoxedCopyFunc) clutter_color_copy,
(GBoxedFreeFunc) g_free); (GBoxedFreeFunc) clutter_color_free);
return our_type; return our_type;
} }

View File

@ -43,17 +43,22 @@ struct _ClutterColor
guint8 alpha; guint8 alpha;
}; };
GType clutter_color_get_type (void) G_GNUC_CONST; ClutterColor *clutter_color_copy (const ClutterColor *color);
void clutter_color_free (ClutterColor *color);
gboolean clutter_color_parse (const gchar *color, gboolean clutter_color_parse (const gchar *color,
ClutterColor *dest); ClutterColor *dest);
gboolean clutter_color_equal (const ClutterColor *a,
const ClutterColor *b);
GType clutter_color_get_type (void) G_GNUC_CONST;
void clutter_color_add (const ClutterColor *src1, void clutter_color_add (const ClutterColor *src1,
const ClutterColor *src2, const ClutterColor *src2,
ClutterColor *dest); ClutterColor *dest);
void clutter_color_subtract (const ClutterColor *src1, void clutter_color_subtract (const ClutterColor *src1,
const ClutterColor *src2, const ClutterColor *src2,
ClutterColor *dest); ClutterColor *dest);
void clutter_color_lighten (const ClutterColor *src, void clutter_color_lighten (const ClutterColor *src,
ClutterColor *dest); ClutterColor *dest);
void clutter_color_darken (const ClutterColor *src, void clutter_color_darken (const ClutterColor *src,

View File

@ -377,10 +377,16 @@ clutter_rectangle_set_color (ClutterRectangle *rectangle,
clutter_actor_set_opacity (CLUTTER_ACTOR (rectangle), clutter_actor_set_opacity (CLUTTER_ACTOR (rectangle),
priv->color.alpha); priv->color.alpha);
if (clutter_color_equal (&priv->color, &priv->border_color))
priv->has_border = FALSE;
else
priv->has_border = TRUE;
if (CLUTTER_ACTOR_IS_VISIBLE (CLUTTER_ACTOR (rectangle))) if (CLUTTER_ACTOR_IS_VISIBLE (CLUTTER_ACTOR (rectangle)))
clutter_actor_queue_redraw (CLUTTER_ACTOR (rectangle)); clutter_actor_queue_redraw (CLUTTER_ACTOR (rectangle));
g_object_notify (G_OBJECT (rectangle), "color"); g_object_notify (G_OBJECT (rectangle), "color");
g_object_notify (G_OBJECT (rectangle), "has-border");
g_object_unref (rectangle); g_object_unref (rectangle);
} }
@ -498,10 +504,16 @@ clutter_rectangle_set_border_color (ClutterRectangle *rectangle,
priv->border_color.blue = color->blue; priv->border_color.blue = color->blue;
priv->border_color.alpha = color->alpha; priv->border_color.alpha = color->alpha;
if (clutter_color_equal (&priv->color, &priv->border_color))
priv->has_border = FALSE;
else
priv->has_border = TRUE;
if (CLUTTER_ACTOR_IS_VISIBLE (CLUTTER_ACTOR (rectangle))) if (CLUTTER_ACTOR_IS_VISIBLE (CLUTTER_ACTOR (rectangle)))
clutter_actor_queue_redraw (CLUTTER_ACTOR (rectangle)); clutter_actor_queue_redraw (CLUTTER_ACTOR (rectangle));
g_object_notify (G_OBJECT (rectangle), "border-color"); g_object_notify (G_OBJECT (rectangle), "border-color");
g_object_notify (G_OBJECT (rectangle), "has-border");
g_object_unref (rectangle); g_object_unref (rectangle);
} }
} }

View File

@ -1,3 +1,9 @@
2006-12-13 Emmanuele Bassi <ebassi@openedhand.com>
* clutter-sections.txt: Update; add clutter_color_equal().
* tmpl/clutter-color.sgml: Update template.
2006-12-13 Emmanuele Bassi <ebassi@openedhand.com> 2006-12-13 Emmanuele Bassi <ebassi@openedhand.com>
* clutter-sections.txt: Update. * clutter-sections.txt: Update.

View File

@ -466,9 +466,12 @@ CLUTTER_FIXED_DIV
<SECTION> <SECTION>
<FILE>clutter-color</FILE> <FILE>clutter-color</FILE>
ClutterColor ClutterColor
clutter_color_copy
clutter_color_free
clutter_color_parse clutter_color_parse
clutter_color_add clutter_color_add
clutter_color_subtract clutter_color_subtract
clutter_color_equal
clutter_color_lighten clutter_color_lighten
clutter_color_darken clutter_color_darken
clutter_color_shade clutter_color_shade
@ -495,12 +498,11 @@ clutter_event_new
clutter_event_copy clutter_event_copy
clutter_event_free clutter_event_free
clutter_event_type clutter_event_type
clutter_key_event_type
clutter_key_event_time
clutter_key_event_state
clutter_button_event_time clutter_button_event_time
clutter_button_event_x clutter_button_event_x
clutter_button_event_y clutter_button_event_y
clutter_key_event_time
clutter_key_event_state
clutter_key_event_symbol clutter_key_event_symbol
clutter_key_event_code clutter_key_event_code
clutter_key_event_unicode clutter_key_event_unicode

View File

@ -27,6 +27,23 @@ clutter-color
@blue: @blue:
@alpha: @alpha:
<!-- ##### FUNCTION clutter_color_copy ##### -->
<para>
</para>
@color:
@Returns:
<!-- ##### FUNCTION clutter_color_free ##### -->
<para>
</para>
@color:
<!-- ##### FUNCTION clutter_color_parse ##### --> <!-- ##### FUNCTION clutter_color_parse ##### -->
<para> <para>
@ -57,6 +74,16 @@ clutter-color
@dest: @dest:
<!-- ##### FUNCTION clutter_color_equal ##### -->
<para>
</para>
@a:
@b:
@Returns:
<!-- ##### FUNCTION clutter_color_lighten ##### --> <!-- ##### FUNCTION clutter_color_lighten ##### -->
<para> <para>

View File

@ -122,24 +122,6 @@ Windowing events handled by Clutter.
@Returns: @Returns:
<!-- ##### FUNCTION clutter_key_event_time ##### -->
<para>
</para>
@keyev:
@Returns:
<!-- ##### FUNCTION clutter_key_event_state ##### -->
<para>
</para>
@keyev:
@Returns:
<!-- ##### FUNCTION clutter_button_event_time ##### --> <!-- ##### FUNCTION clutter_button_event_time ##### -->
<para> <para>
@ -167,6 +149,24 @@ Windowing events handled by Clutter.
@Returns: @Returns:
<!-- ##### FUNCTION clutter_key_event_time ##### -->
<para>
</para>
@keyev:
@Returns:
<!-- ##### FUNCTION clutter_key_event_state ##### -->
<para>
</para>
@keyev:
@Returns:
<!-- ##### FUNCTION clutter_key_event_symbol ##### --> <!-- ##### FUNCTION clutter_key_event_symbol ##### -->
<para> <para>