subghz_static.c 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. #include "subghz_static.h"
  2. #include "../subghz_i.h"
  3. #include <math.h>
  4. #include <furi.h>
  5. #include <furi-hal.h>
  6. #include <input/input.h>
  7. #include <notification/notification-messages.h>
  8. #include <lib/subghz/protocols/subghz_protocol_princeton.h>
  9. static const uint32_t subghz_static_keys[] = {
  10. 0x0074BADE,
  11. 0x0074BADD,
  12. 0x0074BADB,
  13. 0x00E34A4E,
  14. };
  15. struct SubghzStatic {
  16. View* view;
  17. SubGhzEncoderPrinceton* encoder;
  18. };
  19. typedef enum {
  20. SubghzStaticStatusRx,
  21. SubghzStaticStatusTx,
  22. } SubghzStaticStatus;
  23. typedef struct {
  24. uint8_t frequency;
  25. uint32_t real_frequency;
  26. uint8_t button;
  27. } SubghzStaticModel;
  28. void subghz_static_draw(Canvas* canvas, SubghzStaticModel* model) {
  29. char buffer[64];
  30. canvas_set_color(canvas, ColorBlack);
  31. canvas_set_font(canvas, FontPrimary);
  32. canvas_draw_str(canvas, 0, 8, "CC1101 Static");
  33. canvas_set_font(canvas, FontSecondary);
  34. // Frequency
  35. snprintf(
  36. buffer,
  37. sizeof(buffer),
  38. "Freq: %03ld.%03ld.%03ld Hz",
  39. model->real_frequency / 1000000 % 1000,
  40. model->real_frequency / 1000 % 1000,
  41. model->real_frequency % 1000);
  42. canvas_draw_str(canvas, 0, 20, buffer);
  43. snprintf(buffer, sizeof(buffer), "Key: %d", model->button);
  44. canvas_draw_str(canvas, 0, 31, buffer);
  45. }
  46. bool subghz_static_input(InputEvent* event, void* context) {
  47. furi_assert(context);
  48. SubghzStatic* instance = context;
  49. if(event->key == InputKeyBack) {
  50. return false;
  51. }
  52. with_view_model(
  53. instance->view, (SubghzStaticModel * model) {
  54. bool reconfigure = false;
  55. if(event->type == InputTypeShort) {
  56. if(event->key == InputKeyLeft) {
  57. if(model->frequency > 0) model->frequency--;
  58. reconfigure = true;
  59. } else if(event->key == InputKeyRight) {
  60. if(model->frequency < subghz_frequencies_count - 1) model->frequency++;
  61. reconfigure = true;
  62. } else if(event->key == InputKeyDown) {
  63. if(model->button > 0) model->button--;
  64. } else if(event->key == InputKeyUp) {
  65. if(model->button < 3) model->button++;
  66. }
  67. }
  68. if(reconfigure) {
  69. furi_hal_subghz_idle();
  70. model->real_frequency =
  71. furi_hal_subghz_set_frequency_and_path(subghz_frequencies[model->frequency]);
  72. furi_hal_subghz_tx();
  73. }
  74. if(event->key == InputKeyOk) {
  75. if(event->type == InputTypePress) {
  76. NotificationApp* notification = furi_record_open("notification");
  77. notification_message_block(notification, &sequence_set_red_255);
  78. subghz_encoder_princeton_set(
  79. instance->encoder, subghz_static_keys[model->button], 20);
  80. furi_hal_subghz_start_async_tx(
  81. subghz_encoder_princeton_yield, instance->encoder);
  82. while(!furi_hal_subghz_is_async_tx_complete()) osDelay(33);
  83. furi_hal_subghz_stop_async_tx();
  84. notification_message(notification, &sequence_reset_red);
  85. furi_record_close("notification");
  86. }
  87. }
  88. return true;
  89. });
  90. return true;
  91. }
  92. void subghz_static_enter(void* context) {
  93. furi_assert(context);
  94. SubghzStatic* instance = context;
  95. furi_hal_subghz_reset();
  96. furi_hal_subghz_load_preset(FuriHalSubGhzPresetOokAsync);
  97. hal_gpio_init(&gpio_cc1101_g0, GpioModeOutputPushPull, GpioPullNo, GpioSpeedLow);
  98. hal_gpio_write(&gpio_cc1101_g0, false);
  99. with_view_model(
  100. instance->view, (SubghzStaticModel * model) {
  101. model->frequency = subghz_frequencies_433_92;
  102. model->real_frequency =
  103. furi_hal_subghz_set_frequency_and_path(subghz_frequencies[model->frequency]);
  104. model->button = 0;
  105. return true;
  106. });
  107. furi_hal_subghz_tx();
  108. }
  109. void subghz_static_exit(void* context) {
  110. furi_assert(context);
  111. furi_hal_subghz_sleep();
  112. }
  113. SubghzStatic* subghz_static_alloc() {
  114. SubghzStatic* instance = furi_alloc(sizeof(SubghzStatic));
  115. // View allocation and configuration
  116. instance->view = view_alloc();
  117. view_allocate_model(instance->view, ViewModelTypeLocking, sizeof(SubghzStaticModel));
  118. view_set_context(instance->view, instance);
  119. view_set_draw_callback(instance->view, (ViewDrawCallback)subghz_static_draw);
  120. view_set_input_callback(instance->view, subghz_static_input);
  121. view_set_enter_callback(instance->view, subghz_static_enter);
  122. view_set_exit_callback(instance->view, subghz_static_exit);
  123. instance->encoder = subghz_encoder_princeton_alloc();
  124. return instance;
  125. }
  126. void subghz_static_free(SubghzStatic* instance) {
  127. furi_assert(instance);
  128. subghz_encoder_princeton_free(instance->encoder);
  129. view_free(instance->view);
  130. free(instance);
  131. }
  132. View* subghz_static_get_view(SubghzStatic* instance) {
  133. furi_assert(instance);
  134. return instance->view;
  135. }