infrared_app_scene_remote.cpp 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. #include <gui/modules/button_menu.h>
  2. #include <input/input.h>
  3. #include <infrared_worker.h>
  4. #include <dolphin/dolphin.h>
  5. #include "../infrared_app.h"
  6. #include "../infrared_app_view_manager.h"
  7. typedef enum {
  8. ButtonIndexPlus = -2,
  9. ButtonIndexEdit = -1,
  10. ButtonIndexNA = 0,
  11. } ButtonIndex;
  12. static void button_menu_callback(void* context, int32_t index, InputType type) {
  13. InfraredApp* app = static_cast<InfraredApp*>(context);
  14. InfraredAppEvent event;
  15. if(type == InputTypePress) {
  16. event.type = InfraredAppEvent::Type::MenuSelectedPress;
  17. } else if(type == InputTypeRelease) {
  18. event.type = InfraredAppEvent::Type::MenuSelectedRelease;
  19. } else if(type == InputTypeShort) {
  20. event.type = InfraredAppEvent::Type::MenuSelected;
  21. } else {
  22. furi_assert(0);
  23. }
  24. event.payload.menu_index = index;
  25. app->get_view_manager()->send_event(&event);
  26. }
  27. void InfraredAppSceneRemote::on_enter(InfraredApp* app) {
  28. InfraredAppViewManager* view_manager = app->get_view_manager();
  29. ButtonMenu* button_menu = view_manager->get_button_menu();
  30. auto remote_manager = app->get_remote_manager();
  31. int i = 0;
  32. button_pressed = false;
  33. infrared_worker_tx_set_get_signal_callback(
  34. app->get_infrared_worker(), infrared_worker_tx_get_signal_steady_callback, app);
  35. infrared_worker_tx_set_signal_sent_callback(
  36. app->get_infrared_worker(), InfraredApp::signal_sent_callback, app);
  37. buttons_names = remote_manager->get_button_list();
  38. i = 0;
  39. for(auto& name : buttons_names) {
  40. button_menu_add_item(
  41. button_menu, name.c_str(), i++, button_menu_callback, ButtonMenuItemTypeCommon, app);
  42. }
  43. button_menu_add_item(
  44. button_menu, "+", ButtonIndexPlus, button_menu_callback, ButtonMenuItemTypeControl, app);
  45. button_menu_add_item(
  46. button_menu, "Edit", ButtonIndexEdit, button_menu_callback, ButtonMenuItemTypeControl, app);
  47. app->set_text_store(0, "%s", remote_manager->get_remote_name().c_str());
  48. button_menu_set_header(button_menu, app->get_text_store(0));
  49. if(buttonmenu_item_selected != ButtonIndexNA) {
  50. button_menu_set_selected_item(button_menu, buttonmenu_item_selected);
  51. buttonmenu_item_selected = ButtonIndexNA;
  52. }
  53. view_manager->switch_to(InfraredAppViewManager::ViewId::ButtonMenu);
  54. }
  55. bool InfraredAppSceneRemote::on_event(InfraredApp* app, InfraredAppEvent* event) {
  56. bool consumed = true;
  57. if((event->type == InfraredAppEvent::Type::MenuSelected) ||
  58. (event->type == InfraredAppEvent::Type::MenuSelectedPress) ||
  59. (event->type == InfraredAppEvent::Type::MenuSelectedRelease)) {
  60. switch(event->payload.menu_index) {
  61. case ButtonIndexPlus:
  62. furi_assert(event->type == InfraredAppEvent::Type::MenuSelected);
  63. app->notify_click();
  64. buttonmenu_item_selected = event->payload.menu_index;
  65. app->set_learn_new_remote(false);
  66. app->switch_to_next_scene(InfraredApp::Scene::Learn);
  67. break;
  68. case ButtonIndexEdit:
  69. furi_assert(event->type == InfraredAppEvent::Type::MenuSelected);
  70. app->notify_click();
  71. buttonmenu_item_selected = event->payload.menu_index;
  72. app->switch_to_next_scene(InfraredApp::Scene::Edit);
  73. break;
  74. default:
  75. furi_assert(event->type != InfraredAppEvent::Type::MenuSelected);
  76. bool pressed = (event->type == InfraredAppEvent::Type::MenuSelectedPress);
  77. if(pressed && !button_pressed) {
  78. button_pressed = true;
  79. app->notify_click_and_green_blink();
  80. auto button_signal =
  81. app->get_remote_manager()->get_button_data(event->payload.menu_index);
  82. if(button_signal.is_raw()) {
  83. infrared_worker_set_raw_signal(
  84. app->get_infrared_worker(),
  85. button_signal.get_raw_signal().timings,
  86. button_signal.get_raw_signal().timings_cnt);
  87. } else {
  88. infrared_worker_set_decoded_signal(
  89. app->get_infrared_worker(), &button_signal.get_message());
  90. }
  91. DOLPHIN_DEED(DolphinDeedIrSend);
  92. infrared_worker_tx_start(app->get_infrared_worker());
  93. } else if(!pressed && button_pressed) {
  94. button_pressed = false;
  95. infrared_worker_tx_stop(app->get_infrared_worker());
  96. app->notify_green_off();
  97. }
  98. break;
  99. }
  100. } else if(event->type == InfraredAppEvent::Type::Back) {
  101. if(!button_pressed) {
  102. app->search_and_switch_to_previous_scene(
  103. {InfraredApp::Scene::Start, InfraredApp::Scene::RemoteList});
  104. }
  105. } else {
  106. consumed = false;
  107. }
  108. return consumed;
  109. }
  110. void InfraredAppSceneRemote::on_exit(InfraredApp* app) {
  111. infrared_worker_tx_set_get_signal_callback(app->get_infrared_worker(), nullptr, nullptr);
  112. infrared_worker_tx_set_signal_sent_callback(app->get_infrared_worker(), nullptr, nullptr);
  113. InfraredAppViewManager* view_manager = app->get_view_manager();
  114. ButtonMenu* button_menu = view_manager->get_button_menu();
  115. button_menu_reset(button_menu);
  116. }