1 /**
2 * @file lv_demo_flex_layout_view.c
3 *
4 */
5
6 /*********************
7 * INCLUDES
8 *********************/
9
10 #include "lv_demo_flex_layout_main.h"
11
12 #if LV_USE_DEMO_FLEX_LAYOUT
13
14 /*********************
15 * DEFINES
16 *********************/
17
18 /**********************
19 * TYPEDEFS
20 **********************/
21
22 /**********************
23 * STATIC PROTOTYPES
24 **********************/
25
26 static lv_obj_t * btn_create(lv_obj_t * par, const char * str, lv_color_t color);
27 static void obj_child_node_def_style_init(lv_style_t * style);
28 static void obj_child_node_checked_style_init(lv_style_t * style);
29
30 /**********************
31 * STATIC VARIABLES
32 **********************/
33
34 /**********************
35 * MACROS
36 **********************/
37
38 /**********************
39 * GLOBAL FUNCTIONS
40 **********************/
41
view_create(lv_obj_t * par,view_t * ui)42 void view_create(lv_obj_t * par, view_t * ui)
43 {
44 /* layout */
45 lv_obj_set_flex_flow(par, LV_FLEX_FLOW_ROW);
46 lv_obj_set_flex_align(
47 par,
48 LV_FLEX_ALIGN_SPACE_AROUND,
49 LV_FLEX_ALIGN_CENTER,
50 LV_FLEX_ALIGN_SPACE_AROUND
51 );
52
53 /* style */
54 obj_child_node_def_style_init(&ui->obj_def_style);
55 obj_child_node_checked_style_init(&ui->obj_checked_style);
56
57 /* root */
58 ui->root = obj_child_node_create(par, ui);
59 lv_obj_set_size(ui->root, lv_pct(50), lv_pct(80));
60
61 /* main ctrl_pad */
62 lv_obj_t * obj = lv_obj_create(par);
63 lv_obj_set_size(obj, lv_pct(40), lv_pct(80));
64 lv_obj_set_style_pad_all(obj, 0, 0);
65 lv_obj_set_style_pad_gap(obj, 0, 0);
66 lv_obj_set_style_radius(obj, 10, 0);
67 lv_obj_set_style_clip_corner(obj, true, 0);
68 lv_obj_set_style_border_width(obj, 0, 0);
69 lv_obj_set_style_shadow_color(obj, lv_color_hex3(0xaaa), 0);
70 lv_obj_set_style_shadow_width(obj, 20, 0);
71 lv_obj_set_style_shadow_offset_y(obj, 2, 0);
72 lv_obj_remove_flag(obj, LV_OBJ_FLAG_SCROLLABLE);
73 lv_obj_set_flex_flow(obj, LV_FLEX_FLOW_COLUMN);
74 lv_obj_set_flex_align(
75 obj,
76 LV_FLEX_ALIGN_CENTER,
77 LV_FLEX_ALIGN_CENTER,
78 LV_FLEX_ALIGN_CENTER
79 );
80 ui->ctrl_pad.cont = obj;
81
82 /* tabview */
83 view_ctrl_pad_create(ui->ctrl_pad.cont, ui);
84
85 /* btn_cont */
86 obj = lv_obj_create(ui->ctrl_pad.cont);
87 lv_obj_remove_style_all(obj);
88 lv_obj_set_style_border_width(obj, 2, 0);
89 lv_obj_set_style_border_color(obj, lv_palette_lighten(LV_PALETTE_GREY, 2), 0);
90 lv_obj_set_style_border_side(obj, LV_BORDER_SIDE_TOP, 0);
91 lv_obj_set_size(obj, LV_PCT(100), LV_SIZE_CONTENT);
92 lv_obj_set_style_pad_ver(obj, 16, 0);
93 lv_obj_set_flex_flow(obj, LV_FLEX_FLOW_ROW);
94 lv_obj_set_flex_align(
95 obj,
96 LV_FLEX_ALIGN_SPACE_AROUND,
97 LV_FLEX_ALIGN_CENTER,
98 LV_FLEX_ALIGN_CENTER
99 );
100 ui->ctrl_pad.btn.cont = obj;
101 ui->ctrl_pad.btn.add = btn_create(obj, "Add", lv_palette_main(LV_PALETTE_BLUE_GREY));
102 ui->ctrl_pad.btn.remove = btn_create(obj, "Remove", lv_palette_main(LV_PALETTE_RED));
103
104 lv_obj_send_event(ui->root, LV_EVENT_CLICKED, NULL); /*Make it active by default*/
105
106 /* fade effect */
107 lv_obj_fade_in(ui->root, 600, 0);
108 lv_obj_fade_in(ui->ctrl_pad.cont, 600, 300);
109 }
110
111 /**********************
112 * STATIC FUNCTIONS
113 **********************/
114
btn_create(lv_obj_t * par,const char * str,lv_color_t color)115 static lv_obj_t * btn_create(lv_obj_t * par, const char * str, lv_color_t color)
116 {
117 lv_obj_t * btn = lv_button_create(par);
118 lv_obj_set_width(btn, lv_pct(30));
119 lv_obj_set_height(btn, 30);
120 lv_obj_set_style_border_width(btn, 0, LV_PART_MAIN);
121 lv_obj_set_style_bg_color(btn, color, LV_PART_MAIN);
122 lv_obj_set_style_radius(btn, 5, LV_PART_MAIN);
123
124 lv_obj_t * label = lv_label_create(btn);
125 lv_label_set_text(label, str);
126 lv_obj_center(label);
127
128 return btn;
129 }
130
obj_child_node_def_style_init(lv_style_t * style)131 static void obj_child_node_def_style_init(lv_style_t * style)
132 {
133 lv_style_init(style);
134 lv_style_set_size(style, LV_PCT(45), LV_PCT(45));
135 lv_style_set_flex_flow(style, LV_FLEX_FLOW_ROW);
136 lv_style_set_layout(style, LV_LAYOUT_FLEX);
137 lv_style_set_radius(style, 0);
138 }
139
obj_child_node_checked_style_init(lv_style_t * style)140 static void obj_child_node_checked_style_init(lv_style_t * style)
141 {
142 lv_style_init(style);
143 lv_style_set_border_color(style, lv_palette_main(LV_PALETTE_BLUE));
144 lv_style_set_shadow_color(style, lv_palette_main(LV_PALETTE_GREY));
145 lv_style_set_shadow_width(style, 20);
146
147 static lv_style_transition_dsc_t tran;
148 static const lv_style_prop_t prop[] = {
149 LV_STYLE_SHADOW_OPA,
150 LV_STYLE_BORDER_COLOR,
151 LV_STYLE_PROP_INV
152 };
153 lv_style_transition_dsc_init(&tran, prop, lv_anim_path_ease_out, 300, 0, NULL);
154 lv_style_set_transition(style, &tran);
155 }
156
157 #endif
158