A slide-in panel anchored to the left or right edge of the window. More...
#include <Malena/Graphics/Controls/SideMenu.h>
Public Types | |
| using | Anchor = SideMenuSettings::Anchor |
| using | Flag = SideMenuManifest::Flag |
| using | Mode = SideMenuSettings::Mode |
| using | State = SideMenuManifest::State |
Public Member Functions | |
| SideMenu (Mode mode=Mode::OVERLAY, Anchor anchor=Anchor::LEFT, const sf::Font &font=FontManager<>::getDefault()) | |
| SideMenuTheme & | applyFrom (const Theme &t) override |
Populate all fields from the global Theme token set. | |
| template<typename S> | |
| void | applySettings (const S &s) |
| template<typename St> | |
| void | applyStyle (const St &s) |
| template<typename T> | |
| void | applyTheme (const T &t) |
| void | close () |
| sf::Color | getDisabledColor () const |
| sf::Color | getDisabledTextColor () const |
| sf::Color | getErrorColor () const |
| sf::Color | getFillColor () const |
| sf::Color | getFocusColor () const |
| const sf::Font * | getFont () const |
| unsigned int | getFontSize () const |
| unsigned int | getFontSizeSmall () const |
| sf::FloatRect | getGlobalBounds () const override |
| sf::Color | getHoverColor () const |
| ml::List & | getList () |
Return the internal List for configuration. | |
| sf::Color | getMutedColor () const |
| sf::Color | getOutlineColor () const |
| float | getOutlineThickness () const |
| float | getPadding () const |
| float | getPanelWidth () const |
| sf::Vector2f | getPosition () const override |
| float | getRadius () const |
| sf::Color | getTextColor () const |
| bool | isOpen () const |
| bool | isSettingsLocked () const |
Return true if applySettings() is currently blocked. | |
| bool | isThemeLocked () const |
Return true if this component ignores theme changes. | |
| void | lockSettings () |
Prevent applySettings() from taking effect. | |
| void | lockTheme () |
| Prevent automatic re-styling when the global theme changes. | |
| void | onClose (std::function< void()> cb) |
| Called when the panel finishes closing. | |
| void | onOpen (std::function< void()> cb) |
| Called when the panel finishes opening. | |
| void | open () |
| void | setAnchor (Anchor a) |
| void | setAnimDuration (float d) |
| void | setBackdropColor (const sf::Color &c) |
| void | setContent (ml::Core &component) |
| Replace the internal list with any component. | |
| void | setDisabledColor (const sf::Color &c) |
| void | setDisabledTextColor (const sf::Color &c) |
| void | setErrorColor (const sf::Color &c) |
| void | setFillColor (const sf::Color &c) |
| void | setFocusColor (const sf::Color &c) |
| void | setFont (const sf::Font &&)=delete |
| void | setFont (const sf::Font &f) |
| void | setFontSize (unsigned int s) |
| void | setFontSizeSmall (unsigned int s) |
| void | setHamburgerBg (const sf::Color &c) |
| void | setHamburgerColor (const sf::Color &c) |
| void | setHamburgerPosition (const sf::Vector2f &pos) |
| void | setHamburgerSize (float s) |
| void | setHoverColor (const sf::Color &c) |
| void | setMode (Mode m) |
| void | setMutedColor (const sf::Color &c) |
| void | setOutlineColor (const sf::Color &c) |
| void | setOutlineThickness (float t) |
| void | setPadding (float p) |
| void | setPanelBg (const sf::Color &c) |
| void | setPanelHeight (float h) |
| void | setPanelWidth (float w) |
| void | setPosition (const sf::Vector2f &position) override |
| void | setRadius (float r) |
| void | setTextColor (const sf::Color &c) |
| void | toggle () |
| void | unlockSettings () |
Allow applySettings() to take effect again. | |
| void | unlockTheme () |
| Resume reacting to global theme changes. | |
Protected Member Functions | |
| void | draw (sf::RenderTarget &target, sf::RenderStates states) const override |
| void | onThemeApplied (const Theme &theme) override |
Called by ThemeManager when the active theme changes. | |
A slide-in panel anchored to the left or right edge of the window.
SideMenu manages a panel that slides in/out with a built-in hamburger button. It supports two display modes:
onOpen / onClose callbacks so the app can shift its layout accordingly).The panel can host a List (via getList()) or any ml::Core component (via setContent()). The SideMenu draws and positions the content internally; no separate addComponent() call is needed.
Definition at line 70 of file SideMenu.h.
Definition at line 79 of file SideMenu.h.
Definition at line 76 of file SideMenu.h.
Definition at line 78 of file SideMenu.h.
Definition at line 77 of file SideMenu.h.
|
explicit |
|
inlineoverridevirtualinherited |
Populate all fields from the global Theme token set.
Subclasses call GraphicTheme::applyFrom(t) first, then apply their own token mappings.
Reimplemented from ml::ControlTheme.
Definition at line 17 of file SideMenuTheme.h.
|
inline |
Definition at line 120 of file SideMenu.h.
|
inline |
Definition at line 139 of file SideMenu.h.
|
inline |
Definition at line 129 of file SideMenu.h.
| void ml::SideMenu::close | ( | ) |
|
overrideprotected |
|
inlinenodiscardinherited |
Definition at line 75 of file ControlTheme.h.
|
inlinenodiscardinherited |
Definition at line 76 of file ControlTheme.h.
|
inlinenodiscardinherited |
Definition at line 74 of file ControlTheme.h.
|
inlinenodiscardinherited |
Definition at line 67 of file GraphicTheme.h.
|
inlinenodiscardinherited |
Definition at line 73 of file ControlTheme.h.
|
inlinenodiscardinherited |
Definition at line 80 of file ControlTheme.h.
|
inlinenodiscardinherited |
Definition at line 81 of file ControlTheme.h.
|
inlinenodiscardinherited |
Definition at line 82 of file ControlTheme.h.
|
override |
|
inlinenodiscardinherited |
Definition at line 72 of file ControlTheme.h.
| ml::List & ml::SideMenu::getList | ( | ) |
|
inlinenodiscardinherited |
Definition at line 78 of file ControlTheme.h.
|
inlinenodiscardinherited |
Definition at line 68 of file GraphicTheme.h.
|
inlinenodiscardinherited |
Definition at line 69 of file GraphicTheme.h.
|
inlinenodiscardinherited |
Definition at line 79 of file ControlTheme.h.
|
inlinenodiscard |
Definition at line 187 of file SideMenu.h.
|
override |
|
inlinenodiscardinherited |
Definition at line 70 of file GraphicTheme.h.
|
inlinenodiscardinherited |
Definition at line 77 of file ControlTheme.h.
|
nodiscard |
|
inlinenodiscardinherited |
Return true if applySettings() is currently blocked.
Definition at line 115 of file Themeable.h.
|
inlinenodiscardinherited |
Return true if this component ignores theme changes.
Definition at line 97 of file Themeable.h.
|
inlineinherited |
Prevent applySettings() from taking effect.
Explicit individual setter calls still work normally. Only blocks the batch applySettings() path.
Definition at line 107 of file Themeable.h.
|
inlineinherited |
Prevent automatic re-styling when the global theme changes.
The component keeps its current visual state. Explicit individual setter calls still work normally.
Definition at line 85 of file Themeable.h.
| void ml::SideMenu::onClose | ( | std::function< void()> | cb | ) |
Called when the panel finishes closing.
| void ml::SideMenu::onOpen | ( | std::function< void()> | cb | ) |
Called when the panel finishes opening.
|
overrideprotectedvirtual |
Called by ThemeManager when the active theme changes.
Override in your component to re-style from the new theme. Always check isThemeLocked() first:
| theme | The newly active theme. |
Implements ml::Themeable.
| void ml::SideMenu::open | ( | ) |
|
inlineinherited |
Definition at line 28 of file SideMenuSettings.h.
|
inlineinherited |
Definition at line 31 of file SideMenuSettings.h.
|
inlineinherited |
Definition at line 33 of file SideMenuTheme.h.
| void ml::SideMenu::setContent | ( | ml::Core & | component | ) |
Replace the internal list with any component.
The SideMenu draws and positions the component internally. The component's events fire automatically — no separate addComponent() call is needed.
|
inlineinherited |
Definition at line 87 of file ControlTheme.h.
|
inlineinherited |
Definition at line 88 of file ControlTheme.h.
|
inlineinherited |
Definition at line 86 of file ControlTheme.h.
|
inlineinherited |
Definition at line 72 of file GraphicTheme.h.
|
inlineinherited |
Definition at line 85 of file ControlTheme.h.
|
deleteinherited |
|
inlineinherited |
Definition at line 92 of file ControlTheme.h.
|
inlineinherited |
Definition at line 94 of file ControlTheme.h.
|
inlineinherited |
Definition at line 95 of file ControlTheme.h.
|
inlineinherited |
Definition at line 35 of file SideMenuTheme.h.
|
inlineinherited |
Definition at line 34 of file SideMenuTheme.h.
| void ml::SideMenu::setHamburgerPosition | ( | const sf::Vector2f & | pos | ) |
|
inlineinherited |
Definition at line 32 of file SideMenuSettings.h.
|
inlineinherited |
Definition at line 84 of file ControlTheme.h.
|
inlineinherited |
Definition at line 27 of file SideMenuSettings.h.
|
inlineinherited |
Definition at line 90 of file ControlTheme.h.
|
inlineinherited |
Definition at line 73 of file GraphicTheme.h.
|
inlineinherited |
Definition at line 74 of file GraphicTheme.h.
|
inlineinherited |
Definition at line 91 of file ControlTheme.h.
|
inlineinherited |
Definition at line 32 of file SideMenuTheme.h.
|
inlineinherited |
Definition at line 30 of file SideMenuSettings.h.
|
inlineinherited |
Definition at line 29 of file SideMenuSettings.h.
|
override |
|
inlineinherited |
Definition at line 75 of file GraphicTheme.h.
|
inlineinherited |
Definition at line 89 of file ControlTheme.h.
| void ml::SideMenu::toggle | ( | ) |
|
inlineinherited |
Allow applySettings() to take effect again.
Definition at line 112 of file Themeable.h.
|
inlineinherited |
Resume reacting to global theme changes.
Does NOT immediately re-apply the current theme — call ThemeManager::get() and pass it to onThemeApplied() manually if you want to re-sync immediately after unlocking.
Definition at line 94 of file Themeable.h.
|
inherited |
Definition at line 16 of file SideMenuSettings.h.
|
inherited |
seconds
Definition at line 19 of file SideMenuSettings.h.
Definition at line 13 of file SideMenuTheme.h.
Definition at line 33 of file ControlTheme.h.
Definition at line 34 of file ControlTheme.h.
Definition at line 32 of file ControlTheme.h.
Definition at line 43 of file GraphicTheme.h.
Definition at line 31 of file ControlTheme.h.
|
inherited |
Definition at line 39 of file ControlTheme.h.
|
inherited |
Definition at line 40 of file ControlTheme.h.
|
inherited |
Definition at line 41 of file ControlTheme.h.
|
inherited |
Definition at line 15 of file SideMenuTheme.h.
Definition at line 14 of file SideMenuTheme.h.
|
inherited |
hit-area square
Definition at line 20 of file SideMenuSettings.h.
Definition at line 30 of file ControlTheme.h.
|
inherited |
Definition at line 15 of file SideMenuSettings.h.
Definition at line 36 of file ControlTheme.h.
Definition at line 44 of file GraphicTheme.h.
|
inherited |
Definition at line 45 of file GraphicTheme.h.
|
inherited |
Definition at line 37 of file ControlTheme.h.
Definition at line 12 of file SideMenuTheme.h.
|
inherited |
0 = use window height
Definition at line 18 of file SideMenuSettings.h.
|
inherited |
Definition at line 17 of file SideMenuSettings.h.
|
inherited |
Definition at line 46 of file GraphicTheme.h.
|
inherited |
Definition at line 35 of file ControlTheme.h.