menu.cpp 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. #include "stm32g4xx_hal.h"
  2. #include "cmsis_os.h"
  3. #include "menu_tree.h"
  4. #include "control.h"
  5. #include <stdio.h>
  6. #define DBG if(0)
  7. #define MON_DELAY 1000
  8. osMessageQId menu_event;
  9. osMutexId menu_mutex;
  10. osThreadId menu_update_handle;
  11. osThreadId menu_control_handle;
  12. menuItem* selectedMenuItem;
  13. bool update_flag = false;
  14. static void vControl(void const *params);
  15. static void vUpdate(void const *params);
  16. static osStatus menu_block(uint32_t ms);
  17. static void menu_unblock(void);
  18. //
  19. void menu_init(void)
  20. {
  21. #if 0
  22. // Очередь для событий кнопок
  23. osMessageQDef(vButEventQueue, 1, uint8_t);
  24. v_queue_event = osMessageCreate(osMessageQ(vButEventQueue), NULL);
  25. // Обработка событий
  26. osThreadDef(M_Event_Thread, vMenuEvent, osPriorityNormal, 0, 6*configMINIMAL_STACK_SIZE);
  27. v_task_event_handle = osThreadCreate(osThread(M_Event_Thread), NULL);
  28. #endif
  29. // Очередь для управляющих сигналов меню
  30. osMessageQDef(vButEventQueue, 1, uint8_t);
  31. menu_event = osMessageCreate(osMessageQ(vButEventQueue), NULL);
  32. // Mutex для блокировки меню
  33. osMutexDef(menu_mut);
  34. menu_mutex = osMutexCreate(osMutex(menu_mut));
  35. // События. Сигналы энкодера
  36. osThreadDef(control_thr, vControl, osPriorityNormal, 0, 6*configMINIMAL_STACK_SIZE);
  37. menu_control_handle = osThreadCreate(osThread(control_thr), NULL);
  38. // Обновление меню
  39. osThreadDef(menu_up_thr, vUpdate, osPriorityNormal, 0, 6*configMINIMAL_STACK_SIZE);
  40. menu_update_handle = osThreadCreate(osThread(menu_up_thr), NULL);
  41. // Начальный экран
  42. selectedMenuItem = (menuItem *) &m_main;
  43. (*(selectedMenuItem->func_draw))(selectedMenuItem->Select);
  44. #if 0
  45. osTimerDef(vSoundTimer, v_sound_tim);
  46. v_sound_timer_handle = osTimerCreate(osTimer(vSoundTimer), osTimerOnce, NULL);
  47. osMutexDef(menu_mut);
  48. v_menu_mutex_id = osMutexCreate(osMutex(menu_mut));
  49. #endif
  50. }
  51. //
  52. void menu_send_event(control_t but)
  53. {
  54. osMessagePut(menu_event, but, 0);
  55. }
  56. //
  57. static void vControl(void const *params)
  58. {
  59. osEvent event;
  60. for (;;)
  61. {
  62. event = osMessageGet(menu_event, 100);
  63. if (event.status != osEventMessage)
  64. continue;
  65. switch (event.value.v)
  66. {
  67. case CONTROL_FWD :
  68. DBG printf("Encoder forward\r\n");
  69. if (menu_block(0) == osOK) {
  70. button_right();
  71. //(*(selectedMenuItem->func_button_down))();
  72. //(*(selectedMenuItem->func_draw))(selectedMenuItem->Select);
  73. menu_unblock();
  74. }
  75. break;
  76. case CONTROL_BACK :
  77. DBG printf("Encoder back\r\n");
  78. if (menu_block(0) == osOK) {
  79. button_left();
  80. //(*(selectedMenuItem->func_button_down))();
  81. //(*(selectedMenuItem->func_draw))(selectedMenuItem->Select);
  82. menu_unblock();
  83. }
  84. break;
  85. case CONTROL_PUSH :
  86. printf("Encoder push");
  87. break;
  88. }
  89. }
  90. }
  91. //
  92. static void vUpdate(void const *params)
  93. {
  94. for (;;)
  95. {
  96. // Текущий экран меню нужно перерисовать
  97. if (update_flag)
  98. {
  99. (*(selectedMenuItem->func_draw))(selectedMenuItem->Select);
  100. }
  101. osDelay(MON_DELAY);
  102. }
  103. }
  104. //
  105. static osStatus menu_block(uint32_t ms)
  106. {
  107. return osMutexWait(menu_mutex, ms);
  108. }
  109. //
  110. static void menu_unblock(void)
  111. {
  112. osMutexRelease(menu_mutex);
  113. }