subghz_scene_start.c 3.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. #include "../subghz_i.h"
  2. enum SubmenuIndex {
  3. SubmenuIndexAnalyze,
  4. SubmenuIndexRead,
  5. SubmenuIndexSaved,
  6. SubmenuIndexStatic,
  7. SubmenuIndexTest,
  8. SubmenuIndexAddManualy,
  9. };
  10. void subghz_scene_start_submenu_callback(void* context, uint32_t index) {
  11. SubGhz* subghz = context;
  12. view_dispatcher_send_custom_event(subghz->view_dispatcher, index);
  13. }
  14. const void subghz_scene_start_on_enter(void* context) {
  15. SubGhz* subghz = context;
  16. if(subghz->state_notifications == NOTIFICATION_STARTING_STATE) {
  17. subghz->state_notifications = NOTIFICATION_IDLE_STATE;
  18. }
  19. submenu_add_item(
  20. subghz->submenu,
  21. "Analyze",
  22. SubmenuIndexAnalyze,
  23. subghz_scene_start_submenu_callback,
  24. subghz);
  25. submenu_add_item(
  26. subghz->submenu, "Read", SubmenuIndexRead, subghz_scene_start_submenu_callback, subghz);
  27. submenu_add_item(
  28. subghz->submenu, "Saved", SubmenuIndexSaved, subghz_scene_start_submenu_callback, subghz);
  29. submenu_add_item(
  30. subghz->submenu,
  31. "Add manually",
  32. SubmenuIndexAddManualy,
  33. subghz_scene_start_submenu_callback,
  34. subghz);
  35. submenu_add_item(
  36. subghz->submenu, "Static", SubmenuIndexStatic, subghz_scene_start_submenu_callback, subghz);
  37. submenu_add_item(
  38. subghz->submenu, "Test", SubmenuIndexTest, subghz_scene_start_submenu_callback, subghz);
  39. submenu_set_selected_item(
  40. subghz->submenu, scene_manager_get_scene_state(subghz->scene_manager, SubGhzSceneStart));
  41. view_dispatcher_switch_to_view(subghz->view_dispatcher, SubGhzViewMenu);
  42. }
  43. const bool subghz_scene_start_on_event(void* context, SceneManagerEvent event) {
  44. SubGhz* subghz = context;
  45. if(event.type == SceneManagerEventTypeCustom) {
  46. if(event.event == SubmenuIndexAnalyze) {
  47. scene_manager_set_scene_state(
  48. subghz->scene_manager, SubGhzSceneStart, SubmenuIndexAnalyze);
  49. scene_manager_next_scene(subghz->scene_manager, SubGhzSceneAnalyze);
  50. return true;
  51. } else if(event.event == SubmenuIndexRead) {
  52. scene_manager_set_scene_state(
  53. subghz->scene_manager, SubGhzSceneStart, SubmenuIndexRead);
  54. scene_manager_next_scene(subghz->scene_manager, SubGhzSceneRead);
  55. return true;
  56. } else if(event.event == SubmenuIndexSaved) {
  57. scene_manager_set_scene_state(
  58. subghz->scene_manager, SubGhzSceneStart, SubmenuIndexSaved);
  59. scene_manager_next_scene(subghz->scene_manager, SubGhzSceneSaved);
  60. return true;
  61. } else if(event.event == SubmenuIndexAddManualy) {
  62. scene_manager_set_scene_state(
  63. subghz->scene_manager, SubGhzSceneStart, SubmenuIndexAddManualy);
  64. scene_manager_next_scene(subghz->scene_manager, SubGhzSceneSetType);
  65. return true;
  66. } else if(event.event == SubmenuIndexStatic) {
  67. scene_manager_set_scene_state(
  68. subghz->scene_manager, SubGhzSceneStart, SubmenuIndexStatic);
  69. scene_manager_next_scene(subghz->scene_manager, SubGhzSceneStatic);
  70. return true;
  71. } else if(event.event == SubmenuIndexTest) {
  72. scene_manager_set_scene_state(
  73. subghz->scene_manager, SubGhzSceneStart, SubmenuIndexTest);
  74. scene_manager_next_scene(subghz->scene_manager, SubGhzSceneTest);
  75. return true;
  76. }
  77. }
  78. return false;
  79. }
  80. const void subghz_scene_start_on_exit(void* context) {
  81. SubGhz* subghz = context;
  82. submenu_clean(subghz->submenu);
  83. }