2021-04-08 13:07:48 +02:00
|
|
|
#include "../../lv_examples.h"
|
2021-03-25 13:36:50 +01:00
|
|
|
#if LV_BUILD_EXAMPLES && LV_USE_BTN
|
2021-02-04 14:46:11 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a style transition on a button to act like a gum when clicked
|
|
|
|
*/
|
2021-02-07 22:39:54 +01:00
|
|
|
void lv_example_btn_3(void)
|
2021-02-04 14:46:11 +01:00
|
|
|
{
|
|
|
|
/*Properties to transition*/
|
|
|
|
static lv_style_prop_t props[] = {
|
2021-04-23 11:34:59 +02:00
|
|
|
LV_STYLE_TRANSFORM_WIDTH, LV_STYLE_TRANSFORM_HEIGHT, LV_STYLE_TEXT_LETTER_SPACE, 0
|
2021-02-04 14:46:11 +01:00
|
|
|
};
|
|
|
|
|
2021-03-15 02:03:27 +08:00
|
|
|
/*Transition descriptor when going back to the default state.
|
|
|
|
*Add some delay to be sure the press transition is visible even if the press was very short*/
|
2021-02-04 14:46:11 +01:00
|
|
|
static lv_style_transition_dsc_t transition_dsc_def;
|
2021-05-12 12:57:12 +02:00
|
|
|
lv_style_transition_dsc_init(&transition_dsc_def, props, lv_anim_path_overshoot, 250, 100, NULL);
|
2021-02-04 14:46:11 +01:00
|
|
|
|
2021-03-15 02:03:27 +08:00
|
|
|
/*Transition descriptor when going to pressed state.
|
|
|
|
*No delay, go to presses state immediately*/
|
2021-02-04 14:46:11 +01:00
|
|
|
static lv_style_transition_dsc_t transition_dsc_pr;
|
2021-05-12 12:57:12 +02:00
|
|
|
lv_style_transition_dsc_init(&transition_dsc_pr, props, lv_anim_path_ease_in_out, 250, 0, NULL);
|
2021-02-04 14:46:11 +01:00
|
|
|
|
|
|
|
/*Add only the new transition to he default state*/
|
|
|
|
static lv_style_t style_def;
|
|
|
|
lv_style_init(&style_def);
|
|
|
|
lv_style_set_transition(&style_def, &transition_dsc_def);
|
|
|
|
|
|
|
|
/*Add the transition and some transformation to the presses state.*/
|
|
|
|
static lv_style_t style_pr;
|
|
|
|
lv_style_init(&style_pr);
|
|
|
|
lv_style_set_transform_width(&style_pr, 10);
|
|
|
|
lv_style_set_transform_height(&style_pr, -10);
|
2021-03-25 13:36:50 +01:00
|
|
|
lv_style_set_text_letter_space(&style_pr, 10);
|
2021-02-04 14:46:11 +01:00
|
|
|
lv_style_set_transition(&style_pr, &transition_dsc_pr);
|
|
|
|
|
2021-03-25 13:36:50 +01:00
|
|
|
lv_obj_t * btn1 = lv_btn_create(lv_scr_act());
|
2021-03-25 16:14:17 +01:00
|
|
|
lv_obj_align(btn1, LV_ALIGN_CENTER, 0, -80);
|
2021-03-31 19:57:14 +02:00
|
|
|
lv_obj_add_style(btn1, &style_pr, LV_STATE_PRESSED);
|
|
|
|
lv_obj_add_style(btn1, &style_def, 0);
|
2021-02-04 14:46:11 +01:00
|
|
|
|
2021-03-25 13:36:50 +01:00
|
|
|
lv_obj_t * label = lv_label_create(btn1);
|
|
|
|
lv_label_set_text(label, "Gum");
|
2021-02-04 14:46:11 +01:00
|
|
|
}
|
|
|
|
#endif
|