You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
65 lines
2.4 KiB
C
65 lines
2.4 KiB
C
#include "../../lv_examples.h"
|
|
#if LV_USE_IMG && LV_USE_SLIDER && LV_BUILD_EXAMPLES
|
|
|
|
static lv_obj_t * create_slider(lv_color_t color);
|
|
static void slider_event_cb(lv_event_t * e);
|
|
|
|
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*/
|
|
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));
|
|
|
|
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);
|
|
|
|
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);
|
|
|
|
/*Now create the actual image*/
|
|
LV_IMG_DECLARE(img_cogwheel_argb)
|
|
img1 = lv_img_create(lv_scr_act());
|
|
lv_img_set_src(img1, &img_cogwheel_argb);
|
|
lv_obj_align(img1, LV_ALIGN_RIGHT_MID, -20, 0);
|
|
|
|
lv_event_send(intense_slider, LV_EVENT_VALUE_CHANGED, NULL);
|
|
}
|
|
|
|
static void slider_event_cb(lv_event_t * e)
|
|
{
|
|
LV_UNUSED(e);
|
|
|
|
/*Recolor the image based on the sliders' values*/
|
|
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));
|
|
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);
|
|
}
|
|
|
|
static lv_obj_t * create_slider(lv_color_t color)
|
|
{
|
|
lv_obj_t * slider = lv_slider_create(lv_scr_act());
|
|
lv_slider_set_range(slider, 0, 255);
|
|
lv_obj_set_size(slider, 10, 200);
|
|
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);
|
|
lv_obj_add_event_cb(slider, slider_event_cb, LV_EVENT_VALUE_CHANGED, NULL);
|
|
return slider;
|
|
}
|
|
|
|
#endif
|