backends: implements animation's repeat
[platform/core/uifw/libpui.git] / backends / voice / default_ani_timeout.c
index bb26a39..90b3b4b 100644 (file)
@@ -85,7 +85,11 @@ _ani_backend_timeout_get_frame(default_ani_info *ani_info)
        }
        ani_info->frame_idx++;
        if (ani_info->frame_idx >= (ani_info->num_key_frames * SMOOTH_FRAME))
+       {
+               if (ani_info->repeat >= 0)
+                       ani_info->repeat_cur++;
                ani_info->frame_idx = 0;
+       }
 
        return frame;
 }
@@ -143,7 +147,14 @@ _ani_backend_timeout_frame_cb(void *data, int serial)
                return (pui_bool)0;
        }
 
-       pui_info("... update (serial=%d)\n", serial);
+       pui_info("... update (serial=%d), (repeat| cur: %d, want: %d)\n",
+               serial, ani_info->repeat_cur, ani_info->repeat);
+
+       if (ani_info->repeat >= 0 &&
+               ani_info->repeat_cur >= ani_info->repeat)
+       {
+               ani_data->ani_func->ani_stop(ani, EINA_FALSE);
+       }
 
        return (pui_bool)1;
 }
@@ -158,14 +169,13 @@ _ani_timeout_start(pui_ani_t *ani, int repeat)
        ani_data = pui_backend_ani_get_ani_data(ani);
        default_ani_info *info = (default_ani_info *)ani_data->ani_info;
 
-       //TODO
-       (void) info;
-
        pui_info("... info->id: %s, repeat : %d, interval: %d\n", info->id, repeat, info->interval);
 
        pui_backend_ani_status_update(ani, PUI_ANI_STATUS_STARTED);
-       ret = pui_backend_ani_add_frame_cb(ani, _ani_backend_timeout_frame_cb, info->interval / 1000.0);
+       if (repeat == 0) info->repeat = 1;
+       else info->repeat = repeat;
 
+       ret = pui_backend_ani_add_frame_cb(ani, _ani_backend_timeout_frame_cb, info->interval / 1000.0);
        if (!ret)
        {
                pui_err("Failed to add frame callback !\n");