2009-01-08 13:18:00 +00:00
|
|
|
/*
|
|
|
|
* Clutter.
|
|
|
|
*
|
|
|
|
* An OpenGL based 'interactive canvas' library.
|
|
|
|
*
|
|
|
|
* Copyright (C) 2009 Intel Corporation.
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
* Author:
|
|
|
|
* Emmanuele Bassi <ebassi@linux.intel.com>
|
|
|
|
*/
|
|
|
|
|
2009-01-08 12:56:46 +00:00
|
|
|
/**
|
|
|
|
* SECTION:clutter-animatable
|
|
|
|
* @short_description: Interface for animatable classes
|
|
|
|
*
|
|
|
|
* #ClutterAnimatable is an interface that allows a #GObject class
|
|
|
|
* to control how a #ClutterAnimation will animate a property.
|
|
|
|
*
|
2011-09-12 13:12:14 +01:00
|
|
|
* Each #ClutterAnimatable should implement the
|
2012-04-19 16:00:23 +01:00
|
|
|
* #ClutterAnimatableIface.interpolate_property() virtual function of the
|
|
|
|
* interface to compute the animation state between two values of an interval
|
|
|
|
* depending on a progress factor, expressed as a floating point value.
|
2009-01-08 12:56:46 +00:00
|
|
|
*
|
|
|
|
* If a #ClutterAnimatable is animated by a #ClutterAnimation
|
|
|
|
* instance, the #ClutterAnimation will call
|
2012-04-19 16:00:23 +01:00
|
|
|
* clutter_animatable_interpolate_property() passing the name of the
|
|
|
|
* currently animated property; the values interval; and the progress factor.
|
|
|
|
* The #ClutterAnimatable implementation should return the computed value for
|
|
|
|
* the animated
|
2009-01-08 12:56:46 +00:00
|
|
|
* property.
|
|
|
|
*
|
|
|
|
* #ClutterAnimatable is available since Clutter 1.0
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
#include "config.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "clutter-animatable.h"
|
2012-02-27 15:29:50 +00:00
|
|
|
#include "clutter-interval.h"
|
2009-01-08 12:56:46 +00:00
|
|
|
#include "clutter-debug.h"
|
|
|
|
#include "clutter-private.h"
|
|
|
|
|
2010-10-08 14:47:46 +01:00
|
|
|
typedef ClutterAnimatableIface ClutterAnimatableInterface;
|
|
|
|
G_DEFINE_INTERFACE (ClutterAnimatable, clutter_animatable, G_TYPE_OBJECT);
|
2009-01-08 12:56:46 +00:00
|
|
|
|
2010-10-08 14:47:46 +01:00
|
|
|
static void
|
|
|
|
clutter_animatable_default_init (ClutterAnimatableInterface *iface)
|
|
|
|
{
|
2009-01-08 12:56:46 +00:00
|
|
|
}
|
|
|
|
|
2010-05-19 16:10:05 +01:00
|
|
|
/**
|
|
|
|
* clutter_animatable_find_property:
|
|
|
|
* @animatable: a #ClutterAnimatable
|
|
|
|
* @property_name: the name of the animatable property to find
|
|
|
|
*
|
|
|
|
* Finds the #GParamSpec for @property_name
|
|
|
|
*
|
|
|
|
* Return value: (transfer none): The #GParamSpec for the given property
|
|
|
|
* or %NULL
|
|
|
|
*
|
2012-08-27 09:48:36 +01:00
|
|
|
*
|
2010-05-19 16:10:05 +01:00
|
|
|
*/
|
2010-05-19 12:21:54 +01:00
|
|
|
GParamSpec *
|
|
|
|
clutter_animatable_find_property (ClutterAnimatable *animatable,
|
|
|
|
const gchar *property_name)
|
|
|
|
{
|
|
|
|
ClutterAnimatableIface *iface;
|
|
|
|
|
|
|
|
g_return_val_if_fail (CLUTTER_IS_ANIMATABLE (animatable), NULL);
|
|
|
|
g_return_val_if_fail (property_name != NULL, NULL);
|
|
|
|
|
|
|
|
CLUTTER_NOTE (ANIMATION, "Looking for property '%s'", property_name);
|
|
|
|
|
|
|
|
iface = CLUTTER_ANIMATABLE_GET_IFACE (animatable);
|
|
|
|
if (iface->find_property != NULL)
|
2010-07-31 10:40:21 +01:00
|
|
|
return iface->find_property (animatable, property_name);
|
2010-05-19 12:21:54 +01:00
|
|
|
|
|
|
|
return g_object_class_find_property (G_OBJECT_GET_CLASS (animatable),
|
|
|
|
property_name);
|
|
|
|
}
|
|
|
|
|
2010-05-19 16:10:05 +01:00
|
|
|
/**
|
|
|
|
* clutter_animatable_get_initial_state:
|
|
|
|
* @animatable: a #ClutterAnimatable
|
|
|
|
* @property_name: the name of the animatable property to retrieve
|
|
|
|
* @value: a #GValue initialized to the type of the property to retrieve
|
|
|
|
*
|
|
|
|
* Retrieves the current state of @property_name and sets @value with it
|
|
|
|
*
|
2012-08-27 09:48:36 +01:00
|
|
|
*
|
2010-05-19 16:10:05 +01:00
|
|
|
*/
|
2010-05-19 12:21:54 +01:00
|
|
|
void
|
|
|
|
clutter_animatable_get_initial_state (ClutterAnimatable *animatable,
|
|
|
|
const gchar *property_name,
|
|
|
|
GValue *value)
|
|
|
|
{
|
|
|
|
ClutterAnimatableIface *iface;
|
|
|
|
|
|
|
|
g_return_if_fail (CLUTTER_IS_ANIMATABLE (animatable));
|
|
|
|
g_return_if_fail (property_name != NULL);
|
|
|
|
|
|
|
|
CLUTTER_NOTE (ANIMATION, "Getting initial state of '%s'", property_name);
|
|
|
|
|
|
|
|
iface = CLUTTER_ANIMATABLE_GET_IFACE (animatable);
|
|
|
|
if (iface->get_initial_state != NULL)
|
2010-07-31 10:40:21 +01:00
|
|
|
iface->get_initial_state (animatable, property_name, value);
|
2010-05-19 12:21:54 +01:00
|
|
|
else
|
|
|
|
g_object_get_property (G_OBJECT (animatable), property_name, value);
|
|
|
|
}
|
|
|
|
|
2010-05-19 16:10:05 +01:00
|
|
|
/**
|
|
|
|
* clutter_animatable_set_final_state:
|
|
|
|
* @animatable: a #ClutterAnimatable
|
|
|
|
* @property_name: the name of the animatable property to set
|
|
|
|
* @value: the value of the animatable property to set
|
|
|
|
*
|
|
|
|
* Sets the current state of @property_name to @value
|
|
|
|
*
|
2012-08-27 09:48:36 +01:00
|
|
|
*
|
2010-05-19 16:10:05 +01:00
|
|
|
*/
|
2010-05-19 12:21:54 +01:00
|
|
|
void
|
|
|
|
clutter_animatable_set_final_state (ClutterAnimatable *animatable,
|
|
|
|
const gchar *property_name,
|
|
|
|
const GValue *value)
|
|
|
|
{
|
|
|
|
ClutterAnimatableIface *iface;
|
|
|
|
|
|
|
|
g_return_if_fail (CLUTTER_IS_ANIMATABLE (animatable));
|
|
|
|
g_return_if_fail (property_name != NULL);
|
|
|
|
|
|
|
|
CLUTTER_NOTE (ANIMATION, "Setting state of property '%s'", property_name);
|
|
|
|
|
|
|
|
iface = CLUTTER_ANIMATABLE_GET_IFACE (animatable);
|
|
|
|
if (iface->set_final_state != NULL)
|
2010-07-31 10:40:21 +01:00
|
|
|
iface->set_final_state (animatable, property_name, value);
|
2010-05-19 12:21:54 +01:00
|
|
|
else
|
|
|
|
g_object_set_property (G_OBJECT (animatable), property_name, value);
|
|
|
|
}
|
2011-07-15 14:27:26 +01:00
|
|
|
|
2011-07-29 11:48:13 +01:00
|
|
|
/**
|
|
|
|
* clutter_animatable_interpolate_value:
|
|
|
|
* @animatable: a #ClutterAnimatable
|
|
|
|
* @property_name: the name of the property to interpolate
|
|
|
|
* @interval: a #ClutterInterval with the animation range
|
|
|
|
* @progress: the progress to use to interpolate between the
|
|
|
|
* initial and final values of the @interval
|
|
|
|
* @value: (out): return location for an initialized #GValue
|
|
|
|
* using the same type of the @interval
|
|
|
|
*
|
|
|
|
* Asks a #ClutterAnimatable implementation to interpolate a
|
|
|
|
* a named property between the initial and final values of
|
|
|
|
* a #ClutterInterval, using @progress as the interpolation
|
|
|
|
* value, and store the result inside @value.
|
|
|
|
*
|
|
|
|
* This function should be used for every property animation
|
|
|
|
* involving #ClutterAnimatable<!-- -->s.
|
|
|
|
*
|
|
|
|
* Return value: %TRUE if the interpolation was successful,
|
|
|
|
* and %FALSE otherwise
|
|
|
|
*
|
2012-08-27 09:48:36 +01:00
|
|
|
*
|
2011-07-29 11:48:13 +01:00
|
|
|
*/
|
2011-07-15 14:27:26 +01:00
|
|
|
gboolean
|
|
|
|
clutter_animatable_interpolate_value (ClutterAnimatable *animatable,
|
|
|
|
const gchar *property_name,
|
|
|
|
ClutterInterval *interval,
|
|
|
|
gdouble progress,
|
|
|
|
GValue *value)
|
|
|
|
{
|
|
|
|
ClutterAnimatableIface *iface;
|
|
|
|
|
|
|
|
g_return_val_if_fail (CLUTTER_IS_ANIMATABLE (animatable), FALSE);
|
|
|
|
g_return_val_if_fail (property_name != NULL, FALSE);
|
|
|
|
g_return_val_if_fail (CLUTTER_IS_INTERVAL (interval), FALSE);
|
|
|
|
g_return_val_if_fail (value != NULL, FALSE);
|
|
|
|
|
|
|
|
CLUTTER_NOTE (ANIMATION, "Interpolating '%s' (progress: %.3f)",
|
|
|
|
property_name,
|
|
|
|
progress);
|
|
|
|
|
|
|
|
iface = CLUTTER_ANIMATABLE_GET_IFACE (animatable);
|
|
|
|
if (iface->interpolate_value != NULL)
|
|
|
|
{
|
|
|
|
return iface->interpolate_value (animatable, property_name,
|
|
|
|
interval,
|
|
|
|
progress,
|
|
|
|
value);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
return clutter_interval_compute_value (interval, progress, value);
|
|
|
|
}
|