summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJaehyun Cho <jae_hyun.cho@samsung.com>2017-07-03 22:57:23 +0900
committerJaehyun Cho <jae_hyun.cho@samsung.com>2017-08-18 12:06:01 +0900
commit04d50a7b566dc7ac848c9aa38d398f5201d017df (patch)
tree6058c2fb6bff1b5a2d7234a2366ed71c3de17be9
parented2b367a08df80caf212cf75b54ba199620abd76 (diff)
downloadefl-04d50a7b566dc7ac848c9aa38d398f5201d017df.tar.gz
efl_animation: Add group animation instance
-rw-r--r--src/Makefile_Evas.am2
-rw-r--r--src/lib/evas/Evas_Common.h7
-rw-r--r--src/lib/evas/Evas_Eo.h1
-rw-r--r--src/lib/evas/Evas_Internal.h9
-rw-r--r--src/lib/evas/canvas/efl_animation_instance_group.c184
-rw-r--r--src/lib/evas/canvas/efl_animation_instance_group.eo12
-rw-r--r--src/lib/evas/include/evas_private.h1
7 files changed, 216 insertions, 0 deletions
diff --git a/src/Makefile_Evas.am b/src/Makefile_Evas.am
index 5ca239f507..2171b0f0d5 100644
--- a/src/Makefile_Evas.am
+++ b/src/Makefile_Evas.am
@@ -61,6 +61,7 @@ evas_eolian_pub_files = \
lib/evas/canvas/efl_animation_instance_rotate.eo \
lib/evas/canvas/efl_animation_instance_scale.eo \
lib/evas/canvas/efl_animation_instance_translate.eo \
+ lib/evas/canvas/efl_animation_instance_group.eo \
$(NULL)
evas_eolian_legacy_files = \
@@ -236,6 +237,7 @@ lib/evas/canvas/efl_animation_instance_alpha.c \
lib/evas/canvas/efl_animation_instance_rotate.c \
lib/evas/canvas/efl_animation_instance_scale.c \
lib/evas/canvas/efl_animation_instance_translate.c \
+lib/evas/canvas/efl_animation_instance_group.c \
$(NULL)
EXTRA_DIST2 += \
diff --git a/src/lib/evas/Evas_Common.h b/src/lib/evas/Evas_Common.h
index 25e382d5b3..b4190bb1b9 100644
--- a/src/lib/evas/Evas_Common.h
+++ b/src/lib/evas/Evas_Common.h
@@ -3398,6 +3398,13 @@ typedef Eo Efl_Animation_Instance_Translate;
#endif
+#ifndef _EFL_ANIMATION_INSTANCE_GROUP_EO_CLASS_TYPE
+#define _EFL_ANIMATION_INSTANCE_GROUP_EO_CLASS_TYPE
+
+typedef Eo Efl_Animation_Instance_Group;
+
+#endif
+
struct _Efl_Animation_Instance_Animate_Event_Info
{
double progress;
diff --git a/src/lib/evas/Evas_Eo.h b/src/lib/evas/Evas_Eo.h
index d4db252240..975428bb7e 100644
--- a/src/lib/evas/Evas_Eo.h
+++ b/src/lib/evas/Evas_Eo.h
@@ -77,6 +77,7 @@
#include "canvas/efl_animation_instance_rotate.eo.h"
#include "canvas/efl_animation_instance_scale.eo.h"
#include "canvas/efl_animation_instance_translate.eo.h"
+#include "canvas/efl_animation_instance_group.eo.h"
#endif /* EFL_EO_API_SUPPORT */
#if defined(EFL_BETA_API_SUPPORT) && defined(EFL_EO_API_SUPPORT)
diff --git a/src/lib/evas/Evas_Internal.h b/src/lib/evas/Evas_Internal.h
index acdc90771a..9cf03f62c0 100644
--- a/src/lib/evas/Evas_Internal.h
+++ b/src/lib/evas/Evas_Internal.h
@@ -121,6 +121,15 @@ EOAPI void efl_animation_instance_translate_get(const Eo *obj, int *from_x, int
EOAPI void efl_animation_instance_translate_absolute_set(Eo *obj, int from_x, int from_y, int to_x, int to_y);
EOAPI void efl_animation_instance_translate_absolute_get(const Eo *obj, int *from_x, int *from_y, int *to_x, int *to_y);
+EOAPI void efl_animation_instance_group_instance_add(Eo *obj, Efl_Animation_Instance *animation);
+
+EOAPI void efl_animation_instance_group_instance_del(Eo *obj, Efl_Animation_Instance *animation);
+
+EOAPI Eina_List *efl_animation_instance_group_instances_get(Eo *obj);
+
+EWAPI extern const Efl_Event_Description _EFL_ANIMATION_INSTANCE_GROUP_EVENT_MEMBER_POST_END;
+#define EFL_ANIMATION_INSTANCE_GROUP_EVENT_MEMBER_POST_END (&(_EFL_ANIMATION_INSTANCE_GROUP_EVENT_MEMBER_POST_END))
+
#ifdef __cplusplus
}
#endif
diff --git a/src/lib/evas/canvas/efl_animation_instance_group.c b/src/lib/evas/canvas/efl_animation_instance_group.c
new file mode 100644
index 0000000000..22096d99e1
--- /dev/null
+++ b/src/lib/evas/canvas/efl_animation_instance_group.c
@@ -0,0 +1,184 @@
+#include "evas_common_private.h"
+#include "evas_private.h"
+
+#define MY_CLASS EFL_ANIMATION_INSTANCE_GROUP_CLASS
+#define MY_CLASS_NAME efl_class_name_get(MY_CLASS)
+
+#define EFL_ANIMATION_INSTANCE_GROUP_CHECK_OR_RETURN(anim, ...) \
+ do { \
+ if (!anim) { \
+ CRI("Efl_Animation_Instance " # anim " is NULL!"); \
+ return __VA_ARGS__; \
+ } \
+ if (efl_animation_instance_is_deleted(anim)) { \
+ ERR("Efl_Animation_Instance " # anim " has already been deleted!"); \
+ return __VA_ARGS__; \
+ } \
+ } while (0)
+
+#define EFL_ANIMATION_INSTANCE_GROUP_DATA_GET(o, pd) \
+ Evas_Object_Animation_Instance_Group_Data *pd = efl_data_scope_get(o, EFL_ANIMATION_INSTANCE_GROUP_CLASS)
+
+struct _Evas_Object_Animation_Instance_Group_Data
+{
+ Eina_List *instances;
+};
+
+EOLIAN static void
+_efl_animation_instance_group_instance_add(Eo *eo_obj,
+ Evas_Object_Animation_Instance_Group_Data *pd,
+ Efl_Animation_Instance *instance)
+{
+ EFL_ANIMATION_INSTANCE_GROUP_CHECK_OR_RETURN(eo_obj);
+
+ if (!instance) return;
+
+ Efl_Canvas_Object *target = efl_animation_instance_target_get(eo_obj);
+ efl_animation_instance_target_set(instance, target);
+
+ double duration = efl_animation_instance_duration_get(eo_obj);
+ efl_animation_instance_duration_set(instance, duration);
+
+ Eina_Bool state_keep = efl_animation_instance_final_state_keep_get(eo_obj);
+ efl_animation_instance_final_state_keep_set(instance, state_keep);
+
+ pd->instances = eina_list_append(pd->instances, instance);
+}
+
+EOLIAN static void
+_efl_animation_instance_group_instance_del(Eo *eo_obj,
+ Evas_Object_Animation_Instance_Group_Data *pd,
+ Efl_Animation_Instance *instance)
+{
+ EFL_ANIMATION_INSTANCE_GROUP_CHECK_OR_RETURN(eo_obj);
+
+ if (!instance) return;
+
+ pd->instances = eina_list_remove(pd->instances, instance);
+}
+
+EOLIAN static Eina_List *
+_efl_animation_instance_group_instances_get(Eo *eo_obj,
+ Evas_Object_Animation_Instance_Group_Data *pd)
+{
+ EFL_ANIMATION_INSTANCE_GROUP_CHECK_OR_RETURN(eo_obj, NULL);
+
+ return pd->instances;
+}
+
+EOLIAN static void
+_efl_animation_instance_group_efl_animation_instance_target_set(Eo *eo_obj,
+ Evas_Object_Animation_Instance_Group_Data *pd,
+ Efl_Canvas_Object *target)
+{
+ EFL_ANIMATION_INSTANCE_GROUP_CHECK_OR_RETURN(eo_obj);
+
+ Eina_List *l;
+ Efl_Animation_Instance *inst;
+
+ EINA_LIST_FOREACH(pd->instances, l, inst)
+ {
+ efl_animation_instance_target_set(inst, target);
+ }
+
+ efl_animation_instance_target_set(efl_super(eo_obj, MY_CLASS), target);
+}
+
+EOLIAN static void
+_efl_animation_instance_group_efl_animation_instance_duration_set(Eo *eo_obj,
+ Evas_Object_Animation_Instance_Group_Data *pd,
+ double duration)
+{
+ EFL_ANIMATION_INSTANCE_GROUP_CHECK_OR_RETURN(eo_obj);
+
+ if (duration <= 0.0) duration = 0.0;
+
+ Eina_List *l;
+ Efl_Animation_Instance *inst;
+
+ EINA_LIST_FOREACH(pd->instances, l, inst)
+ {
+ efl_animation_instance_duration_set(inst, duration);
+ }
+
+ efl_animation_instance_duration_set(efl_super(eo_obj, MY_CLASS), duration);
+}
+
+EOLIAN static void
+_efl_animation_instance_group_efl_animation_instance_final_state_keep_set(Eo *eo_obj,
+ Evas_Object_Animation_Instance_Group_Data *pd,
+ Eina_Bool state_keep)
+{
+ EFL_ANIMATION_INSTANCE_GROUP_CHECK_OR_RETURN(eo_obj);
+
+ Eina_List *l;
+ Efl_Animation_Instance *inst;
+
+ EINA_LIST_FOREACH(pd->instances, l, inst)
+ {
+ efl_animation_instance_final_state_keep_set(inst, state_keep);
+ }
+
+ efl_animation_instance_final_state_keep_set(efl_super(eo_obj, MY_CLASS),
+ state_keep);
+}
+
+EOLIAN static void
+_efl_animation_instance_group_efl_animation_instance_map_reset(Eo *eo_obj,
+ Evas_Object_Animation_Instance_Group_Data *pd)
+{
+ EFL_ANIMATION_INSTANCE_GROUP_CHECK_OR_RETURN(eo_obj);
+
+ Eina_List *l;
+ Efl_Animation_Instance *inst;
+
+ EINA_LIST_FOREACH(pd->instances, l, inst)
+ {
+ efl_animation_instance_map_reset(inst);
+ }
+}
+
+EOLIAN static Efl_Object *
+_efl_animation_instance_group_efl_object_constructor(Eo *eo_obj,
+ Evas_Object_Animation_Instance_Group_Data *pd)
+{
+ eo_obj = efl_constructor(efl_super(eo_obj, MY_CLASS));
+
+ pd->instances = NULL;
+
+ return eo_obj;
+}
+
+EOLIAN static void
+_efl_animation_instance_group_efl_object_destructor(Eo *eo_obj,
+ Evas_Object_Animation_Instance_Group_Data *pd)
+{
+ Efl_Animation_Instance *inst;
+
+ EINA_LIST_FREE(pd->instances, inst)
+ efl_del(inst);
+
+ efl_destructor(efl_super(eo_obj, MY_CLASS));
+}
+
+/* Internal EO APIs */
+
+EOAPI EFL_VOID_FUNC_BODYV(efl_animation_instance_group_instance_add, EFL_FUNC_CALL(animation), Efl_Animation_Instance *animation);
+
+EOAPI EFL_VOID_FUNC_BODYV(efl_animation_instance_group_instance_del, EFL_FUNC_CALL(animation), Efl_Animation_Instance *animation);
+
+EOAPI EFL_FUNC_BODY(efl_animation_instance_group_instances_get, Eina_List *, NULL);
+
+EWAPI const Efl_Event_Description _EFL_ANIMATION_INSTANCE_GROUP_EVENT_MEMBER_POST_END =
+ EFL_EVENT_DESCRIPTION("member_post_end");
+
+#define EFL_ANIMATION_INSTANCE_GROUP_EXTRA_OPS \
+ EFL_OBJECT_OP_FUNC(efl_animation_instance_group_instance_add, _efl_animation_instance_group_instance_add), \
+ EFL_OBJECT_OP_FUNC(efl_animation_instance_group_instance_del, _efl_animation_instance_group_instance_del), \
+ EFL_OBJECT_OP_FUNC(efl_animation_instance_group_instances_get, _efl_animation_instance_group_instances_get), \
+ EFL_OBJECT_OP_FUNC(efl_animation_instance_target_set, _efl_animation_instance_group_efl_animation_instance_target_set), \
+ EFL_OBJECT_OP_FUNC(efl_animation_instance_duration_set, _efl_animation_instance_group_efl_animation_instance_duration_set), \
+ EFL_OBJECT_OP_FUNC(efl_animation_instance_final_state_keep_set, _efl_animation_instance_group_efl_animation_instance_final_state_keep_set), \
+ EFL_OBJECT_OP_FUNC(efl_animation_instance_map_reset, _efl_animation_instance_group_efl_animation_instance_map_reset)
+
+#include "efl_animation_instance_group.eo.c"
diff --git a/src/lib/evas/canvas/efl_animation_instance_group.eo b/src/lib/evas/canvas/efl_animation_instance_group.eo
new file mode 100644
index 0000000000..cdecf55cc4
--- /dev/null
+++ b/src/lib/evas/canvas/efl_animation_instance_group.eo
@@ -0,0 +1,12 @@
+import efl_animation_types;
+
+abstract Efl.Animation.Instance.Group (Efl.Animation.Instance)
+{
+ [[Efl group animation instance abstract class]]
+ legacy_prefix: evas_object_animation_instance;
+ data: Evas_Object_Animation_Instance_Group_Data;
+ implements {
+ Efl.Object.constructor;
+ Efl.Object.destructor;
+ }
+}
diff --git a/src/lib/evas/include/evas_private.h b/src/lib/evas/include/evas_private.h
index f5e3477635..391ce0feec 100644
--- a/src/lib/evas/include/evas_private.h
+++ b/src/lib/evas/include/evas_private.h
@@ -118,6 +118,7 @@ typedef struct _Evas_Object_Animation_Instance_Alpha_Data Evas_Objec
typedef struct _Evas_Object_Animation_Instance_Rotate_Data Evas_Object_Animation_Instance_Rotate_Data;
typedef struct _Evas_Object_Animation_Instance_Scale_Data Evas_Object_Animation_Instance_Scale_Data;
typedef struct _Evas_Object_Animation_Instance_Translate_Data Evas_Object_Animation_Instance_Translate_Data;
+typedef struct _Evas_Object_Animation_Instance_Group_Data Evas_Object_Animation_Instance_Group_Data;
typedef struct _Evas_Object_Animation_Instance_Data Evas_Object_Animation_Instance_Data;
// 3D stuff