DISTRHO Plugin Framework
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

155 lines
4.7KB

  1. /*
  2. * DISTRHO Plugin Framework (DPF)
  3. * Copyright (C) 2012-2021 Filipe Coelho <falktx@falktx.com>
  4. *
  5. * Permission to use, copy, modify, and/or distribute this software for any purpose with
  6. * or without fee is hereby granted, provided that the above copyright notice and this
  7. * permission notice appear in all copies.
  8. *
  9. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD
  10. * TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN
  11. * NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  12. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER
  13. * IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
  14. * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  15. */
  16. #include "TopLevelWidgetPrivateData.hpp"
  17. #include "WidgetPrivateData.hpp"
  18. #include "WindowPrivateData.hpp"
  19. #include "pugl.hpp"
  20. START_NAMESPACE_DGL
  21. // -----------------------------------------------------------------------
  22. TopLevelWidget::PrivateData::PrivateData(TopLevelWidget* const s, Window& w)
  23. : self(s),
  24. selfw(s),
  25. window(w)
  26. {
  27. window.pData->topLevelWidgets.push_back(self);
  28. }
  29. TopLevelWidget::PrivateData::~PrivateData()
  30. {
  31. window.pData->topLevelWidgets.remove(self);
  32. }
  33. bool TopLevelWidget::PrivateData::keyboardEvent(const KeyboardEvent& ev)
  34. {
  35. // ignore event if we are not visible
  36. if (! selfw->pData->visible)
  37. return false;
  38. // give top-level widget chance to catch this event first
  39. if (self->onKeyboard(ev))
  40. return true;
  41. // propagate event to all subwidgets recursively
  42. return selfw->pData->giveKeyboardEventForSubWidgets(ev);
  43. }
  44. bool TopLevelWidget::PrivateData::characterInputEvent(const CharacterInputEvent& ev)
  45. {
  46. // ignore event if we are not visible
  47. if (! selfw->pData->visible)
  48. return false;
  49. // give top-level widget chance to catch this event first
  50. if (self->onCharacterInput(ev))
  51. return true;
  52. // propagate event to all subwidgets recursively
  53. return selfw->pData->giveCharacterInputEventForSubWidgets(ev);
  54. }
  55. bool TopLevelWidget::PrivateData::mouseEvent(const MouseEvent& ev)
  56. {
  57. // ignore event if we are not visible
  58. if (! selfw->pData->visible)
  59. return false;
  60. MouseEvent rev = ev;
  61. if (window.pData->autoScaling)
  62. {
  63. const double autoScaleFactor = window.pData->autoScaleFactor;
  64. rev.pos.setX(ev.pos.getX() / autoScaleFactor);
  65. rev.pos.setY(ev.pos.getY() / autoScaleFactor);
  66. rev.absolutePos.setX(ev.absolutePos.getX() / autoScaleFactor);
  67. rev.absolutePos.setY(ev.absolutePos.getY() / autoScaleFactor);
  68. }
  69. // give top-level widget chance to catch this event first
  70. if (self->onMouse(ev))
  71. return true;
  72. // propagate event to all subwidgets recursively
  73. return selfw->pData->giveMouseEventForSubWidgets(rev);
  74. }
  75. bool TopLevelWidget::PrivateData::motionEvent(const MotionEvent& ev)
  76. {
  77. // ignore event if we are not visible
  78. if (! selfw->pData->visible)
  79. return false;
  80. MotionEvent rev = ev;
  81. if (window.pData->autoScaling)
  82. {
  83. const double autoScaleFactor = window.pData->autoScaleFactor;
  84. rev.pos.setX(ev.pos.getX() / autoScaleFactor);
  85. rev.pos.setY(ev.pos.getY() / autoScaleFactor);
  86. rev.absolutePos.setX(ev.absolutePos.getX() / autoScaleFactor);
  87. rev.absolutePos.setY(ev.absolutePos.getY() / autoScaleFactor);
  88. }
  89. // give top-level widget chance to catch this event first
  90. if (self->onMotion(ev))
  91. return true;
  92. // propagate event to all subwidgets recursively
  93. return selfw->pData->giveMotionEventForSubWidgets(rev);
  94. }
  95. bool TopLevelWidget::PrivateData::scrollEvent(const ScrollEvent& ev)
  96. {
  97. // ignore event if we are not visible
  98. if (! selfw->pData->visible)
  99. return false;
  100. ScrollEvent rev = ev;
  101. if (window.pData->autoScaling)
  102. {
  103. const double autoScaleFactor = window.pData->autoScaleFactor;
  104. rev.pos.setX(ev.pos.getX() / autoScaleFactor);
  105. rev.pos.setY(ev.pos.getY() / autoScaleFactor);
  106. rev.absolutePos.setX(ev.absolutePos.getX() / autoScaleFactor);
  107. rev.absolutePos.setY(ev.absolutePos.getY() / autoScaleFactor);
  108. rev.delta.setX(ev.delta.getX() / autoScaleFactor);
  109. rev.delta.setY(ev.delta.getY() / autoScaleFactor);
  110. }
  111. // give top-level widget chance to catch this event first
  112. if (self->onScroll(ev))
  113. return true;
  114. // propagate event to all subwidgets recursively
  115. return selfw->pData->giveScrollEventForSubWidgets(rev);
  116. }
  117. void TopLevelWidget::PrivateData::fallbackOnResize()
  118. {
  119. puglFallbackOnResize(window.pData->view);
  120. }
  121. // -----------------------------------------------------------------------
  122. END_NAMESPACE_DGL