cleaned up ClutterBehaviourEllipse api, added documentation

This commit is contained in:
Tomas Frydrych 2007-04-30 08:39:20 +00:00
parent 4085070479
commit e61aed2146
8 changed files with 236 additions and 74 deletions

View File

@ -40,6 +40,7 @@ source_h = \
$(srcdir)/clutter-alpha.h \ $(srcdir)/clutter-alpha.h \
$(srcdir)/clutter-behaviour.h \ $(srcdir)/clutter-behaviour.h \
$(srcdir)/clutter-behaviour-bspline.h \ $(srcdir)/clutter-behaviour-bspline.h \
$(srcdir)/clutter-behaviour-ellipse.h \
$(srcdir)/clutter-behaviour-opacity.h \ $(srcdir)/clutter-behaviour-opacity.h \
$(srcdir)/clutter-behaviour-path.h \ $(srcdir)/clutter-behaviour-path.h \
$(srcdir)/clutter-behaviour-rotate.h \ $(srcdir)/clutter-behaviour-rotate.h \
@ -125,6 +126,7 @@ source_c = \
clutter-backend.c \ clutter-backend.c \
clutter-behaviour.c \ clutter-behaviour.c \
clutter-behaviour-bspline.c \ clutter-behaviour-bspline.c \
clutter-behaviour-ellipse.c \
clutter-behaviour-opacity.c \ clutter-behaviour-opacity.c \
clutter-behaviour-path.c \ clutter-behaviour-path.c \
clutter-behaviour-rotate.c \ clutter-behaviour-rotate.c \

View File

