lv_test_theme.c 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692
  1. /**
  2. * @file lv_demo_widgets.c
  3. *
  4. */
  5. /*********************
  6. * INCLUDES
  7. *********************/
  8. #include "../lvgl/lvgl.h"
  9. /*********************
  10. * DEFINES
  11. *********************/
  12. /**********************
  13. * TYPEDEFS
  14. **********************/
  15. /**********************
  16. * STATIC PROTOTYPES
  17. **********************/
  18. static void controls_create(lv_obj_t * parent);
  19. static void visuals_create(lv_obj_t * parent);
  20. static void selectors_create(lv_obj_t * parent);
  21. static void slider_event_cb(lv_obj_t * slider, lv_event_t e);
  22. static void ta_event_cb(lv_obj_t * ta, lv_event_t e);
  23. static void kb_event_cb(lv_obj_t * ta, lv_event_t e);
  24. static void bar_anim(lv_task_t * t);
  25. static void arc_anim(lv_obj_t * arc, lv_anim_value_t value);
  26. static void linemeter_anim(lv_obj_t * linemeter, lv_anim_value_t value);
  27. static void gauge_anim(lv_obj_t * gauge, lv_anim_value_t value);
  28. static void table_event_cb(lv_obj_t * table, lv_event_t e);
  29. #if LV_USE_THEME_MATERIAL
  30. static void color_chg_event_cb(lv_obj_t * sw, lv_event_t e);
  31. #endif
  32. #if LV_DEMO_WIDGETS_SLIDESHOW
  33. static void tab_content_anim_create(lv_obj_t * parent);
  34. static void tab_changer_task_cb(lv_task_t * task);
  35. #endif
  36. /**********************
  37. * STATIC VARIABLES
  38. **********************/
  39. static lv_obj_t * tv;
  40. static lv_obj_t * t1;
  41. static lv_obj_t * t2;
  42. static lv_obj_t * t3;
  43. static lv_obj_t * kb;
  44. static lv_style_t style_box;
  45. /**********************
  46. * MACROS
  47. **********************/
  48. /**********************
  49. * GLOBAL FUNCTIONS
  50. **********************/
  51. void lv_demo_widgets(void)
  52. {
  53. tv = lv_tabview_create(lv_scr_act(), NULL);
  54. t1 = lv_tabview_add_tab(tv, "Controls");
  55. t2 = lv_tabview_add_tab(tv, "Visuals");
  56. t3 = lv_tabview_add_tab(tv, "Selectors");
  57. lv_style_init(&style_box);
  58. lv_style_set_value_align(&style_box, LV_STATE_DEFAULT, LV_ALIGN_OUT_TOP_LEFT);
  59. lv_style_set_value_ofs_y(&style_box, LV_STATE_DEFAULT, - LV_DPX(10));
  60. lv_style_set_margin_top(&style_box, LV_STATE_DEFAULT, LV_DPX(30));
  61. controls_create(t1);
  62. // visuals_create(t2);
  63. // selectors_create(t3);
  64. }
  65. /**********************
  66. * STATIC FUNCTIONS
  67. **********************/
  68. static void controls_create(lv_obj_t * parent)
  69. {
  70. lv_page_set_scrl_layout(parent, LV_LAYOUT_PRETTY_TOP);
  71. lv_disp_size_t disp_size = lv_disp_get_size_category(NULL);
  72. lv_coord_t grid_w = lv_page_get_width_grid(parent, disp_size <= LV_DISP_SIZE_SMALL ? 1 : 2, 1);
  73. #if LV_DEMO_WIDGETS_SLIDESHOW == 0
  74. static const char * btns[] = {"Cancel", "Ok", ""};
  75. lv_obj_t * m = lv_msgbox_create(lv_scr_act(), NULL);
  76. lv_msgbox_add_btns(m, btns);
  77. lv_obj_t * btnm = lv_msgbox_get_btnmatrix(m);
  78. lv_btnmatrix_set_btn_ctrl(btnm, 1, LV_BTNMATRIX_CTRL_CHECK_STATE);
  79. #endif
  80. lv_obj_t * h = lv_cont_create(parent, NULL);
  81. lv_cont_set_layout(h, LV_LAYOUT_PRETTY_MID);
  82. lv_obj_add_style(h, LV_CONT_PART_MAIN, &style_box);
  83. lv_obj_set_drag_parent(h, true);
  84. lv_obj_set_style_local_value_str(h, LV_CONT_PART_MAIN, LV_STATE_DEFAULT, "Basics");
  85. lv_cont_set_fit2(h, LV_FIT_NONE, LV_FIT_TIGHT);
  86. lv_obj_set_width(h, grid_w);
  87. lv_obj_t * btn = lv_btn_create(h, NULL);
  88. lv_btn_set_fit2(btn, LV_FIT_NONE, LV_FIT_TIGHT);
  89. lv_obj_set_width(btn, lv_obj_get_width_grid(h, disp_size <= LV_DISP_SIZE_SMALL ? 1 : 2, 1));
  90. lv_obj_t * label = lv_label_create(btn, NULL);
  91. lv_label_set_text(label ,"Button");
  92. btn = lv_btn_create(h, btn);
  93. lv_btn_toggle(btn);
  94. label = lv_label_create(btn, NULL);
  95. lv_label_set_text(label ,"Button");
  96. lv_switch_create(h, NULL);
  97. lv_checkbox_create(h, NULL);
  98. lv_coord_t fit_w = lv_obj_get_width_fit(h);
  99. lv_obj_t * slider = lv_slider_create(h, NULL);
  100. lv_slider_set_value(slider, 40, LV_ANIM_OFF);
  101. lv_obj_set_event_cb(slider, slider_event_cb);
  102. lv_obj_set_width_margin(slider, fit_w);
  103. /*Use the knobs style value the display the current value in focused state*/
  104. lv_obj_set_style_local_margin_top(slider, LV_SLIDER_PART_BG, LV_STATE_DEFAULT, LV_DPX(25));
  105. lv_obj_set_style_local_value_font(slider, LV_SLIDER_PART_KNOB, LV_STATE_DEFAULT, lv_theme_get_font_small());
  106. lv_obj_set_style_local_value_ofs_y(slider, LV_SLIDER_PART_KNOB, LV_STATE_FOCUSED, - LV_DPX(25));
  107. lv_obj_set_style_local_value_opa(slider, LV_SLIDER_PART_KNOB, LV_STATE_DEFAULT, LV_OPA_TRANSP);
  108. lv_obj_set_style_local_value_opa(slider, LV_SLIDER_PART_KNOB, LV_STATE_FOCUSED, LV_OPA_COVER);
  109. lv_obj_set_style_local_transition_time(slider, LV_SLIDER_PART_KNOB, LV_STATE_DEFAULT, 300);
  110. lv_obj_set_style_local_transition_prop_5(slider, LV_SLIDER_PART_KNOB, LV_STATE_DEFAULT, LV_STYLE_VALUE_OFS_Y);
  111. lv_obj_set_style_local_transition_prop_6(slider, LV_SLIDER_PART_KNOB, LV_STATE_DEFAULT, LV_STYLE_VALUE_OPA);
  112. slider = lv_slider_create(h, slider);
  113. lv_slider_set_type(slider, LV_SLIDER_TYPE_RANGE);
  114. lv_slider_set_value(slider, 70, LV_ANIM_OFF);
  115. lv_slider_set_left_value(slider, 30, LV_ANIM_OFF);
  116. lv_obj_set_style_local_value_ofs_y(slider, LV_SLIDER_PART_INDIC, LV_STATE_DEFAULT, - LV_DPX(25));
  117. lv_obj_set_style_local_value_font(slider, LV_SLIDER_PART_INDIC, LV_STATE_DEFAULT, lv_theme_get_font_small());
  118. lv_obj_set_style_local_value_opa(slider, LV_SLIDER_PART_INDIC, LV_STATE_DEFAULT, LV_OPA_COVER);
  119. lv_obj_set_event_cb(slider, slider_event_cb);
  120. lv_event_send(slider, LV_EVENT_VALUE_CHANGED, NULL); /*To refresh the text*/
  121. if(lv_obj_get_width(slider) > fit_w) lv_obj_set_width(slider, fit_w);
  122. h = lv_cont_create(parent, h);
  123. lv_cont_set_fit(h, LV_FIT_NONE);
  124. lv_obj_set_style_local_value_str(h, LV_CONT_PART_MAIN, LV_STATE_DEFAULT, "Text input");
  125. lv_obj_t * ta = lv_textarea_create(h, NULL);
  126. lv_cont_set_fit2(ta, LV_FIT_PARENT, LV_FIT_NONE);
  127. lv_textarea_set_text(ta, "");
  128. lv_textarea_set_placeholder_text(ta, "E-mail address");
  129. lv_textarea_set_one_line(ta, true);
  130. lv_textarea_set_cursor_hidden(ta, true);
  131. lv_obj_set_event_cb(ta, ta_event_cb);
  132. ta = lv_textarea_create(h, ta);
  133. lv_textarea_set_pwd_mode(ta, true);
  134. lv_textarea_set_placeholder_text(ta, "Password");
  135. ta = lv_textarea_create(h, NULL);
  136. lv_cont_set_fit2(ta, LV_FIT_PARENT, LV_FIT_NONE);
  137. lv_textarea_set_text(ta, "");
  138. lv_textarea_set_placeholder_text(ta, "Message");
  139. lv_textarea_set_cursor_hidden(ta, true);
  140. lv_obj_set_event_cb(ta, ta_event_cb);
  141. lv_cont_set_fit4(ta, LV_FIT_PARENT, LV_FIT_PARENT, LV_FIT_NONE, LV_FIT_PARENT);
  142. #if LV_DEMO_WIDGETS_SLIDESHOW
  143. tab_content_anim_create(parent);
  144. #endif
  145. }
  146. static void visuals_create(lv_obj_t * parent)
  147. {
  148. lv_page_set_scrl_layout(parent, LV_LAYOUT_PRETTY_TOP);
  149. lv_disp_size_t disp_size = lv_disp_get_size_category(NULL);
  150. lv_coord_t grid_h_chart = lv_page_get_height_grid(parent, 1, 1);
  151. lv_coord_t grid_w_chart = lv_page_get_width_grid(parent, disp_size <= LV_DISP_SIZE_LARGE ? 1 : 2, 1);
  152. lv_obj_t * chart = lv_chart_create(parent, NULL);
  153. lv_obj_add_style(chart, LV_CHART_PART_BG, &style_box);
  154. if(disp_size <= LV_DISP_SIZE_SMALL) {
  155. lv_obj_set_style_local_text_font(chart, LV_CHART_PART_SERIES_BG, LV_STATE_DEFAULT, lv_theme_get_font_small());
  156. }
  157. lv_obj_set_drag_parent(chart, true);
  158. lv_obj_set_style_local_value_str(chart, LV_CONT_PART_MAIN, LV_STATE_DEFAULT, "Line chart");
  159. lv_obj_set_width_margin(chart, grid_w_chart);
  160. lv_obj_set_height_margin(chart, grid_h_chart);
  161. lv_chart_set_div_line_count(chart, 3, 0);
  162. lv_chart_set_point_count(chart, 8);
  163. lv_chart_set_type(chart, LV_CHART_TYPE_LINE);
  164. if(disp_size > LV_DISP_SIZE_SMALL) {
  165. lv_obj_set_style_local_pad_left(chart, LV_CHART_PART_BG, LV_STATE_DEFAULT, 4 * (LV_DPI / 10));
  166. lv_obj_set_style_local_pad_bottom(chart, LV_CHART_PART_BG, LV_STATE_DEFAULT, 3 * (LV_DPI / 10));
  167. lv_obj_set_style_local_pad_right(chart, LV_CHART_PART_BG, LV_STATE_DEFAULT, 2 * (LV_DPI / 10));
  168. lv_obj_set_style_local_pad_top(chart, LV_CHART_PART_BG, LV_STATE_DEFAULT, 2 * (LV_DPI / 10));
  169. lv_chart_set_y_tick_length(chart, 0, 0);
  170. lv_chart_set_x_tick_length(chart, 0, 0);
  171. lv_chart_set_y_tick_texts(chart, "600\n500\n400\n300\n200", 0, LV_CHART_AXIS_DRAW_LAST_TICK);
  172. lv_chart_set_x_tick_texts(chart, "Jan\nFeb\nMar\nApr\nMay\nJun\nJul\nAug", 0, LV_CHART_AXIS_DRAW_LAST_TICK);
  173. }
  174. lv_chart_series_t * s1 = lv_chart_add_series(chart, LV_THEME_DEFAULT_COLOR_PRIMARY);
  175. lv_chart_series_t * s2 = lv_chart_add_series(chart, LV_THEME_DEFAULT_COLOR_SECONDARY);
  176. lv_chart_set_next(chart, s1, 10);
  177. lv_chart_set_next(chart, s1, 90);
  178. lv_chart_set_next(chart, s1, 30);
  179. lv_chart_set_next(chart, s1, 60);
  180. lv_chart_set_next(chart, s1, 10);
  181. lv_chart_set_next(chart, s1, 90);
  182. lv_chart_set_next(chart, s1, 30);
  183. lv_chart_set_next(chart, s1, 60);
  184. lv_chart_set_next(chart, s1, 10);
  185. lv_chart_set_next(chart, s1, 90);
  186. lv_chart_set_next(chart, s2, 32);
  187. lv_chart_set_next(chart, s2, 66);
  188. lv_chart_set_next(chart, s2, 5);
  189. lv_chart_set_next(chart, s2, 47);
  190. lv_chart_set_next(chart, s2, 32);
  191. lv_chart_set_next(chart, s2, 32);
  192. lv_chart_set_next(chart, s2, 66);
  193. lv_chart_set_next(chart, s2, 5);
  194. lv_chart_set_next(chart, s2, 47);
  195. lv_chart_set_next(chart, s2, 66);
  196. lv_chart_set_next(chart, s2, 5);
  197. lv_chart_set_next(chart, s2, 47);
  198. lv_obj_t * chart2 = lv_chart_create(parent, chart);
  199. lv_chart_set_type(chart2, LV_CHART_TYPE_COLUMN);
  200. lv_obj_set_style_local_value_str(chart2, LV_CONT_PART_MAIN, LV_STATE_DEFAULT, "Column chart");
  201. s1 = lv_chart_add_series(chart2, LV_THEME_DEFAULT_COLOR_PRIMARY);
  202. s2 = lv_chart_add_series(chart2, LV_THEME_DEFAULT_COLOR_SECONDARY);
  203. lv_chart_set_next(chart2, s1, 10);
  204. lv_chart_set_next(chart2, s1, 90);
  205. lv_chart_set_next(chart2, s1, 30);
  206. lv_chart_set_next(chart2, s1, 60);
  207. lv_chart_set_next(chart2, s1, 10);
  208. lv_chart_set_next(chart2, s1, 90);
  209. lv_chart_set_next(chart2, s1, 30);
  210. lv_chart_set_next(chart2, s1, 60);
  211. lv_chart_set_next(chart2, s1, 10);
  212. lv_chart_set_next(chart2, s1, 90);
  213. lv_chart_set_next(chart2, s2, 32);
  214. lv_chart_set_next(chart2, s2, 66);
  215. lv_chart_set_next(chart2, s2, 5);
  216. lv_chart_set_next(chart2, s2, 47);
  217. lv_chart_set_next(chart2, s2, 32);
  218. lv_chart_set_next(chart2, s2, 32);
  219. lv_chart_set_next(chart2, s2, 66);
  220. lv_chart_set_next(chart2, s2, 5);
  221. lv_chart_set_next(chart2, s2, 47);
  222. lv_chart_set_next(chart2, s2, 66);
  223. lv_chart_set_next(chart2, s2, 5);
  224. lv_chart_set_next(chart2, s2, 47);
  225. lv_coord_t grid_w_meter;
  226. if(disp_size <= LV_DISP_SIZE_SMALL) grid_w_meter = lv_page_get_width_grid(parent, 1, 1);
  227. else if(disp_size <= LV_DISP_SIZE_MEDIUM) grid_w_meter = lv_page_get_width_grid(parent, 2, 1);
  228. else grid_w_meter = lv_page_get_width_grid(parent, 3, 1);
  229. lv_coord_t meter_h = lv_page_get_height_fit(parent);
  230. lv_coord_t meter_size = LV_MATH_MIN(grid_w_meter, meter_h);
  231. lv_obj_t * lmeter = lv_linemeter_create(parent, NULL);
  232. lv_obj_set_drag_parent(lmeter, true);
  233. lv_linemeter_set_value(lmeter, 50);
  234. lv_obj_set_size(lmeter, meter_size, meter_size);
  235. lv_obj_add_style(lmeter, LV_LINEMETER_PART_MAIN, &style_box);
  236. lv_obj_set_style_local_value_str(lmeter, LV_LINEMETER_PART_MAIN, LV_STATE_DEFAULT, "Line meter");
  237. lv_obj_t * label = lv_label_create(lmeter, NULL);
  238. lv_obj_align(label, lmeter, LV_ALIGN_CENTER, 0, 0);
  239. lv_obj_set_style_local_text_font(label, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, lv_theme_get_font_title());
  240. lv_anim_t a;
  241. lv_anim_init(&a);
  242. lv_anim_set_var(&a, lmeter);
  243. lv_anim_set_exec_cb(&a, (lv_anim_exec_xcb_t)linemeter_anim);
  244. lv_anim_set_values(&a, 0, 100);
  245. lv_anim_set_time(&a, 4000);
  246. lv_anim_set_playback_time(&a, 1000);
  247. lv_anim_set_repeat_count(&a, LV_ANIM_REPEAT_INFINITE);
  248. lv_anim_start(&a);
  249. lv_obj_t * gauge = lv_gauge_create(parent, NULL);
  250. lv_obj_set_drag_parent(gauge, true);
  251. lv_obj_set_size(gauge, meter_size, meter_size);
  252. lv_obj_add_style(gauge, LV_GAUGE_PART_MAIN, &style_box);
  253. lv_obj_set_style_local_value_str(gauge, LV_GAUGE_PART_MAIN, LV_STATE_DEFAULT, "Gauge");
  254. label = lv_label_create(gauge, label);
  255. lv_obj_align(label, gauge, LV_ALIGN_CENTER, 0, grid_w_meter / 3);
  256. lv_anim_set_var(&a, gauge);
  257. lv_anim_set_exec_cb(&a, (lv_anim_exec_xcb_t)gauge_anim);
  258. lv_anim_start(&a);
  259. lv_obj_t * arc = lv_arc_create(parent, NULL);
  260. lv_obj_set_drag_parent(arc, true);
  261. lv_arc_set_bg_angles(arc, 0, 360);
  262. lv_arc_set_rotation(arc, 270);
  263. lv_arc_set_angles(arc, 0, 0);
  264. lv_obj_set_size(arc, meter_size, meter_size);
  265. lv_obj_add_style(arc, LV_ARC_PART_BG, &style_box);
  266. lv_obj_set_style_local_value_str(arc, LV_ARC_PART_BG, LV_STATE_DEFAULT, "Arc");
  267. label = lv_label_create(arc, label);
  268. lv_obj_align(label, arc, LV_ALIGN_CENTER, 0, 0);
  269. lv_anim_set_var(&a, arc);
  270. lv_anim_set_exec_cb(&a, (lv_anim_exec_xcb_t)arc_anim);
  271. lv_anim_set_values(&a, 0, 360);
  272. lv_anim_set_repeat_count(&a, LV_ANIM_REPEAT_INFINITE);
  273. lv_anim_start(&a);
  274. /*Create a bar and use the backgrounds value style property to display the current value*/
  275. lv_obj_t * bar_h = lv_cont_create(parent, NULL);
  276. lv_cont_set_fit2(bar_h, LV_FIT_NONE, LV_FIT_TIGHT);
  277. lv_obj_add_style(bar_h, LV_CONT_PART_MAIN, &style_box);
  278. lv_obj_set_style_local_value_str(bar_h, LV_CONT_PART_MAIN, LV_STATE_DEFAULT, "Bar");
  279. if(disp_size <= LV_DISP_SIZE_SMALL) lv_obj_set_width(bar_h, lv_page_get_width_grid(parent, 1, 1));
  280. else if(disp_size <= LV_DISP_SIZE_MEDIUM) lv_obj_set_width(bar_h, lv_page_get_width_grid(parent, 2, 1));
  281. else lv_obj_set_width(bar_h, lv_page_get_width_grid(parent, 3, 2));
  282. lv_obj_t * bar = lv_bar_create(bar_h, NULL);
  283. lv_obj_set_width(bar, lv_obj_get_width_fit(bar_h));
  284. lv_obj_set_style_local_value_font(bar, LV_BAR_PART_BG, LV_STATE_DEFAULT, lv_theme_get_font_small());
  285. lv_obj_set_style_local_value_align(bar, LV_BAR_PART_BG, LV_STATE_DEFAULT, LV_ALIGN_OUT_BOTTOM_MID);
  286. lv_obj_set_style_local_value_ofs_y(bar, LV_BAR_PART_BG, LV_STATE_DEFAULT, LV_DPI / 20);
  287. lv_obj_set_style_local_margin_bottom(bar, LV_BAR_PART_BG, LV_STATE_DEFAULT, LV_DPI / 7);
  288. lv_obj_align(bar, NULL, LV_ALIGN_CENTER, 0, 0);
  289. lv_obj_t * led_h = lv_cont_create(parent, NULL);
  290. lv_cont_set_layout(led_h, LV_LAYOUT_PRETTY_MID);
  291. if(disp_size <= LV_DISP_SIZE_SMALL) lv_obj_set_width(led_h, lv_page_get_width_grid(parent, 1, 1));
  292. else if(disp_size <= LV_DISP_SIZE_MEDIUM) lv_obj_set_width(led_h, lv_page_get_width_grid(parent, 2, 1));
  293. else lv_obj_set_width(led_h, lv_page_get_width_grid(parent, 3, 1));
  294. lv_obj_set_height(led_h, lv_obj_get_height(bar_h));
  295. lv_obj_add_style(led_h, LV_CONT_PART_MAIN, &style_box);
  296. lv_obj_set_drag_parent(led_h, true);
  297. lv_obj_set_style_local_value_str(led_h, LV_CONT_PART_MAIN, LV_STATE_DEFAULT, "LEDs");
  298. lv_obj_t * led = lv_led_create(led_h, NULL);
  299. lv_coord_t led_size = lv_obj_get_height_fit(led_h);
  300. lv_obj_set_size(led, led_size, led_size);
  301. lv_led_off(led);
  302. led = lv_led_create(led_h, led);
  303. lv_led_set_bright(led, (LV_LED_BRIGHT_MAX - LV_LED_BRIGHT_MIN) / 2 + LV_LED_BRIGHT_MIN);
  304. led = lv_led_create(led_h, led);
  305. lv_led_on(led);
  306. if(disp_size == LV_DISP_SIZE_MEDIUM) {
  307. lv_obj_add_protect(led_h, LV_PROTECT_POS);
  308. lv_obj_align(led_h, bar_h, LV_ALIGN_OUT_BOTTOM_MID, 0, lv_obj_get_style_margin_top(led_h, LV_OBJ_PART_MAIN) + lv_obj_get_style_pad_inner(parent, LV_PAGE_PART_SCROLLABLE));
  309. }
  310. lv_task_create(bar_anim, 100, LV_TASK_PRIO_LOW, bar);
  311. }
  312. static void selectors_create(lv_obj_t * parent)
  313. {
  314. lv_page_set_scrl_layout(parent, LV_LAYOUT_PRETTY_MID);
  315. lv_disp_size_t disp_size = lv_disp_get_size_category(NULL);
  316. lv_coord_t grid_h = lv_page_get_height_grid(parent, 1, 1);
  317. lv_coord_t grid_w;
  318. if(disp_size <= LV_DISP_SIZE_SMALL) grid_w = lv_page_get_width_grid(parent, 1, 1);
  319. else grid_w = lv_page_get_width_grid(parent, 2, 1);
  320. lv_obj_t * cal = lv_calendar_create(parent, NULL);
  321. lv_obj_set_drag_parent(cal, true);
  322. if(disp_size > LV_DISP_SIZE_MEDIUM) {
  323. lv_obj_set_size(cal, LV_MATH_MIN(grid_h, grid_w), LV_MATH_MIN(grid_h, grid_w));
  324. } else {
  325. lv_obj_set_size(cal, grid_w, grid_w);
  326. if(disp_size <= LV_DISP_SIZE_SMALL) {
  327. lv_obj_set_style_local_text_font(cal, LV_CALENDAR_PART_BG, LV_STATE_DEFAULT, lv_theme_get_font_small());
  328. }
  329. }
  330. static lv_calendar_date_t hl[] = {
  331. {.year = 2020, .month = 1, .day = 5},
  332. {.year = 2020, .month = 1, .day = 9},
  333. };
  334. lv_obj_t * btn;
  335. lv_obj_t * h = lv_cont_create(parent, NULL);
  336. lv_obj_set_drag_parent(h, true);
  337. if(disp_size <= LV_DISP_SIZE_SMALL) {
  338. lv_cont_set_fit2(h, LV_FIT_NONE, LV_FIT_TIGHT);
  339. lv_obj_set_width(h, lv_page_get_width_fit(parent));
  340. lv_cont_set_layout(h, LV_LAYOUT_COLUMN_MID);
  341. } else if(disp_size <= LV_DISP_SIZE_MEDIUM) {
  342. lv_obj_set_size(h, lv_obj_get_width(cal), lv_obj_get_height(cal));
  343. lv_cont_set_layout(h, LV_LAYOUT_PRETTY_TOP);
  344. } else {
  345. lv_obj_set_click(h, false);
  346. lv_obj_set_style_local_bg_opa(h, LV_CONT_PART_MAIN, LV_STATE_DEFAULT, LV_OPA_TRANSP);
  347. lv_obj_set_style_local_border_opa(h, LV_CONT_PART_MAIN, LV_STATE_DEFAULT, LV_OPA_TRANSP);
  348. lv_obj_set_style_local_pad_left(h, LV_CONT_PART_MAIN, LV_STATE_DEFAULT, 0);
  349. lv_obj_set_style_local_pad_right(h, LV_CONT_PART_MAIN, LV_STATE_DEFAULT, 0);
  350. lv_obj_set_style_local_pad_top(h, LV_CONT_PART_MAIN, LV_STATE_DEFAULT, 0);
  351. lv_obj_set_size(h, LV_MATH_MIN(grid_h, grid_w), LV_MATH_MIN(grid_h, grid_w));
  352. lv_cont_set_layout(h, LV_LAYOUT_PRETTY_TOP);
  353. }
  354. lv_obj_t * roller = lv_roller_create(h, NULL);
  355. lv_obj_add_style(roller, LV_CONT_PART_MAIN, &style_box);
  356. lv_obj_set_style_local_value_str(roller, LV_CONT_PART_MAIN, LV_STATE_DEFAULT, "Roller");
  357. lv_roller_set_auto_fit(roller, false);
  358. lv_roller_set_align(roller, LV_LABEL_ALIGN_CENTER);
  359. lv_roller_set_visible_row_count(roller, 4);
  360. lv_obj_set_width(roller, lv_obj_get_width_grid(h, disp_size <= LV_DISP_SIZE_SMALL ? 1 : 2, 1));
  361. lv_obj_t * dd = lv_dropdown_create(h, NULL);
  362. lv_obj_add_style(dd, LV_CONT_PART_MAIN, &style_box);
  363. lv_obj_set_style_local_value_str(dd, LV_CONT_PART_MAIN, LV_STATE_DEFAULT, "Dropdown");
  364. lv_obj_set_width(dd, lv_obj_get_width_grid(h, disp_size <= LV_DISP_SIZE_SMALL ? 1 : 2, 1));
  365. lv_dropdown_set_options(dd, "Alpha\nBravo\nCharlie\nDelta\nEcho\nFoxtrot\nGolf\nHotel\nIndia\nJuliette\nKilo\nLima\nMike\nNovember\n"
  366. "Oscar\nPapa\nQuebec\nRomeo\nSierra\nTango\nUniform\nVictor\nWhiskey\nXray\nYankee\nZulu");
  367. lv_obj_t * list = lv_list_create(parent, NULL);
  368. lv_list_set_scroll_propagation(list, true);
  369. lv_obj_set_size(list, grid_w, grid_h);
  370. const char * txts[] = {LV_SYMBOL_SAVE, "Save", LV_SYMBOL_CUT, "Cut", LV_SYMBOL_COPY, "Copy",
  371. LV_SYMBOL_OK, "This is a quite long text to scroll on the list", LV_SYMBOL_EDIT, "Edit", LV_SYMBOL_WIFI, "Wifi",
  372. LV_SYMBOL_BLUETOOTH, "Bluetooth", LV_SYMBOL_GPS, "GPS", LV_SYMBOL_USB, "USB",
  373. LV_SYMBOL_SD_CARD, "SD card", LV_SYMBOL_CLOSE, "Close", NULL};
  374. uint32_t i;
  375. for(i = 0; txts[i] != NULL; i += 2) {
  376. btn = lv_list_add_btn(list, txts[i], txts[i + 1]);
  377. lv_btn_set_checkable(btn, true);
  378. /*Make a button disabled*/
  379. if(i == 4) {
  380. lv_btn_set_state(btn, LV_BTN_STATE_DISABLED);
  381. }
  382. }
  383. lv_calendar_set_highlighted_dates(cal, hl, 2);
  384. static lv_style_t style_cell4;
  385. lv_style_init(&style_cell4);
  386. lv_style_set_bg_opa(&style_cell4, LV_STATE_DEFAULT, LV_OPA_50);
  387. lv_style_set_bg_color(&style_cell4, LV_STATE_DEFAULT, LV_COLOR_GRAY);
  388. lv_obj_t * page = lv_page_create(parent ,NULL);
  389. lv_obj_set_size(page, grid_w, grid_h);
  390. lv_coord_t table_w_max = lv_page_get_width_fit(page);
  391. lv_page_set_scroll_propagation(page, true);
  392. lv_obj_t * table1 = lv_table_create(page, NULL);
  393. lv_obj_add_style(table1, LV_TABLE_PART_CELL4, &style_cell4);
  394. /*Clean the background style of the table because it is placed on a page*/
  395. lv_obj_clean_style_list(table1, LV_TABLE_PART_BG);
  396. lv_obj_set_drag_parent(table1, true);
  397. lv_obj_set_event_cb(table1, table_event_cb);
  398. lv_table_set_col_cnt(table1, disp_size > LV_DISP_SIZE_SMALL ? 3 : 2);
  399. if(disp_size > LV_DISP_SIZE_SMALL) {
  400. lv_table_set_col_width(table1, 0, LV_MATH_MAX(30, 1 * table_w_max / 5));
  401. lv_table_set_col_width(table1, 1, LV_MATH_MAX(60, 2 * table_w_max / 5));
  402. lv_table_set_col_width(table1, 2, LV_MATH_MAX(60, 2 * table_w_max / 5));
  403. } else {
  404. lv_table_set_col_width(table1, 0, LV_MATH_MAX(30, 1 * table_w_max / 4 - 1));
  405. lv_table_set_col_width(table1, 1, LV_MATH_MAX(60, 3 * table_w_max / 4 - 1));
  406. }
  407. lv_table_set_cell_value(table1, 0, 0, "#");
  408. lv_table_set_cell_value(table1, 1, 0, "1");
  409. lv_table_set_cell_value(table1, 2, 0, "2");
  410. lv_table_set_cell_value(table1, 3, 0, "3");
  411. lv_table_set_cell_value(table1, 4, 0, "4");
  412. lv_table_set_cell_value(table1, 5, 0, "5");
  413. lv_table_set_cell_value(table1, 6, 0, "6");
  414. lv_table_set_cell_value(table1, 0, 1, "NAME");
  415. lv_table_set_cell_value(table1, 1, 1, "Mark");
  416. lv_table_set_cell_value(table1, 2, 1, "Jacob");
  417. lv_table_set_cell_value(table1, 3, 1, "John");
  418. lv_table_set_cell_value(table1, 4, 1, "Emily");
  419. lv_table_set_cell_value(table1, 5, 1, "Ivan");
  420. lv_table_set_cell_value(table1, 6, 1, "George");
  421. if(disp_size > LV_DISP_SIZE_SMALL) {
  422. lv_table_set_cell_value(table1, 0, 2, "CITY");
  423. lv_table_set_cell_value(table1, 1, 2, "Moscow");
  424. lv_table_set_cell_value(table1, 2, 2, "New York");
  425. lv_table_set_cell_value(table1, 3, 2, "Oslo");
  426. lv_table_set_cell_value(table1, 4, 2, "London");
  427. lv_table_set_cell_value(table1, 5, 2, "Texas");
  428. lv_table_set_cell_value(table1, 6, 2, "Athen");
  429. }
  430. }
  431. static void slider_event_cb(lv_obj_t * slider, lv_event_t e)
  432. {
  433. if(e == LV_EVENT_VALUE_CHANGED) {
  434. if(lv_slider_get_type(slider) == LV_SLIDER_TYPE_NORMAL) {
  435. static char buf[16];
  436. lv_snprintf(buf, sizeof(buf), "%d", lv_slider_get_value(slider));
  437. lv_obj_set_style_local_value_str(slider, LV_SLIDER_PART_KNOB, LV_STATE_DEFAULT, buf);
  438. } else {
  439. static char buf[32];
  440. lv_snprintf(buf, sizeof(buf), "%d-%d", lv_slider_get_left_value(slider), lv_slider_get_value(slider));
  441. lv_obj_set_style_local_value_str(slider, LV_SLIDER_PART_INDIC, LV_STATE_DEFAULT, buf);
  442. }
  443. }
  444. }
  445. static void ta_event_cb(lv_obj_t * ta, lv_event_t e)
  446. {
  447. if(e == LV_EVENT_RELEASED) {
  448. if(kb == NULL) {
  449. lv_obj_set_height(tv, LV_VER_RES / 2);
  450. kb = lv_keyboard_create(lv_scr_act(), NULL);
  451. lv_obj_set_event_cb(kb, kb_event_cb);
  452. lv_indev_wait_release(lv_indev_get_act());
  453. }
  454. lv_textarea_set_cursor_hidden(ta, false);
  455. lv_page_focus(t1, lv_textarea_get_label(ta), LV_ANIM_ON);
  456. lv_keyboard_set_textarea(kb, ta);
  457. } else if(e == LV_EVENT_DEFOCUSED) {
  458. lv_textarea_set_cursor_hidden(ta, true);
  459. }
  460. }
  461. static void kb_event_cb(lv_obj_t * _kb, lv_event_t e)
  462. {
  463. lv_keyboard_def_event_cb(kb, e);
  464. if(e == LV_EVENT_CANCEL) {
  465. if(kb) {
  466. lv_obj_set_height(tv, LV_VER_RES);
  467. lv_obj_del(kb);
  468. kb = NULL;
  469. }
  470. }
  471. }
  472. static void bar_anim(lv_task_t * t)
  473. {
  474. static uint32_t x = 0;
  475. lv_obj_t * bar = t->user_data;
  476. static char buf[64];
  477. lv_snprintf(buf, sizeof(buf), "Copying %d/%d", x, lv_bar_get_max_value(bar));
  478. lv_obj_set_style_local_value_str(bar, LV_BAR_PART_BG, LV_STATE_DEFAULT, buf);
  479. lv_bar_set_value(bar, x, LV_ANIM_OFF);
  480. x++;
  481. if(x > lv_bar_get_max_value(bar)) x = 0;
  482. }
  483. static void arc_anim(lv_obj_t * arc, lv_anim_value_t value)
  484. {
  485. lv_arc_set_end_angle(arc, value);
  486. static char buf[64];
  487. lv_snprintf(buf, sizeof(buf), "%d", value);
  488. lv_obj_t * label = lv_obj_get_child(arc, NULL);
  489. lv_label_set_text(label, buf);
  490. lv_obj_align(label, arc, LV_ALIGN_CENTER, 0, 0);
  491. }
  492. static void linemeter_anim(lv_obj_t * linemeter, lv_anim_value_t value)
  493. {
  494. lv_linemeter_set_value(linemeter, value);
  495. static char buf[64];
  496. lv_snprintf(buf, sizeof(buf), "%d", value);
  497. lv_obj_t * label = lv_obj_get_child(linemeter, NULL);
  498. lv_label_set_text(label, buf);
  499. lv_obj_align(label, linemeter, LV_ALIGN_CENTER, 0, 0);
  500. }
  501. static void gauge_anim(lv_obj_t * gauge, lv_anim_value_t value)
  502. {
  503. lv_gauge_set_value(gauge, 0, value);
  504. static char buf[64];
  505. lv_snprintf(buf, sizeof(buf), "%d", value);
  506. lv_obj_t * label = lv_obj_get_child(gauge, NULL);
  507. lv_label_set_text(label, buf);
  508. lv_obj_align(label, gauge, LV_ALIGN_IN_TOP_MID, 0, lv_obj_get_y(label));
  509. }
  510. static void table_event_cb(lv_obj_t * table, lv_event_t e)
  511. {
  512. if(e == LV_EVENT_CLICKED) {
  513. uint16_t row;
  514. uint16_t col;
  515. lv_res_t r = lv_table_get_pressed_cell(table, &row, &col);
  516. if(r == LV_RES_OK && col && row) { /*Skip the first row and col*/
  517. if(lv_table_get_cell_type(table, row, col) == 1) {
  518. lv_table_set_cell_type(table, row, col, 4);
  519. } else {
  520. lv_table_set_cell_type(table, row, col, 1);
  521. }
  522. }
  523. }
  524. }
  525. #if LV_USE_THEME_MATERIAL
  526. static void color_chg_event_cb(lv_obj_t * sw, lv_event_t e)
  527. {
  528. if(LV_THEME_DEFAULT_INIT != lv_theme_material_init) return;
  529. if(e == LV_EVENT_VALUE_CHANGED) {
  530. uint32_t flag = LV_THEME_MATERIAL_FLAG_LIGHT;
  531. if(lv_switch_get_state(sw)) flag = LV_THEME_MATERIAL_FLAG_DARK;
  532. LV_THEME_DEFAULT_INIT(lv_theme_get_color_primary(), lv_theme_get_color_secondary(),
  533. flag,
  534. lv_theme_get_font_small(), lv_theme_get_font_normal(), lv_theme_get_font_subtitle(), lv_theme_get_font_title());
  535. }
  536. }
  537. #endif
  538. #if LV_DEMO_WIDGETS_SLIDESHOW
  539. static void tab_content_anim_create(lv_obj_t * parent)
  540. {
  541. lv_anim_t a;
  542. lv_obj_t * scrl = lv_page_get_scrl(parent);
  543. lv_coord_t y_start = lv_obj_get_style_pad_top(parent, LV_PAGE_PART_BG);
  544. lv_coord_t anim_h = lv_obj_get_height(scrl) - lv_obj_get_height_fit(parent);
  545. uint32_t anim_time = lv_anim_speed_to_time(LV_DPI, 0, anim_h);
  546. lv_anim_init(&a);
  547. lv_anim_set_var(&a, scrl);
  548. lv_anim_set_exec_cb(&a, (lv_anim_exec_xcb_t)lv_obj_set_y);
  549. lv_anim_set_values(&a, y_start, y_start - anim_h);
  550. lv_anim_set_time(&a, anim_time);
  551. lv_anim_set_playback_time(&a, anim_time);
  552. lv_anim_set_playback_delay(&a, 200);
  553. lv_anim_set_repeat_count(&a, LV_ANIM_REPEAT_INFINITE);
  554. lv_anim_set_repeat_delay(&a, 200);
  555. lv_anim_start(&a);
  556. }
  557. static void tab_changer_task_cb(lv_task_t * task)
  558. {
  559. uint16_t act = lv_tabview_get_tab_act(tv);
  560. act++;
  561. if(act >= 3) act = 0;
  562. lv_tabview_set_tab_act(tv, act, LV_ANIM_ON);
  563. switch(act) {
  564. case 0:
  565. tab_content_anim_create(t1);
  566. break;
  567. case 1:
  568. tab_content_anim_create(t2);
  569. break;
  570. case 2:
  571. tab_content_anim_create(t3);
  572. break;
  573. }
  574. }
  575. #endif