[clutter/wip/apocalypses/apocalypse-6: 9/17] interactive/actor: Do not use clutter_actor_animate()
- From: Emmanuele Bassi <ebassi src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [clutter/wip/apocalypses/apocalypse-6: 9/17] interactive/actor: Do not use clutter_actor_animate()
- Date: Thu, 15 Mar 2012 17:02:51 +0000 (UTC)
commit 389ee457472ed9e32bb78fed3ae9b2b5c2dc4585
Author: Emmanuele Bassi <ebassi linux intel com>
Date: Thu Mar 15 11:25:26 2012 +0000
interactive/actor: Do not use clutter_actor_animate()
Use implicit animations instead.
tests/interactive/test-actor.c | 59 ++++++++++++++++++++++-----------------
1 files changed, 33 insertions(+), 26 deletions(-)
---
diff --git a/tests/interactive/test-actor.c b/tests/interactive/test-actor.c
index a2e77b3..9801fc1 100644
--- a/tests/interactive/test-actor.c
+++ b/tests/interactive/test-actor.c
@@ -16,9 +16,11 @@ animate_color (ClutterActor *actor,
else
end_color = CLUTTER_COLOR_Red;
- clutter_actor_animate (actor, CLUTTER_LINEAR, 500,
- "background-color", end_color,
- NULL);
+ clutter_actor_save_easing_state (actor);
+ clutter_actor_set_easing_duration (actor, 500);
+ clutter_actor_set_easing_mode (actor, CLUTTER_LINEAR);
+ clutter_actor_set_background_color (actor, end_color);
+ clutter_actor_restore_easing_state (actor);
toggled = !toggled;
@@ -38,41 +40,46 @@ on_crossing (ClutterActor *actor,
else
depth = 0.0;
- clutter_actor_animate (actor, CLUTTER_EASE_OUT_BOUNCE, 500,
- "depth", depth,
- NULL);
+ clutter_actor_save_easing_state (actor);
+ clutter_actor_set_easing_duration (actor, 500);
+ clutter_actor_set_easing_mode (actor, CLUTTER_EASE_OUT_BOUNCE);
+ clutter_actor_set_depth (actor, depth);
+ clutter_actor_restore_easing_state (actor);
return CLUTTER_EVENT_STOP;
}
static void
-restore_actor (ClutterActor *actor)
+on_transition_complete (ClutterTransition *transition,
+ ClutterActor *actor)
{
- clutter_actor_set_rotation (actor, CLUTTER_Y_AXIS, 0.0,
- SIZE / 2.0,
- 0.f,
- 0.f);
- clutter_actor_set_reactive (actor, TRUE);
+ clutter_actor_save_easing_state (actor);
+ clutter_actor_set_easing_duration (actor, 250);
+
+ clutter_actor_set_rotation (actor, CLUTTER_Y_AXIS, 0.0f,
+ SIZE / 2.0f, 0.f, 0.f);
+
+ clutter_actor_restore_easing_state (actor);
}
static gboolean
animate_rotation (ClutterActor *actor,
ClutterEvent *event)
{
- ClutterVertex center;
-
- center.x = SIZE / 2.0;
- center.y = 0.f;
- center.z = 0.f;
-
- clutter_actor_animate (actor, CLUTTER_EASE_OUT_EXPO, 500,
- "fixed::reactive", FALSE,
- "fixed::rotation-center-y", ¢er,
- "rotation-angle-y", 360.0,
- "signal-swapped-after::completed",
- G_CALLBACK (restore_actor),
- actor,
- NULL);
+ ClutterTransition *transition;
+
+ clutter_actor_save_easing_state (actor);
+ clutter_actor_set_easing_duration (actor, 1000);
+
+ clutter_actor_set_rotation (actor, CLUTTER_Y_AXIS, 360.0,
+ SIZE / 2.0f, 0.f, 0.f);
+
+ transition = clutter_actor_get_transition (actor, "rotation-angle-y");
+ g_signal_connect (transition, "completed",
+ G_CALLBACK (on_transition_complete),
+ actor);
+
+ clutter_actor_restore_easing_state (actor);
return CLUTTER_EVENT_STOP;
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]