send_view.c 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. #include "send_view.h"
  2. #include <furi.h>
  3. #include <gui/elements.h>
  4. #include <notification/notification.h>
  5. #include <notification/notification_messages.h>
  6. #include <furi_hal_uart.h>
  7. #include <string.h>
  8. #include <stdio.h>
  9. #define FLIPPERZERO_SERIAL_BAUD 115200
  10. typedef enum ESerialCommand { ESerialCommand_Send } ESerialCommand;
  11. struct SendView {
  12. View* view;
  13. };
  14. typedef struct {
  15. bool right_pressed;
  16. bool connected;
  17. } SendViewModel;
  18. static void Shake(void) {
  19. NotificationApp* notification = furi_record_open(RECORD_NOTIFICATION);
  20. notification_message(notification, &sequence_single_vibro);
  21. furi_record_close(RECORD_NOTIFICATION);
  22. }
  23. void send_serial_command_send(ESerialCommand command) {
  24. uint8_t data[1] = {0};
  25. char name[10] = "send";
  26. int length = strlen(name);
  27. for(int i = 0; i < length; i++) {
  28. switch(command) {
  29. case ESerialCommand_Send:
  30. data[0] = name[i];
  31. break;
  32. default:
  33. return;
  34. };
  35. furi_hal_uart_tx(FuriHalUartIdUSART1, data, 1);
  36. }
  37. }
  38. static void send_view_draw_callback(Canvas* canvas, void* context) {
  39. furi_assert(context);
  40. SendViewModel* model = context;
  41. canvas_clear(canvas);
  42. canvas_set_color(canvas, ColorBlack);
  43. canvas_draw_str_aligned(canvas, 64, 0, AlignCenter, AlignTop, "SEND MODULE");
  44. canvas_draw_line(canvas, 0, 10, 128, 10);
  45. canvas_draw_str_aligned(canvas, 64, 15, AlignCenter, AlignTop, "Press right to send IFTTT");
  46. canvas_draw_str_aligned(canvas, 64, 25, AlignCenter, AlignTop, "command or press and hold");
  47. canvas_draw_str_aligned(canvas, 64, 35, AlignCenter, AlignTop, "back to return to the menu");
  48. // Right
  49. if(model->right_pressed) {
  50. }
  51. }
  52. static void send_view_process(SendView* send_view, InputEvent* event) {
  53. with_view_model(
  54. send_view->view,
  55. SendViewModel * model,
  56. {
  57. if(event->type == InputTypePress) {
  58. if(event->key == InputKeyUp) {
  59. } else if(event->key == InputKeyDown) {
  60. } else if(event->key == InputKeyLeft) {
  61. } else if(event->key == InputKeyRight) {
  62. model->right_pressed = true;
  63. Shake();
  64. send_serial_command_send(ESerialCommand_Send);
  65. } else if(event->key == InputKeyOk) {
  66. } else if(event->key == InputKeyBack) {
  67. }
  68. } else if(event->type == InputTypeRelease) {
  69. if(event->key == InputKeyUp) {
  70. } else if(event->key == InputKeyDown) {
  71. } else if(event->key == InputKeyLeft) {
  72. } else if(event->key == InputKeyRight) {
  73. model->right_pressed = false;
  74. } else if(event->key == InputKeyOk) {
  75. } else if(event->key == InputKeyBack) {
  76. }
  77. } else if(event->type == InputTypeShort) {
  78. if(event->key == InputKeyBack) {
  79. }
  80. }
  81. },
  82. true);
  83. }
  84. static bool send_view_input_callback(InputEvent* event, void* context) {
  85. furi_assert(context);
  86. SendView* send_view = context;
  87. bool consumed = false;
  88. if(event->type == InputTypeLong && event->key == InputKeyBack) {
  89. } else {
  90. send_view_process(send_view, event);
  91. consumed = true;
  92. }
  93. return consumed;
  94. }
  95. SendView* send_view_alloc() {
  96. SendView* send_view = malloc(sizeof(SendView));
  97. send_view->view = view_alloc();
  98. view_set_context(send_view->view, send_view);
  99. view_allocate_model(send_view->view, ViewModelTypeLocking, sizeof(SendViewModel));
  100. view_set_draw_callback(send_view->view, send_view_draw_callback);
  101. view_set_input_callback(send_view->view, send_view_input_callback);
  102. furi_hal_uart_set_br(FuriHalUartIdUSART1, FLIPPERZERO_SERIAL_BAUD);
  103. return send_view;
  104. }
  105. void send_view_free(SendView* send_view) {
  106. furi_assert(send_view);
  107. view_free(send_view->view);
  108. free(send_view);
  109. }
  110. View* send_view_get_view(SendView* send_view) {
  111. furi_assert(send_view);
  112. return send_view->view;
  113. }
  114. void send_view_set_data(SendView* send_view, bool connected) {
  115. furi_assert(send_view);
  116. with_view_model(
  117. send_view->view, SendViewModel * model, { model->connected = connected; }, true);
  118. }