@ -79,7 +79,6 @@ enum
PROP_HEIGHT, PROP_HEIGHT,
PROP_ANGLE_BEGIN, PROP_ANGLE_BEGIN,
PROP_ANGLE_END, PROP_ANGLE_END,
PROP_DIRECTION,
}; };
struct _ClutterBehaviourEllipsePrivate struct _ClutterBehaviourEllipsePrivate
@ -92,7 +91,6 @@ struct _ClutterBehaviourEllipsePrivate
gint b; gint b;
ClutterAngle angle_begin; ClutterAngle angle_begin;
ClutterAngle angle_end; ClutterAngle angle_end;
ClutterRotateDirection direction;
}; };
static void static void
@ -109,8 +107,8 @@ clutter_behaviour_ellipse_advance (ClutterBehaviourEllipse * e,
knot->x = CFX_INT (e->priv->a * clutter_cosi (angle)); knot->x = CFX_INT (e->priv->a * clutter_cosi (angle));
knot->y = CFX_INT (e->priv->b * clutter_sini (angle)); knot->y = CFX_INT (e->priv->b * clutter_sini (angle));
/* g_debug ("advancing to angle %d [%d, %d] (a: %d, b: %d)", */ g_debug ("advancing to angle %d [%d, %d] (a: %d, b: %d)",
/* angle, knot->x, knot->y, e->priv->a, e->priv->b); */ angle, knot->x, knot->y, e->priv->a, e->priv->b);
} }
@ -131,16 +129,17 @@ clutter_behaviour_ellipse_alpha_notify (ClutterBehaviour * behave,
ClutterBehaviourEllipse * self = CLUTTER_BEHAVIOUR_ELLIPSE (behave); ClutterBehaviourEllipse * self = CLUTTER_BEHAVIOUR_ELLIPSE (behave);
ClutterAngle angle; ClutterAngle angle;
if (self->priv->direction == CLUTTER_ROTATE_CW) if (self->priv->angle_end >= self->priv->angle_begin)
{ {
angle = self->priv->angle_end - self->priv->angle_begin; angle = self->priv->angle_end - self->priv->angle_begin;
angle = (angle * alpha) / CLUTTER_ALPHA_MAX_ALPHA + angle =
self->priv->angle_begin; (angle * alpha) / CLUTTER_ALPHA_MAX_ALPHA + self->priv->angle_begin;
} }
else else
{ {
angle = 1024 - (self->priv->angle_end - self->priv->angle_begin); angle = self->priv->angle_begin - self->priv->angle_end;
angle = self->priv->angle_begin - (angle * alpha) / CLUTTER_ALPHA_MAX_ALPHA; angle =
self->priv->angle_begin - (angle * alpha) / CLUTTER_ALPHA_MAX_ALPHA;
} }
clutter_behaviour_ellipse_advance (self, angle, &knot); clutter_behaviour_ellipse_advance (self, angle, &knot);
@ -175,13 +174,10 @@ clutter_behaviour_ellipse_set_property (GObject *gobject,
priv->angle_end = g_value_get_int (value); priv->angle_end = g_value_get_int (value);
break; break;
case PROP_WIDTH: case PROP_WIDTH:
priv->a = g_value_get_int (value) / 2; priv->a = g_value_get_int (value) >> 1;
break; break;
case PROP_HEIGHT: case PROP_HEIGHT:
priv->b = g_value_get_int (value) / 2; priv->b = g_value_get_int (value) >> 1;
break;
case PROP_DIRECTION:
priv->direction = g_value_get_enum (value);
break; break;
case PROP_CENTER: case PROP_CENTER:
clutter_behaviour_ellipse_set_center (el, g_value_get_boxed (value)); clutter_behaviour_ellipse_set_center (el, g_value_get_boxed (value));
@ -216,9 +212,6 @@ clutter_behaviour_ellipse_get_property (GObject *gobject,
case PROP_HEIGHT: case PROP_HEIGHT:
g_value_set_int (value, 2 * priv->b); g_value_set_int (value, 2 * priv->b);
break; break;
case PROP_DIRECTION:
g_value_set_enum (value, priv->direction);
break;
case PROP_CENTER: case PROP_CENTER:
g_value_set_boxed (value, &priv->center); g_value_set_boxed (value, &priv->center);
break; break;
@ -243,7 +236,7 @@ clutter_behaviour_ellipse_class_init (ClutterBehaviourEllipseClass *klass)
/** /**
* ClutterBehaviourEllipse:angle-begin: * ClutterBehaviourEllipse:angle-begin:
* *
* The initial angle from whence the rotation should begin. * The initial angle from where the rotation should begin.
* *
* Since: 0.4 * Since: 0.4
*/ */
@ -310,30 +303,15 @@ clutter_behaviour_ellipse_class_init (ClutterBehaviourEllipseClass *klass)
"Center of ellipse", "Center of ellipse",
CLUTTER_TYPE_KNOT, CLUTTER_TYPE_KNOT,
CLUTTER_PARAM_READWRITE)); CLUTTER_PARAM_READWRITE));
/**
* ClutterBehaviourEllipse:direction:
*
* The direction of the rotation.
*
* Since: 0.4
*/
g_object_class_install_property (object_class,
PROP_DIRECTION,
g_param_spec_enum ("direction",
"Direction",
"Direction of rotation",
CLUTTER_TYPE_ROTATE_DIRECTION,
CLUTTER_ROTATE_CW,
CLUTTER_PARAM_READWRITE));
/** /**
* ClutterBehaviourEllipse::knot-reached: * ClutterBehaviourEllipse::knot-reached:
* @pathb: the object which received the signal * @ellipse: the object which received the signal
* @knot: the #ClutterKnot reached * @knot: the #ClutterKnot reached
* *
* This signal is emitted at the end of each frame. * This signal is emitted at the end of each frame.
* *
* Since: 0.2 * Since: 0.4
*/ */
ellipse_signals[KNOT_REACHED] = ellipse_signals[KNOT_REACHED] =
g_signal_new ("knot-reached", g_signal_new ("knot-reached",
@ -359,11 +337,16 @@ clutter_behaviour_ellipse_init (ClutterBehaviourEllipse * self)
/** /**
* clutter_behaviour_ellipse_new: * clutter_behaviour_ellipse_new:
* @alpha: a #ClutterAlpha, or %NULL * @alpha: a #ClutterAlpha, or %NULL
* @center: center of the ellipse * @center: center of the ellipse as #ClutterKnot
* @width: width of the ellipse * @width: width of the ellipse
* @height: heigh of the ellipse * @height: height of the ellipse
* @begin: #ClutterAngle at which movement begins
* @end: #ClutterAngle at which movement ends
* *
* Creates a behaviour that drives actors along the elliptical path. * Creates a behaviour that drives actors along an elliptical path with
* given center, width and height; the movement begins at angle_begin and
* ends at angle_end; if angle_end > angle_begin, the movement is in
* counter-clockwise direction, clockwise other wise.
* *
* Return value: a #ClutterBehaviour * Return value: a #ClutterBehaviour
* *
@ -375,8 +358,7 @@ clutter_behaviour_ellipse_new (ClutterAlpha * alpha,
gint width, gint width,
gint height, gint height,
ClutterAngle begin, ClutterAngle begin,
ClutterAngle end, ClutterAngle end)
ClutterRotateDirection dir)
{ {
ClutterBehaviourEllipse *bc; ClutterBehaviourEllipse *bc;
@ -389,7 +371,6 @@ clutter_behaviour_ellipse_new (ClutterAlpha * alpha,
"height", height, "height", height,
"angle-begin", begin, "angle-begin", begin,
"angle-end", end, "angle-end", end,
"direction", dir,
NULL); NULL);
return CLUTTER_BEHAVIOUR (bc); return CLUTTER_BEHAVIOUR (bc);
@ -398,9 +379,9 @@ clutter_behaviour_ellipse_new (ClutterAlpha * alpha,
/** /**
* clutter_behaviour_ellipse_set_center * clutter_behaviour_ellipse_set_center
* @self: a #ClutterBehaviourEllipse * @self: a #ClutterBehaviourEllipse
* @knot: a #ClutterKnot center for the bezier * @knot: a #ClutterKnot center for the ellipse
* *
* Sets the center of the ellipse path to the point represented by knot. * Sets the center of the elliptical path to the point represented by knot.
* *
* Since: 0.4 * Since: 0.4
*/ */
@ -408,7 +389,13 @@ void
clutter_behaviour_ellipse_set_center (ClutterBehaviourEllipse * self, clutter_behaviour_ellipse_set_center (ClutterBehaviourEllipse * self,
ClutterKnot * knot) ClutterKnot * knot)
{ {
if (self->priv->center.x != knot->x || self->priv->center.y != knot->y)
{
g_object_ref (self);
self->priv->center = *knot; self->priv->center = *knot;
g_object_notify (G_OBJECT (self), "center");
g_object_unref (self);
}
} }
/** /**
@ -416,7 +403,7 @@ clutter_behaviour_ellipse_set_center (ClutterBehaviourEllipse * self,
* @self: a #ClutterBehaviourEllipse * @self: a #ClutterBehaviourEllipse
* @knot: a #ClutterKnot where to store the center of the ellipse * @knot: a #ClutterKnot where to store the center of the ellipse
* *
* Gets the center of the ellipse path. * Gets the center of the elliptical path path.
* *
* Since: 0.4 * Since: 0.4
*/ */
@ -427,3 +414,150 @@ clutter_behaviour_ellipse_get_center (ClutterBehaviourEllipse * self,
*knot = self->priv->center; *knot = self->priv->center;
} }
/**
* clutter_behaviour_ellipse_set_width
* @self: a #ClutterBehaviourEllipse
* @width: width of the ellipse
*
* Sets the width of the elliptical path.
*
* Since: 0.4
*/
void
clutter_behaviour_ellipse_set_width (ClutterBehaviourEllipse * self,
gint width)
{
if (self->priv->a != width >> 1)
{
g_object_ref (self);
self->priv->a = width >> 1;
g_object_notify (G_OBJECT (self), "width");
g_object_unref (self);
}
}
/**
* clutter_behaviour_ellipse_get_width
* @self: a #ClutterBehaviourEllipse
*
* Gets the width of the elliptical path.
*
* Since: 0.4
*/
gint
clutter_behaviour_ellipse_get_width (ClutterBehaviourEllipse * self)
{
return self->priv->a << 1;
}
/**
* clutter_behaviour_ellipse_set_height
* @self: a #ClutterBehaviourEllipse
* @height: height of the ellipse
*
* Sets the height of the elliptical path.
*
* Since: 0.4
*/
void
clutter_behaviour_ellipse_set_height (ClutterBehaviourEllipse * self,
gint height)
{
if (self->priv->b != height >> 1)
{
g_object_ref (self);
self->priv->b = height >> 1;
g_object_notify (G_OBJECT (self), "height");
g_object_unref (self);
}
}
/**
* clutter_behaviour_ellipse_get_height
* @self: a #ClutterBehaviourEllipse
*
* Gets the height of the elliptical path.
*
* Since: 0.4
*/
gint
clutter_behaviour_ellipse_get_height (ClutterBehaviourEllipse * self)
{
return self->priv->b << 1;
}
/**
* clutter_behaviour_ellipse_set_angle_begin
* @self: a #ClutterBehaviourEllipse
* @angle_begin: #ClutterAngle at which movement begins
*
* Sets the angle at which movement begins.
*
* Since: 0.4
*/
void
clutter_behaviour_ellipse_set_angle_begin (ClutterBehaviourEllipse * self,
ClutterAngle angle_begin)
{
if (self->priv->angle_begin != angle_begin)
{
g_object_ref (self);
self->priv->angle_begin = angle_begin;
g_object_notify (G_OBJECT (self), "angle-begin");
g_object_unref (self);
}
}
/**
* clutter_behaviour_ellipse_get_angle_begin
* @self: a #ClutterBehaviourEllipse
*
* Gets the at which movements begins.
*
* Since: 0.4
*/
ClutterAngle
clutter_behaviour_ellipse_get_angle_begin (ClutterBehaviourEllipse * self)
{
return self->priv->angle_begin;
}
/**
* clutter_behaviour_ellipse_set_angle_end
* @self: a #ClutterBehaviourEllipse
* @angle_end: #ClutterAngle at which movement ends
*
* Sets the angle at which movement ends.
*
* Since: 0.4
*/
void
clutter_behaviour_ellipse_set_angle_end (ClutterBehaviourEllipse * self,
ClutterAngle angle_end)
{
if (self->priv->angle_end != angle_end)
{
g_object_ref (self);
self->priv->angle_end = angle_end;
g_object_notify (G_OBJECT (self), "angle-end");
g_object_unref (self);
}
}
/**
* clutter_behaviour_ellipse_get_angle_end
* @self: a #ClutterBehaviourEllipse
*
* Gets the at which movements ends.
*
* Since: 0.4
*/
ClutterAngle
clutter_behaviour_ellipse_get_angle_end (ClutterBehaviourEllipse * self)
{
return self->priv->angle_end;
}

View File

@ -5,7 +5,7 @@
* *
* Authored By Tomas Frydrych <tf@openedhand.com> * Authored By Tomas Frydrych <tf@openedhand.com>
* *
* Copyright (C) 2006, 2007 OpenedHand * Copyright (C) 2007 OpenedHand
* *
* This library is free software; you can redistribute it and/or * This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public * modify it under the terms of the GNU Lesser General Public
@ -29,7 +29,6 @@
#include <clutter/clutter-alpha.h> #include <clutter/clutter-alpha.h>
#include <clutter/clutter-actor.h> #include <clutter/clutter-actor.h>
#include <clutter/clutter-behaviour.h> #include <clutter/clutter-behaviour.h>
#include <clutter/clutter-behaviour-rotate.h>
G_BEGIN_DECLS G_BEGIN_DECLS
@ -87,14 +86,33 @@ ClutterBehaviour *clutter_behaviour_ellipse_new (ClutterAlpha
gint width, gint width,
gint height, gint height,
ClutterAngle start, ClutterAngle start,
ClutterAngle end, ClutterAngle end);
ClutterRotateDirection dir);
void clutter_behaviour_ellipse_set_center (ClutterBehaviourEllipse * self, void clutter_behaviour_ellipse_set_center (ClutterBehaviourEllipse * self,
ClutterKnot * knot); ClutterKnot * knot);
void clutter_behaviour_ellipse_get_center (ClutterBehaviourEllipse * bs, void clutter_behaviour_ellipse_get_center (ClutterBehaviourEllipse * bs,
ClutterKnot * knot); ClutterKnot * knot);
void clutter_behaviour_ellipse_set_width (ClutterBehaviourEllipse * self,
gint width);
gint clutter_behaviour_ellipse_get_width (ClutterBehaviourEllipse * self);
void clutter_behaviour_ellipse_set_height (ClutterBehaviourEllipse * self,
gint height);
gint clutter_behaviour_ellipse_get_height (ClutterBehaviourEllipse * self);
void clutter_behaviour_ellipse_set_angle_begin (ClutterBehaviourEllipse * self,
ClutterAngle angle_begin);
ClutterAngle clutter_behaviour_ellipse_get_angle_begin (ClutterBehaviourEllipse * self);
void clutter_behaviour_ellipse_set_angle_end (ClutterBehaviourEllipse * self,
ClutterAngle angle_end);
ClutterAngle clutter_behaviour_ellipse_get_angle_end (ClutterBehaviourEllipse * self);
G_END_DECLS G_END_DECLS
#endif /* __CLUTTER_BEHAVIOUR_ELLIPSE_H__ */ #endif /* __CLUTTER_BEHAVIOUR_ELLIPSE_H__ */

