1 #include "../../lv_examples.h"
2 #if LV_USE_TABLE && LV_BUILD_EXAMPLES
3
4 #define ITEM_CNT 200
5
draw_event_cb(lv_event_t * e)6 static void draw_event_cb(lv_event_t * e)
7 {
8 lv_obj_t * obj = lv_event_get_target(e);
9 lv_obj_draw_part_dsc_t * dsc = lv_event_get_draw_part_dsc(e);
10 /*If the cells are drawn...*/
11 if(dsc->part == LV_PART_ITEMS) {
12 bool chk = lv_table_has_cell_ctrl(obj, dsc->id, 0, LV_TABLE_CELL_CTRL_CUSTOM_1);
13
14 lv_draw_rect_dsc_t rect_dsc;
15 lv_draw_rect_dsc_init(&rect_dsc);
16 rect_dsc.bg_color = chk ? lv_theme_get_color_primary(obj) : lv_palette_lighten(LV_PALETTE_GREY, 2);
17 rect_dsc.radius = LV_RADIUS_CIRCLE;
18
19 lv_area_t sw_area;
20 sw_area.x1 = dsc->draw_area->x2 - 50;
21 sw_area.x2 = sw_area.x1 + 40;
22 sw_area.y1 = dsc->draw_area->y1 + lv_area_get_height(dsc->draw_area) / 2 - 10;
23 sw_area.y2 = sw_area.y1 + 20;
24 lv_draw_rect(dsc->draw_ctx, &rect_dsc, &sw_area);
25
26 rect_dsc.bg_color = lv_color_white();
27 if(chk) {
28 sw_area.x2 -= 2;
29 sw_area.x1 = sw_area.x2 - 16;
30 }
31 else {
32 sw_area.x1 += 2;
33 sw_area.x2 = sw_area.x1 + 16;
34 }
35 sw_area.y1 += 2;
36 sw_area.y2 -= 2;
37 lv_draw_rect(dsc->draw_ctx, &rect_dsc, &sw_area);
38 }
39 }
40
change_event_cb(lv_event_t * e)41 static void change_event_cb(lv_event_t * e)
42 {
43 lv_obj_t * obj = lv_event_get_target(e);
44 uint16_t col;
45 uint16_t row;
46 lv_table_get_selected_cell(obj, &row, &col);
47 bool chk = lv_table_has_cell_ctrl(obj, row, 0, LV_TABLE_CELL_CTRL_CUSTOM_1);
48 if(chk) lv_table_clear_cell_ctrl(obj, row, 0, LV_TABLE_CELL_CTRL_CUSTOM_1);
49 else lv_table_add_cell_ctrl(obj, row, 0, LV_TABLE_CELL_CTRL_CUSTOM_1);
50 }
51
52 /**
53 * A very light-weighted list created from table
54 */
lv_example_table_2(void)55 void lv_example_table_2(void)
56 {
57 /*Measure memory usage*/
58 lv_mem_monitor_t mon1;
59 lv_mem_monitor(&mon1);
60
61 uint32_t t = lv_tick_get();
62
63 lv_obj_t * table = lv_table_create(lv_scr_act());
64
65 /*Set a smaller height to the table. It'll make it scrollable*/
66 lv_obj_set_size(table, LV_SIZE_CONTENT, 200);
67
68 lv_table_set_col_width(table, 0, 150);
69 lv_table_set_row_cnt(table, ITEM_CNT); /*Not required but avoids a lot of memory reallocation lv_table_set_set_value*/
70 lv_table_set_col_cnt(table, 1);
71
72 /*Don't make the cell pressed, we will draw something different in the event*/
73 lv_obj_remove_style(table, NULL, LV_PART_ITEMS | LV_STATE_PRESSED);
74
75 uint32_t i;
76 for(i = 0; i < ITEM_CNT; i++) {
77 lv_table_set_cell_value_fmt(table, i, 0, "Item %"LV_PRIu32, i + 1);
78 }
79
80 lv_obj_align(table, LV_ALIGN_CENTER, 0, -20);
81
82 /*Add an event callback to to apply some custom drawing*/
83 lv_obj_add_event_cb(table, draw_event_cb, LV_EVENT_DRAW_PART_END, NULL);
84 lv_obj_add_event_cb(table, change_event_cb, LV_EVENT_VALUE_CHANGED, NULL);
85
86 lv_mem_monitor_t mon2;
87 lv_mem_monitor(&mon2);
88
89 uint32_t mem_used = mon1.free_size - mon2.free_size;
90
91 uint32_t elaps = lv_tick_elaps(t);
92
93 lv_obj_t * label = lv_label_create(lv_scr_act());
94 lv_label_set_text_fmt(label, "%"LV_PRIu32" items were created in %"LV_PRIu32" ms\n"
95 "using %"LV_PRIu32" bytes of memory",
96 ITEM_CNT, elaps, mem_used);
97
98 lv_obj_align(label, LV_ALIGN_BOTTOM_MID, 0, -10);
99
100 }
101
102 #endif
103