1 #include "../../lv_examples.h"
2 #if LV_USE_ROLLER && LV_FONT_MONTSERRAT_22 && LV_BUILD_EXAMPLES
3
event_handler(lv_event_t * e)4 static void event_handler(lv_event_t * e)
5 {
6 lv_event_code_t code = lv_event_get_code(e);
7 lv_obj_t * obj = lv_event_get_target(e);
8 if(code == LV_EVENT_VALUE_CHANGED) {
9 char buf[32];
10 lv_roller_get_selected_str(obj, buf, sizeof(buf));
11 LV_LOG_USER("Selected value: %s", buf);
12 }
13 }
14
15 /**
16 * Roller with various alignments and larger text in the selected area
17 */
lv_example_roller_2(void)18 void lv_example_roller_2(void)
19 {
20 /*A style to make the selected option larger*/
21 static lv_style_t style_sel;
22 lv_style_init(&style_sel);
23 lv_style_set_text_font(&style_sel, &lv_font_montserrat_22);
24 lv_style_set_bg_color(&style_sel, lv_color_hex3(0xf88));
25 lv_style_set_border_width(&style_sel, 2);
26 lv_style_set_border_color(&style_sel, lv_color_hex3(0xf00));
27
28 const char * opts = "1\n2\n3\n4\n5\n6\n7\n8\n9\n10";
29 lv_obj_t * roller;
30
31 /*A roller on the left with left aligned text, and custom width*/
32 roller = lv_roller_create(lv_screen_active());
33 lv_roller_set_options(roller, opts, LV_ROLLER_MODE_NORMAL);
34 lv_roller_set_visible_row_count(roller, 2);
35 lv_obj_set_width(roller, 100);
36 lv_obj_add_style(roller, &style_sel, LV_PART_SELECTED);
37 lv_obj_set_style_text_align(roller, LV_TEXT_ALIGN_LEFT, 0);
38 lv_obj_set_style_bg_color(roller, lv_color_hex3(0x0f0), 0);
39 lv_obj_set_style_bg_grad_color(roller, lv_color_hex3(0xafa), 0);
40 lv_obj_set_style_bg_grad_dir(roller, LV_GRAD_DIR_VER, 0);
41 lv_obj_align(roller, LV_ALIGN_LEFT_MID, 10, 0);
42 lv_obj_add_event_cb(roller, event_handler, LV_EVENT_ALL, NULL);
43 lv_roller_set_selected(roller, 2, LV_ANIM_OFF);
44
45 /*A roller on the middle with center aligned text, and auto (default) width*/
46 roller = lv_roller_create(lv_screen_active());
47 lv_roller_set_options(roller, opts, LV_ROLLER_MODE_NORMAL);
48 lv_roller_set_visible_row_count(roller, 3);
49 lv_obj_add_style(roller, &style_sel, LV_PART_SELECTED);
50 lv_obj_align(roller, LV_ALIGN_CENTER, 0, 0);
51 lv_obj_add_event_cb(roller, event_handler, LV_EVENT_ALL, NULL);
52 lv_roller_set_selected(roller, 5, LV_ANIM_OFF);
53
54 /*A roller on the right with right aligned text, and custom width*/
55 roller = lv_roller_create(lv_screen_active());
56 lv_roller_set_options(roller, opts, LV_ROLLER_MODE_NORMAL);
57 lv_roller_set_visible_row_count(roller, 4);
58 lv_obj_set_width(roller, 80);
59 lv_obj_add_style(roller, &style_sel, LV_PART_SELECTED);
60 lv_obj_set_style_text_align(roller, LV_TEXT_ALIGN_RIGHT, 0);
61 lv_obj_align(roller, LV_ALIGN_RIGHT_MID, -10, 0);
62 lv_obj_add_event_cb(roller, event_handler, LV_EVENT_ALL, NULL);
63 lv_roller_set_selected(roller, 8, LV_ANIM_OFF);
64 }
65
66 #endif
67