2021-07-19 19:58:58 +08:00
|
|
|
#include "../lv_examples.h"
|
2021-11-29 14:54:37 +01:00
|
|
|
#if LV_USE_FLEX && LV_BUILD_EXAMPLES
|
2021-07-19 19:58:58 +08:00
|
|
|
|
2021-10-25 12:44:44 -04:00
|
|
|
static lv_anim_timeline_t * anim_timeline = NULL;
|
2021-07-19 19:58:58 +08:00
|
|
|
|
|
|
|
static lv_obj_t * obj1 = NULL;
|
|
|
|
static lv_obj_t * obj2 = NULL;
|
|
|
|
static lv_obj_t * obj3 = NULL;
|
|
|
|
|
2023-10-31 19:25:01 +01:00
|
|
|
static const int32_t obj_width = 90;
|
|
|
|
static const int32_t obj_height = 70;
|
2021-07-19 19:58:58 +08:00
|
|
|
|
2023-12-01 09:28:44 +01:00
|
|
|
static void set_width(lv_anim_t * var, int32_t v)
|
2021-07-19 19:58:58 +08:00
|
|
|
{
|
2023-12-01 09:28:44 +01:00
|
|
|
lv_obj_set_width(var->var, v);
|
2021-07-19 19:58:58 +08:00
|
|
|
}
|
|
|
|
|
2023-12-01 09:28:44 +01:00
|
|
|
static void set_height(lv_anim_t * var, int32_t v)
|
2021-07-19 19:58:58 +08:00
|
|
|
{
|
2023-12-01 09:28:44 +01:00
|
|
|
lv_obj_set_height(var->var, v);
|
2021-07-19 19:58:58 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
static void anim_timeline_create(void)
|
|
|
|
{
|
|
|
|
/* obj1 */
|
|
|
|
lv_anim_t a1;
|
|
|
|
lv_anim_init(&a1);
|
|
|
|
lv_anim_set_var(&a1, obj1);
|
|
|
|
lv_anim_set_values(&a1, 0, obj_width);
|
2023-12-01 09:28:44 +01:00
|
|
|
lv_anim_set_custom_exec_cb(&a1, set_width);
|
2021-07-19 19:58:58 +08:00
|
|
|
lv_anim_set_path_cb(&a1, lv_anim_path_overshoot);
|
2023-12-11 19:35:22 +08:00
|
|
|
lv_anim_set_duration(&a1, 300);
|
2021-07-19 19:58:58 +08:00
|
|
|
|
|
|
|
lv_anim_t a2;
|
|
|
|
lv_anim_init(&a2);
|
|
|
|
lv_anim_set_var(&a2, obj1);
|
|
|
|
lv_anim_set_values(&a2, 0, obj_height);
|
2023-12-01 09:28:44 +01:00
|
|
|
lv_anim_set_custom_exec_cb(&a2, set_height);
|
2021-07-19 19:58:58 +08:00
|
|
|
lv_anim_set_path_cb(&a2, lv_anim_path_ease_out);
|
2023-12-11 19:35:22 +08:00
|
|
|
lv_anim_set_duration(&a2, 300);
|
2021-07-19 19:58:58 +08:00
|
|
|
|
|
|
|
/* obj2 */
|
|
|
|
lv_anim_t a3;
|
|
|
|
lv_anim_init(&a3);
|
|
|
|
lv_anim_set_var(&a3, obj2);
|
|
|
|
lv_anim_set_values(&a3, 0, obj_width);
|
2023-12-01 09:28:44 +01:00
|
|
|
lv_anim_set_custom_exec_cb(&a3, set_width);
|
2021-07-19 19:58:58 +08:00
|
|
|
lv_anim_set_path_cb(&a3, lv_anim_path_overshoot);
|
2023-12-11 19:35:22 +08:00
|
|
|
lv_anim_set_duration(&a3, 300);
|
2021-07-19 19:58:58 +08:00
|
|
|
|
|
|
|
lv_anim_t a4;
|
|
|
|
lv_anim_init(&a4);
|
|
|
|
lv_anim_set_var(&a4, obj2);
|
|
|
|
lv_anim_set_values(&a4, 0, obj_height);
|
2023-12-01 09:28:44 +01:00
|
|
|
lv_anim_set_custom_exec_cb(&a4, set_height);
|
2021-07-19 19:58:58 +08:00
|
|
|
lv_anim_set_path_cb(&a4, lv_anim_path_ease_out);
|
2023-12-11 19:35:22 +08:00
|
|
|
lv_anim_set_duration(&a4, 300);
|
2021-07-19 19:58:58 +08:00
|
|
|
|
|
|
|
/* obj3 */
|
|
|
|
lv_anim_t a5;
|
|
|
|
lv_anim_init(&a5);
|
|
|
|
lv_anim_set_var(&a5, obj3);
|
|
|
|
lv_anim_set_values(&a5, 0, obj_width);
|
2023-12-01 09:28:44 +01:00
|
|
|
lv_anim_set_custom_exec_cb(&a5, set_width);
|
2021-07-19 19:58:58 +08:00
|
|
|
lv_anim_set_path_cb(&a5, lv_anim_path_overshoot);
|
2023-12-11 19:35:22 +08:00
|
|
|
lv_anim_set_duration(&a5, 300);
|
2021-07-19 19:58:58 +08:00
|
|
|
|
|
|
|
lv_anim_t a6;
|
|
|
|
lv_anim_init(&a6);
|
|
|
|
lv_anim_set_var(&a6, obj3);
|
|
|
|
lv_anim_set_values(&a6, 0, obj_height);
|
2023-12-01 09:28:44 +01:00
|
|
|
lv_anim_set_custom_exec_cb(&a6, set_height);
|
2021-07-19 19:58:58 +08:00
|
|
|
lv_anim_set_path_cb(&a6, lv_anim_path_ease_out);
|
2023-12-11 19:35:22 +08:00
|
|
|
lv_anim_set_duration(&a6, 300);
|
2021-07-19 19:58:58 +08:00
|
|
|
|
|
|
|
/* Create anim timeline */
|
|
|
|
anim_timeline = lv_anim_timeline_create();
|
|
|
|
lv_anim_timeline_add(anim_timeline, 0, &a1);
|
|
|
|
lv_anim_timeline_add(anim_timeline, 0, &a2);
|
|
|
|
lv_anim_timeline_add(anim_timeline, 200, &a3);
|
|
|
|
lv_anim_timeline_add(anim_timeline, 200, &a4);
|
|
|
|
lv_anim_timeline_add(anim_timeline, 400, &a5);
|
|
|
|
lv_anim_timeline_add(anim_timeline, 400, &a6);
|
|
|
|
}
|
|
|
|
|
2021-07-27 20:30:36 +08:00
|
|
|
static void btn_start_event_handler(lv_event_t * e)
|
2021-07-19 19:58:58 +08:00
|
|
|
{
|
|
|
|
lv_obj_t * btn = lv_event_get_target(e);
|
|
|
|
|
2022-02-13 13:59:17 -05:00
|
|
|
if(!anim_timeline) {
|
2021-07-19 19:58:58 +08:00
|
|
|
anim_timeline_create();
|
|
|
|
}
|
|
|
|
|
|
|
|
bool reverse = lv_obj_has_state(btn, LV_STATE_CHECKED);
|
|
|
|
lv_anim_timeline_set_reverse(anim_timeline, reverse);
|
|
|
|
lv_anim_timeline_start(anim_timeline);
|
|
|
|
}
|
|
|
|
|
2023-10-12 20:37:27 +02:00
|
|
|
static void btn_delete_event_handler(lv_event_t * e)
|
2021-07-19 19:58:58 +08:00
|
|
|
{
|
|
|
|
LV_UNUSED(e);
|
2022-02-13 13:59:17 -05:00
|
|
|
if(anim_timeline) {
|
2023-10-12 20:37:27 +02:00
|
|
|
lv_anim_timeline_delete(anim_timeline);
|
2021-07-19 19:58:58 +08:00
|
|
|
anim_timeline = NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-07-27 20:30:36 +08:00
|
|
|
static void btn_stop_event_handler(lv_event_t * e)
|
|
|
|
{
|
|
|
|
LV_UNUSED(e);
|
2022-02-13 13:59:17 -05:00
|
|
|
if(anim_timeline) {
|
2021-07-27 20:30:36 +08:00
|
|
|
lv_anim_timeline_stop(anim_timeline);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-07-19 19:58:58 +08:00
|
|
|
static void slider_prg_event_handler(lv_event_t * e)
|
|
|
|
{
|
|
|
|
lv_obj_t * slider = lv_event_get_target(e);
|
|
|
|
|
2022-02-13 13:59:17 -05:00
|
|
|
if(!anim_timeline) {
|
2021-07-19 19:58:58 +08:00
|
|
|
anim_timeline_create();
|
|
|
|
}
|
|
|
|
|
|
|
|
int32_t progress = lv_slider_get_value(slider);
|
|
|
|
lv_anim_timeline_set_progress(anim_timeline, progress);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create an animation timeline
|
|
|
|
*/
|
|
|
|
void lv_example_anim_timeline_1(void)
|
|
|
|
{
|
2023-10-12 20:37:27 +02:00
|
|
|
lv_obj_t * par = lv_screen_active();
|
2021-07-19 19:58:58 +08:00
|
|
|
lv_obj_set_flex_flow(par, LV_FLEX_FLOW_ROW);
|
|
|
|
lv_obj_set_flex_align(par, LV_FLEX_ALIGN_SPACE_AROUND, LV_FLEX_ALIGN_CENTER, LV_FLEX_ALIGN_CENTER);
|
|
|
|
|
2021-07-27 20:30:36 +08:00
|
|
|
/* create btn_start */
|
2023-09-14 20:12:31 +02:00
|
|
|
lv_obj_t * btn_start = lv_button_create(par);
|
2023-11-28 15:36:51 +01:00
|
|
|
lv_obj_add_event_cb(btn_start, btn_start_event_handler, LV_EVENT_VALUE_CHANGED, NULL);
|
2021-07-27 20:30:36 +08:00
|
|
|
lv_obj_add_flag(btn_start, LV_OBJ_FLAG_IGNORE_LAYOUT);
|
|
|
|
lv_obj_add_flag(btn_start, LV_OBJ_FLAG_CHECKABLE);
|
|
|
|
lv_obj_align(btn_start, LV_ALIGN_TOP_MID, -100, 20);
|
2021-07-19 19:58:58 +08:00
|
|
|
|
2021-07-27 20:30:36 +08:00
|
|
|
lv_obj_t * label_start = lv_label_create(btn_start);
|
|
|
|
lv_label_set_text(label_start, "Start");
|
|
|
|
lv_obj_center(label_start);
|
2021-07-19 19:58:58 +08:00
|
|
|
|
2021-07-27 20:30:36 +08:00
|
|
|
/* create btn_del */
|
2023-09-14 20:12:31 +02:00
|
|
|
lv_obj_t * btn_del = lv_button_create(par);
|
2023-11-28 15:36:51 +01:00
|
|
|
lv_obj_add_event_cb(btn_del, btn_delete_event_handler, LV_EVENT_CLICKED, NULL);
|
2021-07-19 19:58:58 +08:00
|
|
|
lv_obj_add_flag(btn_del, LV_OBJ_FLAG_IGNORE_LAYOUT);
|
2021-07-27 20:30:36 +08:00
|
|
|
lv_obj_align(btn_del, LV_ALIGN_TOP_MID, 0, 20);
|
2021-07-19 19:58:58 +08:00
|
|
|
|
|
|
|
lv_obj_t * label_del = lv_label_create(btn_del);
|
2021-07-27 20:30:36 +08:00
|
|
|
lv_label_set_text(label_del, "Delete");
|
2021-07-19 19:58:58 +08:00
|
|
|
lv_obj_center(label_del);
|
|
|
|
|
2021-07-27 20:30:36 +08:00
|
|
|
/* create btn_stop */
|
2023-09-14 20:12:31 +02:00
|
|
|
lv_obj_t * btn_stop = lv_button_create(par);
|
2023-11-28 15:36:51 +01:00
|
|
|
lv_obj_add_event_cb(btn_stop, btn_stop_event_handler, LV_EVENT_CLICKED, NULL);
|
2021-07-27 20:30:36 +08:00
|
|
|
lv_obj_add_flag(btn_stop, LV_OBJ_FLAG_IGNORE_LAYOUT);
|
|
|
|
lv_obj_align(btn_stop, LV_ALIGN_TOP_MID, 100, 20);
|
|
|
|
|
|
|
|
lv_obj_t * label_stop = lv_label_create(btn_stop);
|
|
|
|
lv_label_set_text(label_stop, "Stop");
|
|
|
|
lv_obj_center(label_stop);
|
|
|
|
|
|
|
|
/* create slider_prg */
|
2021-07-19 19:58:58 +08:00
|
|
|
lv_obj_t * slider_prg = lv_slider_create(par);
|
2023-11-28 15:36:51 +01:00
|
|
|
lv_obj_add_event_cb(slider_prg, slider_prg_event_handler, LV_EVENT_VALUE_CHANGED, NULL);
|
2021-07-19 19:58:58 +08:00
|
|
|
lv_obj_add_flag(slider_prg, LV_OBJ_FLAG_IGNORE_LAYOUT);
|
|
|
|
lv_obj_align(slider_prg, LV_ALIGN_BOTTOM_MID, 0, -20);
|
|
|
|
lv_slider_set_range(slider_prg, 0, 65535);
|
|
|
|
|
2021-07-27 20:30:36 +08:00
|
|
|
/* create 3 objects */
|
2021-07-19 19:58:58 +08:00
|
|
|
obj1 = lv_obj_create(par);
|
|
|
|
lv_obj_set_size(obj1, obj_width, obj_height);
|
2023-12-01 09:28:44 +01:00
|
|
|
lv_obj_set_scrollbar_mode(obj1, LV_SCROLLBAR_MODE_OFF);
|
2021-07-19 19:58:58 +08:00
|
|
|
|
|
|
|
obj2 = lv_obj_create(par);
|
|
|
|
lv_obj_set_size(obj2, obj_width, obj_height);
|
2023-12-01 09:28:44 +01:00
|
|
|
lv_obj_set_scrollbar_mode(obj2, LV_SCROLLBAR_MODE_OFF);
|
2021-07-19 19:58:58 +08:00
|
|
|
|
|
|
|
obj3 = lv_obj_create(par);
|
|
|
|
lv_obj_set_size(obj3, obj_width, obj_height);
|
2023-12-01 09:28:44 +01:00
|
|
|
lv_obj_set_scrollbar_mode(obj3, LV_SCROLLBAR_MODE_OFF);
|
2023-11-14 11:05:27 +01:00
|
|
|
|
|
|
|
anim_timeline_create();
|
2021-07-19 19:58:58 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|