2021-04-08 13:07:48 +02:00
|
|
|
#include "../../lv_examples.h"
|
2021-03-18 17:03:36 +01:00
|
|
|
#if LV_USE_IMG && LV_USE_SLIDER && LV_BUILD_EXAMPLES
|
2021-02-08 09:53:03 +01:00
|
|
|
|
|
|
|
static lv_obj_t * create_slider(lv_color_t color);
|
2021-04-14 15:31:54 +02:00
|
|
|
static void slider_event_cb(lv_event_t * e);
|
2021-02-08 09:53:03 +01:00
|
|
|
|
|
|
|
static lv_obj_t * red_slider, * green_slider, * blue_slider, * intense_slider;
|
|
|
|
static lv_obj_t * img1;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Demonstrate runtime image re-coloring
|
|
|
|
*/
|
|
|
|
void lv_example_img_2(void)
|
|
|
|
{
|
|
|
|
/*Create 4 sliders to adjust RGB color and re-color intensity*/
|
2021-04-23 12:46:14 +02:00
|
|
|
red_slider = create_slider(lv_palette_main(LV_PALETTE_RED));
|
|
|
|
green_slider = create_slider(lv_palette_main(LV_PALETTE_GREEN));
|
|
|
|
blue_slider = create_slider(lv_palette_main(LV_PALETTE_BLUE));
|
|
|
|
intense_slider = create_slider(lv_palette_main(LV_PALETTE_GREY));
|
2021-02-08 09:53:03 +01:00
|
|
|
|
|
|
|
lv_slider_set_value(red_slider, LV_OPA_20, LV_ANIM_OFF);
|
|
|
|
lv_slider_set_value(green_slider, LV_OPA_90, LV_ANIM_OFF);
|
|
|
|
lv_slider_set_value(blue_slider, LV_OPA_60, LV_ANIM_OFF);
|
|
|
|
lv_slider_set_value(intense_slider, LV_OPA_50, LV_ANIM_OFF);
|
|
|
|
|
2021-03-25 16:14:17 +01:00
|
|
|
lv_obj_align(red_slider, LV_ALIGN_LEFT_MID, 25, 0);
|
|
|
|
lv_obj_align_to(green_slider, red_slider, LV_ALIGN_OUT_RIGHT_MID, 25, 0);
|
|
|
|
lv_obj_align_to(blue_slider, green_slider, LV_ALIGN_OUT_RIGHT_MID, 25, 0);
|
|
|
|
lv_obj_align_to(intense_slider, blue_slider, LV_ALIGN_OUT_RIGHT_MID, 25, 0);
|
2021-02-08 09:53:03 +01:00
|
|
|
|
2021-03-15 02:03:27 +08:00
|
|
|
/*Now create the actual image*/
|
2021-02-19 18:19:32 +01:00
|
|
|
LV_IMG_DECLARE(img_cogwheel_argb)
|
2021-03-25 13:36:50 +01:00
|
|
|
img1 = lv_img_create(lv_scr_act());
|
2021-02-08 09:53:03 +01:00
|
|
|
lv_img_set_src(img1, &img_cogwheel_argb);
|
2021-03-25 16:14:17 +01:00
|
|
|
lv_obj_align(img1, LV_ALIGN_RIGHT_MID, -20, 0);
|
2021-02-08 09:53:03 +01:00
|
|
|
|
2023-02-20 20:50:58 +01:00
|
|
|
lv_obj_send_event(intense_slider, LV_EVENT_VALUE_CHANGED, NULL);
|
2021-02-08 09:53:03 +01:00
|
|
|
}
|
|
|
|
|
2021-04-14 15:31:54 +02:00
|
|
|
static void slider_event_cb(lv_event_t * e)
|
2021-02-08 09:53:03 +01:00
|
|
|
{
|
2021-04-19 11:15:28 +02:00
|
|
|
LV_UNUSED(e);
|
2021-02-14 22:07:38 +01:00
|
|
|
|
2021-04-19 11:15:28 +02:00
|
|
|
/*Recolor the image based on the sliders' values*/
|
2022-02-13 13:59:17 -05:00
|
|
|
lv_color_t color = lv_color_make(lv_slider_get_value(red_slider), lv_slider_get_value(green_slider),
|
|
|
|
lv_slider_get_value(blue_slider));
|
2021-04-19 11:15:28 +02:00
|
|
|
lv_opa_t intense = lv_slider_get_value(intense_slider);
|
|
|
|
lv_obj_set_style_img_recolor_opa(img1, intense, 0);
|
|
|
|
lv_obj_set_style_img_recolor(img1, color, 0);
|
2021-02-08 09:53:03 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static lv_obj_t * create_slider(lv_color_t color)
|
|
|
|
{
|
2021-03-25 13:36:50 +01:00
|
|
|
lv_obj_t * slider = lv_slider_create(lv_scr_act());
|
2021-02-08 09:53:03 +01:00
|
|
|
lv_slider_set_range(slider, 0, 255);
|
|
|
|
lv_obj_set_size(slider, 10, 200);
|
2021-03-31 19:57:14 +02:00
|
|
|
lv_obj_set_style_bg_color(slider, color, LV_PART_KNOB);
|
|
|
|
lv_obj_set_style_bg_color(slider, lv_color_darken(color, LV_OPA_40), LV_PART_INDICATOR);
|
2023-02-20 20:50:58 +01:00
|
|
|
lv_obj_add_event(slider, slider_event_cb, LV_EVENT_VALUE_CHANGED, NULL);
|
2021-02-08 09:53:03 +01:00
|
|
|
return slider;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|