2 * Copyright © 2019 Samsung Electronics co., Ltd. All Rights Reserved.
4 * Permission is hereby granted, free of charge, to any person obtaining
5 * a copy of this software and associated documentation files (the
6 * "Software"), to deal in the Software without restriction, including
7 * without limitation the rights to use, copy, modify, merge, publish,
8 * distribute, sublicense, and/or sell copies of the Software, and to
9 * permit persons to whom the Software is furnished to do so, subject to
10 * the following conditions:
12 * The above copyright notice and this permission notice (including the
13 * next paragraph) shall be included in all copies or substantial
14 * portions of the Software.
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
20 * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
21 * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
22 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
26 #include "../default_backend.h"
29 _ani_backend_swupdatedone_get_led_rgb(default_frame_info_t *frame, int led_idx, unsigned int *r, unsigned int *g, unsigned int *b)
32 if (!r || !g || !b) return;
33 if (led_idx > frame->num_led) return;
35 *r = (frame->leds[led_idx].color & LED_MASK_RED) >> 16;
36 *g = (frame->leds[led_idx].color & LED_MASK_GREEN) >> 8;
37 *b = (frame->leds[led_idx].color & LED_MASK_BLUE);
41 _ani_backend_swupdatedone_free_frame(default_frame_info_t *frame)
45 if (frame->leds) free(frame->leds);
49 static default_frame_info_t *
50 _ani_backend_swupdatedone_get_frame(default_ani_info *ani_info)
52 default_frame_info_t *frame, *key_frame, *key_frame2;
54 unsigned int r, g, b, r2, g2, b2;
58 frame = (default_frame_info_t *)calloc(sizeof(default_frame_info_t), 1);
59 if (!frame) return NULL;
61 if (ani_info->frame_idx == 0)
63 ani_info->frame_max = (unsigned int)(ani_info->frames[ani_info->key_frame_cur].frame_duration / ani_info->interval);
66 idx = ani_info->key_frame_cur;
67 idx2 = (idx + 1) % ani_info->num_key_frames;
69 key_frame = &ani_info->frames[idx];
70 key_frame2 = &ani_info->frames[idx2];
71 frame->num_led = key_frame->num_led;
72 frame->leds = (default_led_info_t *)calloc(sizeof(default_led_info_t), frame->num_led);
79 div = (double)(ani_info->frame_idx) / (double)ani_info->frame_max;
80 r = g = b = r2 = g2 = b2 = 0x0;
82 for (int i = 0; i < key_frame->num_led; i++)
84 _ani_backend_swupdatedone_get_led_rgb(key_frame, i, &r, &g, &b);
85 _ani_backend_swupdatedone_get_led_rgb(key_frame2, i, &r2, &g2, &b2);
86 r3 = (int)(r2 - r) * div + r;
87 g3 = (int)(g2 - g) * div + g;
88 b3 = (int)(b2 - b) * div + b;
90 frame->leds[i].color = (r3 << 16) + (g3 << 8) + (b3);
93 ani_info->frame_idx++;
94 if (ani_info->frame_idx >= ani_info->frame_max)
96 ani_info->frame_idx = 0;
97 ani_info->key_frame_cur = (ani_info->key_frame_cur + 1) % ani_info->num_key_frames;
98 if (ani_info->repeat >= 0 && ani_info->key_frame_cur == 0)
99 ani_info->repeat_cur++;
106 _ani_backend_swupdatedone_frame_cb(void *data, int serial)
108 pui_int_error e = PUI_INT_ERROR_NONE;
109 pui_ani_t *ani = (pui_ani_t *)data;
110 pui_backend_ani_data *ani_data = NULL;
111 pui_ani_control_buffer *buffer = NULL;
112 default_frame_info_t *frame;
113 unsigned int r = 0x0, g = 0x0, b = 0x0;
115 ani_data = pui_backend_ani_get_ani_data(ani);
116 default_ani_info *ani_info = (default_ani_info *)ani_data->ani_info;
118 /* TODO : make use of ani_info */
121 buffer = pui_backend_ani_get_buffer(ani);
123 pui_err("Failed to get buffer for animation\n");
127 frame = _ani_backend_swupdatedone_get_frame(ani_info);
128 for(int i = 0; i<12; i++)
130 _ani_backend_swupdatedone_get_led_rgb(frame, i, &r, &g, &b);
131 buffer->ptr[4*i] = 0;
132 buffer->ptr[4*i + 1] = b; /* BLUE */
133 buffer->ptr[4*i + 2] = g; /* GREEN */
134 buffer->ptr[4*i + 3] = r; /* RED */
136 _ani_backend_swupdatedone_free_frame(frame);
138 e = pui_backend_ani_set_buffer(ani, buffer);
140 if (e != PUI_INT_ERROR_NONE)
142 pui_err("Failed on setting buffer on animation !(e=%d)\n", e);
146 e = pui_backend_ani_update(ani);
148 if (e != PUI_INT_ERROR_NONE)
150 pui_err("Failed on updating animation !(e=%d)\n", e);
154 pui_info("... update (serial=%d), (repeat| cur: %d, want: %d)\n",
155 serial, ani_info->repeat_cur, ani_info->repeat);
157 if (ani_info->repeat >= 0 &&
158 ani_info->repeat_cur >= ani_info->repeat)
160 ani_data->ani_func->ani_stop(ani, EINA_FALSE);
167 _ani_swupdatedone_start(pui_ani_t *ani, int repeat)
170 pui_int_error e = PUI_INT_ERROR_NONE;
171 pui_backend_ani_data *ani_data = NULL;
173 ani_data = pui_backend_ani_get_ani_data(ani);
174 default_ani_info *info = (default_ani_info *)ani_data->ani_info;
176 pui_info("... info->id: %s, repeat : %d, interval: %d\n", info->id, repeat, info->interval);
178 pui_backend_ani_status_update(ani, PUI_ANI_STATUS_STARTED);
179 if (repeat == 0) info->repeat = 1;
180 else info->repeat = repeat;
182 info->key_frame_cur = 0;
184 info->repeat_cur = 0;
186 ret = pui_backend_ani_add_frame_cb(ani, _ani_backend_swupdatedone_frame_cb, info->interval / 1000.0);
189 pui_err("Failed to add frame callback !\n");
190 e = PUI_INT_ERROR_INVALID_RESOURCES;
197 _ani_swupdatedone_stop(pui_ani_t *ani, pui_bool force)
199 pui_int_error e = PUI_INT_ERROR_NONE;
200 pui_backend_ani_data *ani_data = NULL;
202 ani_data = pui_backend_ani_get_ani_data(ani);
203 default_ani_info *info = (default_ani_info *)ani_data->ani_info;
208 pui_info("... info->id: %s, force=%d\n", info->id, force);
210 pui_backend_ani_remove_frame_cb(ani);
213 pui_backend_ani_status_update(ani, PUI_ANI_STATUS_PAUSED);
215 pui_backend_ani_status_update(ani, PUI_ANI_STATUS_STOPPED);
223 pui_default_backend_ani_swupdatedone_func_set(pui_backend_ani_func *func)
227 func->ani_start = _ani_swupdatedone_start;
228 func->ani_stop = _ani_swupdatedone_stop;