view_port.h 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. #pragma once
  2. #include <input/input.h>
  3. #include "canvas.h"
  4. #ifdef __cplusplus
  5. extern "C" {
  6. #endif
  7. typedef struct ViewPort ViewPort;
  8. /*
  9. * ViewPort Draw callback
  10. * @warning called from GUI thread
  11. */
  12. typedef void (*ViewPortDrawCallback)(Canvas* canvas, void* context);
  13. /*
  14. * ViewPort Input callback
  15. * @warning called from GUI thread
  16. */
  17. typedef void (*ViewPortInputCallback)(InputEvent* event, void* context);
  18. /*
  19. * ViewPort allocator
  20. * always returns view_port or stops system if not enough memory.
  21. */
  22. ViewPort* view_port_alloc();
  23. /*
  24. * ViewPort deallocator
  25. * Ensure that view_port was unregistered in GUI system before use.
  26. */
  27. void view_port_free(ViewPort* view_port);
  28. /*
  29. * Set view_port width.
  30. * Will be used to limit canvas drawing area and autolayout feature.
  31. * @param width - wanted width, 0 - auto.
  32. */
  33. void view_port_set_width(ViewPort* view_port, uint8_t width);
  34. uint8_t view_port_get_width(ViewPort* view_port);
  35. /*
  36. * Set view_port height.
  37. * Will be used to limit canvas drawing area and autolayout feature.
  38. * @param height - wanted height, 0 - auto.
  39. */
  40. void view_port_set_height(ViewPort* view_port, uint8_t height);
  41. uint8_t view_port_get_height(ViewPort* view_port);
  42. /*
  43. * Enable or disable view_port rendering.
  44. * @param view_port - ViewPort instance
  45. * @param enabled
  46. * @warning automatically dispatches update event
  47. */
  48. void view_port_enabled_set(ViewPort* view_port, bool enabled);
  49. bool view_port_is_enabled(ViewPort* view_port);
  50. /*
  51. * ViewPort event callbacks
  52. * @param callback - appropriate callback function
  53. * @param context - context to pass to callback
  54. */
  55. void view_port_draw_callback_set(ViewPort* view_port, ViewPortDrawCallback callback, void* context);
  56. void view_port_input_callback_set(
  57. ViewPort* view_port,
  58. ViewPortInputCallback callback,
  59. void* context);
  60. /*
  61. * Emit update signal to GUI system.
  62. * Rendering will happen later after GUI system process signal.
  63. */
  64. void view_port_update(ViewPort* view_port);
  65. #ifdef __cplusplus
  66. }
  67. #endif