xremote_navigation_view.c 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. /*!
  2. * @file flipper-xremote/views/xremote_navigation_view.c
  3. @license This project is released under the GNU GPLv3 License
  4. * @copyright (c) 2023 Sandro Kalatozishvili (s.kalatoz@gmail.com)
  5. *
  6. * @brief Navigation page view callbacks and infrared functionality.
  7. */
  8. #include "xremote_navigation_view.h"
  9. #include "../xremote_app.h"
  10. static void xremote_navigation_view_draw_callback(Canvas* canvas, void* context)
  11. {
  12. furi_assert(context);
  13. XRemoteViewModel* model = context;
  14. XRemoteAppContext *app_ctx = model->context;
  15. xremote_canvas_draw_header(canvas, "Navigation");
  16. xremote_canvas_draw_button(canvas, model->up_pressed, 23, 30, XRemoteIconArrowUp);
  17. xremote_canvas_draw_button(canvas, model->down_pressed, 23, 72, XRemoteIconArrowDown);
  18. xremote_canvas_draw_button(canvas, model->left_pressed, 2, 51, XRemoteIconArrowLeft);
  19. xremote_canvas_draw_button(canvas, model->right_pressed, 44, 51, XRemoteIconArrowRight);
  20. xremote_canvas_draw_button(canvas, model->ok_pressed, 23, 51, XRemoteIconOk);
  21. if (app_ctx && app_ctx->app_settings->exit_behavior == XRemoteAppExitHold)
  22. xremote_canvas_draw_button_wide(canvas, model->back_pressed, 0, 95, "Back", XRemoteIconBack);
  23. else
  24. xremote_canvas_draw_button_wide(canvas, model->back_pressed, 0, 95, "Hold", XRemoteIconBack);
  25. xremote_canvas_draw_exit_footer(canvas, xremote_app_context_get_exit_str(app_ctx));
  26. }
  27. static void xremote_navigation_view_process(XRemoteView* view, InputEvent* event)
  28. {
  29. with_view_model(
  30. xremote_view_get_view(view),
  31. XRemoteViewModel* model,
  32. {
  33. model->context = xremote_view_get_app_context(view);
  34. if (event->type == InputTypePress)
  35. {
  36. if (event->key == InputKeyUp)
  37. {
  38. model->up_pressed = true;
  39. xremote_view_send_ir(view, XREMOTE_COMMAND_UP);
  40. }
  41. else if (event->key == InputKeyDown)
  42. {
  43. model->down_pressed = true;
  44. xremote_view_send_ir(view, XREMOTE_COMMAND_DOWN);
  45. }
  46. else if (event->key == InputKeyLeft)
  47. {
  48. model->left_pressed = true;
  49. xremote_view_send_ir(view, XREMOTE_COMMAND_LEFT);
  50. }
  51. else if (event->key == InputKeyRight)
  52. {
  53. model->right_pressed = true;
  54. xremote_view_send_ir(view, XREMOTE_COMMAND_RIGHT);
  55. }
  56. else if (event->key == InputKeyOk)
  57. {
  58. model->ok_pressed = true;
  59. xremote_view_send_ir(view, XREMOTE_COMMAND_OK);
  60. }
  61. else if (event->key == InputKeyBack)
  62. {
  63. model->back_pressed = true;
  64. xremote_view_send_ir(view, XREMOTE_COMMAND_BACK);
  65. }
  66. }
  67. else if (event->type == InputTypeRelease)
  68. {
  69. if (event->key == InputKeyUp) model->up_pressed = false;
  70. else if (event->key == InputKeyDown) model->down_pressed = false;
  71. else if (event->key == InputKeyLeft) model->left_pressed = false;
  72. else if (event->key == InputKeyRight) model->right_pressed = false;
  73. else if (event->key == InputKeyOk) model->ok_pressed = false;
  74. else if (event->key == InputKeyBack) model->back_pressed = false;
  75. }
  76. },
  77. true);
  78. }
  79. static bool xremote_navigation_view_input_callback(InputEvent* event, void* context)
  80. {
  81. furi_assert(context);
  82. XRemoteView* view = (XRemoteView*)context;
  83. XRemoteAppContext* app_ctx = xremote_view_get_app_context(view);
  84. XRemoteAppExit exit = app_ctx->app_settings->exit_behavior;
  85. if (event->key == InputKeyBack &&
  86. event->type == InputTypeShort &&
  87. exit == XRemoteAppExitPress) return false;
  88. else if (event->key == InputKeyBack &&
  89. event->type == InputTypeLong &&
  90. exit == XRemoteAppExitHold) return false;
  91. xremote_navigation_view_process(view, event);
  92. return true;
  93. }
  94. XRemoteView* xremote_navigation_view_alloc(void* app_ctx)
  95. {
  96. XRemoteView *view = xremote_view_alloc(app_ctx,
  97. xremote_navigation_view_input_callback,
  98. xremote_navigation_view_draw_callback);
  99. with_view_model(
  100. xremote_view_get_view(view),
  101. XRemoteViewModel* model,
  102. {
  103. model->context = xremote_view_get_app_context(view);
  104. model->up_pressed = false;
  105. model->down_pressed = false;
  106. model->left_pressed = false;
  107. model->right_pressed = false;
  108. model->back_pressed = false;
  109. model->ok_pressed = false;
  110. }, true);
  111. return view;
  112. }