2007-07-25 13:08:12 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include <glib.h>
|
2008-11-07 19:32:28 +00:00
|
|
|
#include <gmodule.h>
|
2007-07-25 13:08:12 +00:00
|
|
|
|
|
|
|
#include <clutter/clutter.h>
|
|
|
|
|
2008-11-07 19:32:28 +00:00
|
|
|
G_MODULE_EXPORT int
|
|
|
|
test_rotate_main (int argc, char *argv[])
|
2007-07-25 13:08:12 +00:00
|
|
|
{
|
|
|
|
ClutterTimeline *timeline;
|
|
|
|
ClutterAlpha *alpha;
|
|
|
|
ClutterBehaviour *r_behave;
|
|
|
|
ClutterActor *stage;
|
|
|
|
ClutterActor *hand, *label;
|
|
|
|
ClutterColor stage_color = { 0xcc, 0xcc, 0xcc, 0xff };
|
2009-11-05 17:30:33 +00:00
|
|
|
gchar *file;
|
2007-07-25 13:08:12 +00:00
|
|
|
|
|
|
|
clutter_init (&argc, &argv);
|
|
|
|
|
|
|
|
stage = clutter_stage_get_default ();
|
|
|
|
|
|
|
|
clutter_stage_set_color (CLUTTER_STAGE (stage),
|
|
|
|
&stage_color);
|
|
|
|
|
|
|
|
/* Make a hand */
|
2009-11-05 17:30:33 +00:00
|
|
|
file = g_build_filename (TESTS_DATADIR, "redhand.png", NULL);
|
|
|
|
hand = clutter_texture_new_from_file (file, NULL);
|
2008-04-25 13:37:36 +00:00
|
|
|
if (!hand)
|
2009-11-05 17:30:33 +00:00
|
|
|
g_error("Unable to load '%s'", file);
|
|
|
|
|
|
|
|
g_free (file);
|
2008-04-25 13:37:36 +00:00
|
|
|
|
2007-07-25 13:08:12 +00:00
|
|
|
clutter_actor_set_position (hand, 240, 140);
|
|
|
|
clutter_actor_show (hand);
|
|
|
|
clutter_container_add_actor (CLUTTER_CONTAINER (stage), hand);
|
|
|
|
|
2009-02-02 23:55:30 +00:00
|
|
|
label = clutter_text_new_with_text ("Mono 16",
|
|
|
|
"The Wonder\n"
|
|
|
|
"of the\n"
|
|
|
|
"Spinning Hand");
|
|
|
|
clutter_text_set_line_alignment (CLUTTER_TEXT (label), PANGO_ALIGN_CENTER);
|
2007-07-25 13:08:12 +00:00
|
|
|
clutter_actor_set_position (label, 150, 150);
|
2008-01-17 14:31:14 +00:00
|
|
|
clutter_actor_set_size (label, 500, 100);
|
2007-07-25 13:08:12 +00:00
|
|
|
clutter_actor_show (label);
|
|
|
|
clutter_container_add_actor (CLUTTER_CONTAINER (stage), label);
|
|
|
|
|
|
|
|
/* Make a timeline */
|
2009-06-04 13:05:12 +01:00
|
|
|
timeline = clutter_timeline_new (7692); /* num frames, fps */
|
2009-05-31 15:15:46 +01:00
|
|
|
clutter_timeline_set_loop (timeline, TRUE);
|
2007-07-25 13:08:12 +00:00
|
|
|
|
2008-11-17 Emmanuele Bassi <ebassi@linux.intel.com>
Bug 1014 - Clutter Animation API Improvements
* clutter/Makefile.am:
* clutter/clutter.h: Update the build
* clutter/clutter-types.h: Add AnimationMode, an enumeration
for easing functions.
* clutter/clutter-alpha.[ch]: Add the :mode property to
control the function bound to an Alpha instance using an
enumeration value. Also add six new alpha functions:
- ease-in, ease-out, ease-in-out
- sine-in, sine-out, sine-in-out
* clutter/clutter-deprecated.h: Deprecate the #defines for
the alpha functions. They will be replaced by entries in the
ClutterAnimationMode.
* clutter/clutter-interval.[ch]: Add ClutterInterval, an
object for defining, validating and computing an interval
between two values.
* clutter/clutter-animation.[ch]: Add ClutterAnimation, an
object responsible for animation the properties of a single
actor along an interval of values. ClutterAnimation memory
management is automatic. A simple wrapper method for
ClutterActor is provided:
clutter_actor_animate()
which will create, or update, an animation for the passed
actor.
* clutter/clutter-debug.h:
* clutter/clutter-main.c: Add a new 'animation' debug note.
* clutter/clutter-script.c: Clean up the alpha functions
whitelist, and add the new functions.
* doc/reference/clutter/Makefile.am:
* doc/reference/clutter/clutter-sections.txt: Update the
API reference.
* doc/reference/clutter/clutter-animation.xml: Renamed to
doc/reference/clutter/clutter-animation-tutorial.xml to
avoid clashes with the ClutterAnimation section.
* doc/reference/clutter/clutter-docs.sgml: Renamed to
doc/reference/clutter/clutter-docs.xml, as it was an XML
file and not a SGML file.
* tests/Makefile.am:
* tests/interactive/Makefile.am:
* tests/interactive/test-animation.c:
* tests/interactive/test-easing.c: Add two tests for the
new simple animation API and the easing functions.
* tests/interactive/test-actors.c:
* tests/interactive/test-behave.c:
* tests/interactive/test-depth.c:
* tests/interactive/test-effects.c:
* tests/interactive/test-layout.c:
* tests/interactive/test-multistage.c:
* tests/interactive/test-paint-wrapper.c:
* tests/interactive/test-rotate.c:
* tests/interactive/test-scale.c:
* tests/interactive/test-texture-quality.c:
* tests/interactive/test-threads.c:
* tests/interactive/test-viewport.c: Update interactive tests
to the deprecations and new alpha API.
2008-11-18 09:50:03 +00:00
|
|
|
/* Set an alpha func to power behaviour */
|
2009-01-16 13:42:06 +00:00
|
|
|
alpha = clutter_alpha_new_full (timeline, CLUTTER_LINEAR);
|
2007-07-25 13:08:12 +00:00
|
|
|
|
|
|
|
/* Create a behaviour for that alpha */
|
|
|
|
r_behave = clutter_behaviour_rotate_new (alpha,
|
|
|
|
CLUTTER_Z_AXIS,
|
|
|
|
CLUTTER_ROTATE_CW,
|
|
|
|
0.0, 360.0);
|
|
|
|
|
2007-07-26 11:04:04 +00:00
|
|
|
clutter_behaviour_rotate_set_center (CLUTTER_BEHAVIOUR_ROTATE (r_behave),
|
|
|
|
86, 125, 0);
|
2007-07-25 13:08:12 +00:00
|
|
|
|
|
|
|
/* Apply it to our actor */
|
|
|
|
clutter_behaviour_apply (r_behave, hand);
|
|
|
|
clutter_behaviour_apply (r_behave, label);
|
|
|
|
|
|
|
|
/* start the timeline and thus the animations */
|
|
|
|
clutter_timeline_start (timeline);
|
|
|
|
|
|
|
|
clutter_actor_show_all (stage);
|
|
|
|
|
|
|
|
clutter_main();
|
|
|
|
|
|
|
|
g_object_unref (r_behave);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|