default_backend: implements frame_duration to proceed each frame at a different speed
[platform/core/uifw/libpui.git] / backends / notification / default_ani_networkerror.c
index 6295946..f24c74c 100644 (file)
@@ -49,13 +49,20 @@ _ani_backend_networkerror_free_frame(default_frame_info_t *frame)
 static default_frame_info_t *
 _ani_backend_networkerror_get_frame(default_ani_info *ani_info)
 {
-#define BLINK_FRAME 40
        default_frame_info_t *frame, *key_frame;
+       int idx;
 
        frame = (default_frame_info_t *)calloc(sizeof(default_frame_info_t), 1);
        if (!frame) return NULL;
 
-       key_frame = &ani_info->frames[0];
+       if (ani_info->frame_idx == 0)
+       {
+               ani_info->frame_max = (unsigned int)(ani_info->frames[ani_info->key_frame_cur].frame_duration / ani_info->interval);
+       }
+
+       idx = ani_info->key_frame_cur;
+       key_frame = &ani_info->frames[idx];
+
        frame->num_led = key_frame->num_led;
        frame->leds = (default_led_info_t *)calloc(sizeof(default_led_info_t), frame->num_led);
        if (!frame->leds)
@@ -64,24 +71,19 @@ _ani_backend_networkerror_get_frame(default_ani_info *ani_info)
                return NULL;
        }
 
-       if (ani_info->frame_idx % BLINK_FRAME == 0)
+       for (int i = 0; i < key_frame->num_led; i++)
        {
-               for (int i = 0; i < key_frame->num_led; i++)
-               {
-                       frame->leds[i].color = key_frame->leds[i].color;
-               }
-       }
-       else
-       {
-               for (int i = 0; i < key_frame->num_led; i++)
-               {
-                       frame->leds[i].color = 0x000000;
-               }
+               frame->leds[i].color = key_frame->leds[i].color;
        }
 
        ani_info->frame_idx++;
-       if (ani_info->frame_idx >= BLINK_FRAME)
+       if (ani_info->frame_idx >= ani_info->frame_max)
+       {
                ani_info->frame_idx = 0;
+               ani_info->key_frame_cur = (ani_info->key_frame_cur + 1) % ani_info->num_key_frames;
+               if (ani_info->repeat >= 0 && ani_info->key_frame_cur == 0)
+                       ani_info->repeat_cur++;
+       }
 
        return frame;
 }
@@ -140,7 +142,14 @@ _ani_backend_networkerror_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;
 }
@@ -155,14 +164,17 @@ _ani_networkerror_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_networkerror_frame_cb, info->interval / 1000.0);
+       if (repeat == 0) info->repeat = 1;
+       else info->repeat = repeat;
 
+       info->key_frame_cur = 0;
+       info->frame_idx = 0;
+       info->repeat_cur = 0;
+
+       ret = pui_backend_ani_add_frame_cb(ani, _ani_backend_networkerror_frame_cb, info->interval / 1000.0);
        if (!ret)
        {
                pui_err("Failed to add frame callback !\n");
@@ -173,7 +185,7 @@ _ani_networkerror_start(pui_ani_t *ani, int repeat)
 }
 
 pui_error
-_ani_networkerror_stop(pui_ani_t *ani)
+_ani_networkerror_stop(pui_ani_t *ani, pui_bool force)
 {
        pui_int_error e = PUI_INT_ERROR_NONE;
        pui_backend_ani_data *ani_data = NULL;
@@ -184,10 +196,15 @@ _ani_networkerror_stop(pui_ani_t *ani)
        //TODO
        (void) info;
 
-       pui_info("... info->id: %s\n", info->id);
+       pui_info("... info->id: %s, force=%d\n", info->id, force);
 
        pui_backend_ani_remove_frame_cb(ani);
-       pui_backend_ani_status_update(ani, PUI_ANI_STATUS_STOPPED);
+
+       if (force)
+               pui_backend_ani_status_update(ani, PUI_ANI_STATUS_PAUSED);
+       else
+               pui_backend_ani_status_update(ani, PUI_ANI_STATUS_STOPPED);
+
 
        return e;
 }