View File

@ -34,6 +34,7 @@
#include "clutter-timeline.h" #include "clutter-timeline.h"
#include "clutter-behaviour.h" #include "clutter-behaviour.h"
#include "clutter-behaviour-bspline.h" #include "clutter-behaviour-bspline.h"
#include "clutter-behaviour-ellipse.h"
#include "clutter-behaviour-opacity.h" #include "clutter-behaviour-opacity.h"
#include "clutter-behaviour-path.h" #include "clutter-behaviour-path.h"
#include "clutter-behaviour-rotate.h" #include "clutter-behaviour-rotate.h"

View File

@ -80,6 +80,7 @@
<xi:include href="xml/clutter-alpha.xml"/> <xi:include href="xml/clutter-alpha.xml"/>
<xi:include href="xml/clutter-behaviour.xml"/> <xi:include href="xml/clutter-behaviour.xml"/>
<xi:include href="xml/clutter-behaviour-bspline.xml"/> <xi:include href="xml/clutter-behaviour-bspline.xml"/>
<xi:include href="xml/clutter-behaviour-ellipse.xml"/>
<xi:include href="xml/clutter-behaviour-opacity.xml"/> <xi:include href="xml/clutter-behaviour-opacity.xml"/>
<xi:include href="xml/clutter-behaviour-path.xml"/> <xi:include href="xml/clutter-behaviour-path.xml"/>
<xi:include href="xml/clutter-behaviour-rotate.xml"/> <xi:include href="xml/clutter-behaviour-rotate.xml"/>

