subghz_scene_rpc.c 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. #include "../subghz_i.h"
  2. typedef enum {
  3. SubGhzRpcStateIdle,
  4. SubGhzRpcStateLoaded,
  5. } SubGhzRpcState;
  6. void subghz_scene_rpc_on_enter(void* context) {
  7. SubGhz* subghz = context;
  8. Popup* popup = subghz->popup;
  9. popup_set_header(popup, "Sub-GHz", 89, 42, AlignCenter, AlignBottom);
  10. popup_set_text(popup, "RPC mode", 89, 44, AlignCenter, AlignTop);
  11. popup_set_icon(popup, 0, 12, &I_RFIDDolphinSend_97x61);
  12. view_dispatcher_switch_to_view(subghz->view_dispatcher, SubGhzViewIdPopup);
  13. scene_manager_set_scene_state(subghz->scene_manager, SubGhzSceneRpc, SubGhzRpcStateIdle);
  14. notification_message(subghz->notifications, &sequence_display_backlight_on);
  15. }
  16. bool subghz_scene_rpc_on_event(void* context, SceneManagerEvent event) {
  17. SubGhz* subghz = context;
  18. Popup* popup = subghz->popup;
  19. bool consumed = false;
  20. SubGhzRpcState state = scene_manager_get_scene_state(subghz->scene_manager, SubGhzSceneRpc);
  21. if(event.type == SceneManagerEventTypeCustom) {
  22. consumed = true;
  23. if(event.event == SubGhzCustomEventSceneExit) {
  24. scene_manager_stop(subghz->scene_manager);
  25. view_dispatcher_stop(subghz->view_dispatcher);
  26. rpc_system_app_confirm(subghz->rpc_ctx, RpcAppEventAppExit, true);
  27. } else if(event.event == SubGhzCustomEventSceneRpcSessionClose) {
  28. scene_manager_stop(subghz->scene_manager);
  29. view_dispatcher_stop(subghz->view_dispatcher);
  30. } else if(event.event == SubGhzCustomEventSceneRpcButtonPress) {
  31. bool result = false;
  32. if((subghz->txrx->txrx_state == SubGhzTxRxStateSleep) &&
  33. (state == SubGhzRpcStateLoaded)) {
  34. result = subghz_tx_start(subghz, subghz->txrx->fff_data);
  35. if(result) subghz_blink_start(subghz);
  36. }
  37. rpc_system_app_confirm(subghz->rpc_ctx, RpcAppEventButtonPress, result);
  38. } else if(event.event == SubGhzCustomEventSceneRpcButtonRelease) {
  39. bool result = false;
  40. if(subghz->txrx->txrx_state == SubGhzTxRxStateTx) {
  41. subghz_blink_stop(subghz);
  42. subghz_tx_stop(subghz);
  43. subghz_sleep(subghz);
  44. result = true;
  45. }
  46. rpc_system_app_confirm(subghz->rpc_ctx, RpcAppEventButtonRelease, result);
  47. } else if(event.event == SubGhzCustomEventSceneRpcLoad) {
  48. bool result = false;
  49. const char* arg = rpc_system_app_get_data(subghz->rpc_ctx);
  50. if(arg && (state == SubGhzRpcStateIdle)) {
  51. if(subghz_key_load(subghz, arg, false)) {
  52. scene_manager_set_scene_state(
  53. subghz->scene_manager, SubGhzSceneRpc, SubGhzRpcStateLoaded);
  54. furi_string_set(subghz->file_path, arg);
  55. result = true;
  56. FuriString* file_name;
  57. file_name = furi_string_alloc();
  58. path_extract_filename(subghz->file_path, file_name, true);
  59. snprintf(
  60. subghz->file_name_tmp,
  61. SUBGHZ_MAX_LEN_NAME,
  62. "loaded\n%s",
  63. furi_string_get_cstr(file_name));
  64. popup_set_text(popup, subghz->file_name_tmp, 89, 44, AlignCenter, AlignTop);
  65. furi_string_free(file_name);
  66. }
  67. }
  68. rpc_system_app_confirm(subghz->rpc_ctx, RpcAppEventLoadFile, result);
  69. }
  70. }
  71. return consumed;
  72. }
  73. void subghz_scene_rpc_on_exit(void* context) {
  74. SubGhz* subghz = context;
  75. if(subghz->txrx->txrx_state == SubGhzTxRxStateTx) {
  76. subghz_tx_stop(subghz);
  77. subghz_sleep(subghz);
  78. subghz_blink_stop(subghz);
  79. }
  80. Popup* popup = subghz->popup;
  81. popup_set_header(popup, NULL, 0, 0, AlignCenter, AlignBottom);
  82. popup_set_text(popup, NULL, 0, 0, AlignCenter, AlignTop);
  83. popup_set_icon(popup, 0, 0, NULL);
  84. }