In this example we will figure out how to manipulate the animations on an Edje object.
After reading this document you will be able to manipulate the frametime, freeze, pause and stop, all animations on an Edje object.
To play with this example you will use the keyboard. Below are listed the keys and what each does.
- '+' Increase the frametime;
- '-' Decrease the frametime;
- '=' Prints the actual frametime and says if the animations is playing;
- 'f' Freezes the animations in the Edje object;
- 'F' Freezes the animations in all objects in the running program;
- 't' Thaws the animations in the Edje object;
- 'T' Thaws the animations in all objects in the running program;
- 's' Pauses the animations;
- 'p' Plays the animations previously stopped;
- 'a' Starts the animation in the Edje object;
- 'A' Stops the animations in the Edje object;
Now that we've explained how to use our example, we will see how it is made. Let's start by looking at the piece of code responsible to the actions commented above.
{
double ft;
if (!strcmp(ev->
key,
"h"))
{
printf(commands);
return;
}
else if (!strcmp(ev->
key,
"plus"))
{
frametime *= 2.0;
printf("Increasing frametime to: %f\n", frametime);
}
else if (!strcmp(ev->
key,
"minus"))
{
frametime /= 2.0;
printf("Decreasing frametime to: %f\n", frametime);
}
else if (!strcmp(ev->
key,
"equal"))
{
printf("Frametime: %f\n", ft);
printf("Object is playing\n");
else
printf("Object was paused\n");
printf("Animation is running\n");
else
printf("Animation was stopped\n");
}
else if (!strcmp(ev->
key,
"s"))
{
printf("Pausing the object\n");
}
else if (!strcmp(ev->
key,
"p"))
{
printf("Playing the object\n");
}
else if (!strcmp(ev->
key,
"f"))
else if (!strcmp(ev->
key,
"t"))
else if (!strcmp(ev->
key,
"F"))
{
printf("Freezing all objects\n");
}
else if (!strcmp(ev->
key,
"T"))
{
printf("Thawing all objects\n");
}
else if (!strcmp(ev->
key,
"a"))
{
printf("Starting the animation in the Edje object\n");
}
else if (!strcmp(ev->
key,
"A"))
{
printf("Stopping the animation in the Edje object\n");
}
else if (!strcmp(ev->
key,
"Escape"))
else
{
printf(
"unhandled key: %s\n", ev->
key);
printf(commands);
}
- Note
- The actions for the keys 'f' and 'F' will have the same effect in our example, just because there is only one object in the running program, The same happens with the keys 't' and 'T'.
As you may have seen these set of functions are pretty easy to handle. The other important part of this example is the EDC file. The animations used in the code were created there
program {
signal: "load";
source: "";
in: 2.0 0.0;
after: "animation,state1";
}
program {
name: "animation,state1";
in: 1.0 0.0;
action: STATE_SET "invert" 1.0;
target: "part_one";
target: "part_two";
target: "part_three";
transition: LINEAR 0.6;
after: "animation,state2";
}
program {
name: "animation,state2";
in: 1.0 0.0;
action: STATE_SET "default" 0.0;
target: "part_one";
target: "part_two";
target: "part_three";
transition: LINEAR 0.6;
after: "animation,state1";
}
}
The example's window should look like this picture:
The full example follows.
#ifdef HAVE_CONFIG_H
# include "config.h"
#else
# define EINA_UNUSED
#endif
#ifndef PACKAGE_DATA_DIR
#define PACKAGE_DATA_DIR "."
#endif
#include <Ecore.h>
#define WIDTH (400)
#define HEIGHT (300)
static const char commands[] = \
"commands are:\n"
"\t+ - increase frametime\n"
"\t- - decrease frametime\n"
"\t= - status of the animation\n"
"\ts - pause\n"
"\tp - play\n"
"\tf - freeze one object\n"
"\tF - freeze all objects\n"
"\tt - thaw one object\n"
"\tT - thaw all objects\n"
"\ta - start animation of one object\n"
"\tA - stop animation of one object\n"
"\tEsc - exit\n"
"\th - print help\n";
static double frametime = 1.0 / 30.0;
static void
{
}
static void
_on_canvas_resize(Ecore_Evas *ee)
{
int w;
int h;
}
static void
{
double ft;
if (!strcmp(ev->
key,
"h"))
{
printf(commands);
return;
}
else if (!strcmp(ev->
key,
"plus"))
{
frametime *= 2.0;
printf("Increasing frametime to: %f\n", frametime);
}
else if (!strcmp(ev->
key,
"minus"))
{
frametime /= 2.0;
printf("Decreasing frametime to: %f\n", frametime);
}
else if (!strcmp(ev->
key,
"equal"))
{
printf("Frametime: %f\n", ft);
printf("Object is playing\n");
else
printf("Object was paused\n");
printf("Animation is running\n");
else
printf("Animation was stopped\n");
}
else if (!strcmp(ev->
key,
"s"))
{
printf("Pausing the object\n");
}
else if (!strcmp(ev->
key,
"p"))
{
printf("Playing the object\n");
}
else if (!strcmp(ev->
key,
"f"))
else if (!strcmp(ev->
key,
"t"))
else if (!strcmp(ev->
key,
"F"))
{
printf("Freezing all objects\n");
}
else if (!strcmp(ev->
key,
"T"))
{
printf("Thawing all objects\n");
}
else if (!strcmp(ev->
key,
"a"))
{
printf("Starting the animation in the Edje object\n");
}
else if (!strcmp(ev->
key,
"A"))
{
printf("Stopping the animation in the Edje object\n");
}
else if (!strcmp(ev->
key,
"Escape"))
else
{
printf(
"unhandled key: %s\n", ev->
key);
printf(commands);
}
}
int
{
const char *edje_file = PACKAGE_DATA_DIR"/animations.edj";
Ecore_Evas *ee;
return EXIT_FAILURE;
goto shutdown_ecore_evas;
if (!ee) goto shutdown_edje;
_on_key_down, NULL);
printf(commands);
return EXIT_SUCCESS;
shutdown_edje:
shutdown_ecore_evas:
return EXIT_FAILURE;
}
collections {
group {
name: "animations_group";
min: 100 80;
parts {
part {
name: "part_one";
type: RECT;
scale: 1;
description {
min: 50 50;
state: "default" 0.0;
color: 0 0 0 255; /* black */
rel1.relative: 0.0 0.0;
rel2.relative: 0.33 1.0;
}
description {
state: "invert" 1.0;
inherit: "default" 0.0;
rel1.relative: 0.0 0.0;
rel2.relative: 1.0 0.33;
}
}
part {
name: "part_two";
type: RECT;
scale: 1;
description {
min: 50 50;
state: "default" 0.0;
color: 255 255 0 255; /* yellow */
rel1.relative: 0.33 0.0;
rel2.relative: 0.66 1.0;
}
description {
state: "invert" 1.0;
inherit: "default" 0.0;
rel1.relative: 0.0 0.66;
rel2.relative: 1.0 1.0;
}
}
part {
name: "part_three";
type: RECT;
description {
state: "default" 0.0;
color: 255 0 0 255; /* red */
rel1.relative: 0.66 0.0;
rel2.relative: 1.0 1.0;
}
description {
state: "invert" 1.0;
inherit: "default" 0.0;
rel1.relative: 0.0 0.33;
rel2.relative: 1.0 0.66;
}
}
}
program {
signal: "load";
source: "";
in: 2.0 0.0;
after: "animation,state1";
}
program {
name: "animation,state1";
in: 1.0 0.0;
action: STATE_SET "invert" 1.0;
target: "part_one";
target: "part_two";
target: "part_three";
transition: LINEAR 0.6;
after: "animation,state2";
}
program {
name: "animation,state2";
in: 1.0 0.0;
action: STATE_SET "default" 0.0;
target: "part_one";
target: "part_two";
target: "part_three";
transition: LINEAR 0.6;
after: "animation,state1";
}
}
To compile use this command:
* gcc -o edje-animations edje-animations.c -DPACKAGE_BIN_DIR=\"/Where/enlightenment/is/installed/bin\"
* -DPACKAGE_LIB_DIR=\"/Where/enlightenment/is/installed/lib\"
* -DPACKAGE_DATA_DIR=\"/Where/enlightenment/is/installed/share\"
* `pkg-config --cflags --libs evas ecore ecore-evas edje`
*
* edje_cc animations.edc
*