View File

@ -497,6 +497,26 @@ ClutterBehaviourBsplinePrivate
clutter_behaviour_bspline_get_type clutter_behaviour_bspline_get_type
</SECTION> </SECTION>
<SECTION>
<FILE>clutter-behaviour-ellipse</FILE>
<TITLE>ClutterBehaviourEllipse</TITLE>
ClutterBehaviourEllipse
ClutterBehaviourEllipseClass
clutter_behaviour_ellipse_new
clutter_behaviour_ellipse_set_center
clutter_behaviour_ellipse_get_center
<SUBSECTION Standard>
CLUTTER_BEHAVIOUR_ELLIPSE
CLUTTER_BEHAVIOUR_ELLIPSE_CLASS
CLUTTER_IS_BEHAVIOUR_ELLIPSE
CLUTTER_IS_BEHAVIOUR_ELLIPSE_CLASS
CLUTTER_BEHAVIOUR_ELLIPSE_GET_CLASS
<SUBSECTION Private>
ClutterBehaviourEllipsePrivate
clutter_behaviour_ellipse_get_type
</SECTION>
<SECTION> <SECTION>
<FILE>clutter-backend</FILE> <FILE>clutter-backend</FILE>
<TITLE>ClutterBackend</TITLE> <TITLE>ClutterBackend</TITLE>

View File

@ -12,6 +12,7 @@ clutter_media_get_type
clutter_behaviour_get_type clutter_behaviour_get_type
clutter_alpha_get_type clutter_alpha_get_type
clutter_behaviour_bspline_get_type clutter_behaviour_bspline_get_type
clutter_behaviour_ellipse_get_type
clutter_behaviour_opacity_get_type clutter_behaviour_opacity_get_type
clutter_behaviour_path_get_type clutter_behaviour_path_get_type
clutter_behaviour_rotate_get_type clutter_behaviour_rotate_get_type

View File

@ -23,21 +23,6 @@ clutter-media
</para> </para>
<!-- ##### SIGNAL ClutterMedia::eos ##### -->
<para>
</para>
@cluttermedia: the object which received the signal.
<!-- ##### SIGNAL ClutterMedia::error ##### -->
<para>
</para>
@cluttermedia: the object which received the signal.
@arg1:
<!-- ##### ARG ClutterMedia:buffer-percent ##### --> <!-- ##### ARG ClutterMedia:buffer-percent ##### -->
<para> <para>