Evas_Object *layout;
Evas_Object *slider;
Evas_Object *button;
- Ecore_Evas *ee;
+ Ecore_Animator *animator;
Eina_Bool autoPlaying;
};
{
AppInfo *info = (AppInfo *)data;
if (info->view) delete info->view;
- info->view = NULL;
-
- ecore_evas_data_set(info->ee, "AppInfo", NULL);
-
+ ecore_animator_del(info->animator);
free(info);
}
}
}
-static void
-_ee_pre_render_cb(Ecore_Evas *ee)
+static Eina_Bool
+_animator_cb(void *data)
{
- AppInfo *info = (AppInfo *)ecore_evas_data_get(ee, "AppInfo");
+ AppInfo *info = (AppInfo *)data;
if (info && info->autoPlaying && info->view)
{
if (pos >= 1.0)
_toggle_start_button(info);
}
+ return ECORE_CALLBACK_RENEW;
}
static void
create_layout(Evas_Object *parent, const char *file)
{
Evas_Object *layout, *slider, *image, *button;
- Evas *e;
- Ecore_Evas *ee;
+ Ecore_Animator *animator;
char buf[64];
AppInfo *info = (AppInfo *)calloc(sizeof(AppInfo), 1);
//IMAGE from LOTTIEVIEW
image = view->getImage();
evas_object_show(image);
- evas_object_size_hint_min_set(image, 500, 500);
elm_object_part_content_set(layout, "lottie", image);
//SLIDER
elm_object_part_content_set(layout, "button", button);
evas_object_smart_callback_add(button, "clicked", _button_clicked_cb, (void *)info);
- e = evas_object_evas_get(layout);
- ee = ecore_evas_ecore_evas_get(e);
- ecore_evas_data_set(ee, "AppInfo", info);
- ecore_evas_callback_pre_render_set(ee, _ee_pre_render_cb);
+ animator = ecore_animator_add(_animator_cb, info);
info->view = view;
info->layout = layout;
info->slider = slider;
info->button = button;
- info->ee = ee;
+ info->animator = animator;
evas_object_event_callback_add(layout, EVAS_CALLBACK_DEL, _layout_del_cb, (void *)info);
sprintf(buf, "%d / %ld", 0, view->getTotalFrame());
collections {
- group { name: "layout";
+ group { "layout";
parts {
rect { "bg";
- desc { state: "default" 0.0;
+ desc { "default";
color: 225 225 225 225;
}
}
spacer { "lottie_base";
- desc { state: "default" 0.0;
+ desc { "default";
rel1.to_y: "text";
rel1.relative: 0.0 1.0;
rel2.to_y: "slider";
}
}
swallow { "lottie";
- desc { state: "default" 0.0;
+ desc { "default";
rel1.to: "lottie_base";
- rel1.relative: 0.5 0.5;
rel2.to: "lottie_base";
- rel2.relative: 0.5 0.5;
}
}
text { "text";
- desc { state: "default" 0.0;
+ desc { "default";
rel1.relative: 1.0 0.0;
rel2.relative: 1.0 0.0;
rel1.offset: -20 20;
}
}
swallow { "slider";
- desc { state: "default" 0.0;
+ desc { "default";
min: 0 100;
max: -1 100;
align: 0.5 1.0;
}
}
spacer { "left_pad";
- desc { state: "default" 0.0;
+ desc { "default";
fixed: 1 0;
min: 20 0;
align: 0.0 0.5;
}
}
spacer { "right_pad";
- desc { state: "default" 0.0;
+ desc { "default";
fixed: 1 0;
min: 20 0;
align: 1.0 0.5;
}
}
swallow { "button";
- desc { state: "default" 0.0;
+ desc { "default";
fixed: 1 1;
min: 80 55;
align: 1.0 0.5;
}
}
spacer { "button_left_pad";
- desc { state: "default" 0.0;
+ desc { "default";
fixed: 1 0;
min: 20 0;
align: 1.0 0.5;