Menu.h 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. // zlib open source license
  2. //
  3. // Copyright (c) 2018 to 2023 David Forsgren Piuva
  4. //
  5. // This software is provided 'as-is', without any express or implied
  6. // warranty. In no event will the authors be held liable for any damages
  7. // arising from the use of this software.
  8. //
  9. // Permission is granted to anyone to use this software for any purpose,
  10. // including commercial applications, and to alter it and redistribute it
  11. // freely, subject to the following restrictions:
  12. //
  13. // 1. The origin of this software must not be misrepresented; you must not
  14. // claim that you wrote the original software. If you use this software
  15. // in a product, an acknowledgment in the product documentation would be
  16. // appreciated but is not required.
  17. //
  18. // 2. Altered source versions must be plainly marked as such, and must not be
  19. // misrepresented as being the original software.
  20. //
  21. // 3. This notice may not be removed or altered from any source
  22. // distribution.
  23. #ifndef DFPSR_GUI_COMPONENT_MENU
  24. #define DFPSR_GUI_COMPONENT_MENU
  25. #include "../VisualComponent.h"
  26. #include "../../../api/fontAPI.h"
  27. namespace dsr {
  28. class Menu : public VisualComponent {
  29. PERSISTENT_DECLARATION(Menu)
  30. public:
  31. // Attributes
  32. PersistentColor backColor = PersistentColor(130, 130, 130);
  33. PersistentColor foreColor = PersistentColor(0, 0, 0);
  34. // The text to display for the head that is directly interacted with.
  35. PersistentString text;
  36. // Name of theme class used to draw the background of the head.
  37. // "MenuTop" is used if listClass is empty or not found, and the menu is not directly within another menu.
  38. // "MenuSub" is used if listClass is empty or not found, and the menu is a direct child of another menu.
  39. PersistentString headClass;
  40. // Name of theme class used to draw the background of the drop-down list.
  41. // "MenuList" is used if listClass is empty or not found.
  42. PersistentString listClass;
  43. PersistentInteger padding = PersistentInteger(4); // Empty space around child components and its own text.
  44. PersistentInteger spacing = PersistentInteger(2); // Empty space between child components.
  45. void declareAttributes(StructureDefinition &target) const override;
  46. Persistent* findAttribute(const ReadableString &name) override;
  47. private:
  48. void loadTheme(const VisualTheme &theme);
  49. void completeAssets();
  50. void generateGraphics();
  51. void generateBackground();
  52. MediaMethod headImageMethod, listBackgroundImageMethod;
  53. OrderedImageRgbaU8 headImage, listBackgroundImage;
  54. ComponentState headStateListenerMask; // Bit-mask telling which state bits are requested as input arguments to headImageMethod.
  55. RasterFont font;
  56. bool subMenu = false;
  57. IRect overlayLocation; // Relative to the parent's location, just like its own location
  58. bool pressed = false;
  59. // Settings fetched from the theme
  60. String finalHeadClass; // The selected HeadClass/Class from layout settings or the component's default theme class "MenuTop" or "MenuSub" based on ownership.
  61. String finalListClass; // The selected ListClass from layout settings or the component's default theme class "MenuList".
  62. int menuHead_filter = 0; // 0 for solid, 1 for alpha filter.
  63. int menuList_filter = 0; // 0 for solid, 1 for alpha filter.
  64. public:
  65. Menu();
  66. public:
  67. bool isContainer() const override;
  68. void drawSelf(ImageRgbaU8& targetImage, const IRect &relativeLocation) override;
  69. void drawOverlay(ImageRgbaU8& targetImage, const IVector2D &absoluteOffset) override;
  70. void changedTheme(VisualTheme newTheme) override;
  71. void changedLocation(const IRect &oldLocation, const IRect &newLocation) override;
  72. void changedAttribute(const ReadableString &name) override;
  73. void updateLocationEvent(const IRect& oldLocation, const IRect& newLocation) override;
  74. void receiveMouseEvent(const MouseEvent& event) override;
  75. IVector2D getDesiredDimensions() override;
  76. bool managesChildren() override;
  77. public:
  78. // Helper functions for decorations.
  79. bool hasArrow();
  80. // Helper functions for overlay projecting components.
  81. void createOverlay();
  82. void updateStateEvent(ComponentState oldState, ComponentState newState) override;
  83. bool pointIsInsideOfOverlay(const IVector2D& pixelPosition) override;
  84. };
  85. }
  86. #endif