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)
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;
}
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;
}
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");
}
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;
//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;
}