TGUI 1.8
|
#include <TGUI/Widgets/MenuBar.hpp>
Public Types | |
using | Ptr = std::shared_ptr<MenuBar> |
Shared widget pointer. | |
using | ConstPtr = std::shared_ptr<const MenuBar> |
Shared constant widget pointer. | |
![]() | |
using | Ptr = std::shared_ptr<Widget> |
Shared widget pointer. | |
using | ConstPtr = std::shared_ptr<const Widget> |
Shared constant widget pointer. | |
Public Member Functions | |
MenuBar (const char *typeName=StaticWidgetType, bool initRenderer=true) | |
MenuBarRenderer * | getSharedRenderer () override |
Returns the renderer, which gives access to functions that determine how the widget is displayed. | |
const MenuBarRenderer * | getSharedRenderer () const override |
MenuBarRenderer * | getRenderer () override |
Returns the renderer, which gives access to functions that determine how the widget is displayed. | |
template<typename Func, typename... Args> | |
unsigned int | connectMenuItem (const String &menu, const String &menuItem, Func &&handler, const Args &... args) |
Connects a signal handler to the "MenuItemClicked" callback that will only be called when a specific menu item was clicked. | |
template<typename Func, typename... Args> | |
unsigned int | connectMenuItem (const std::vector< String > &hierarchy, Func &&handler, const Args &... args) |
Connects a signal handler to the "MenuItemClicked" callback that will only be called when a specific menu item was clicked. | |
void | setSize (const Layout2d &size) override |
Changes the size of the menu bar. | |
void | setEnabled (bool enabled) override |
Enables or disables the widget. | |
void | addMenu (const String &text) |
Adds a new menu. | |
bool | addMenuItem (const String &text) |
Adds a new menu item to the last added menu. | |
bool | addMenuItem (const String &menu, const String &text) |
Adds a new menu item to an existing menu. | |
bool | addMenuItem (const std::vector< String > &hierarchy, bool createParents=true) |
Adds a new menu item (or sub menu item) | |
bool | changeMenuItem (const std::vector< String > &hierarchy, const String &text) |
Changes the text of an existing menu item. | |
void | removeAllMenus () |
Removes all menus. | |
bool | removeMenu (const String &menu) |
Removes a menu. | |
bool | removeMenuItem (const String &menu, const String &menuItem) |
Removes a menu item. | |
bool | removeMenuItem (const std::vector< String > &hierarchy, bool removeParentsWhenEmpty=true) |
Removes a menu item (or sub menu item) | |
bool | removeMenuItems (const String &menu) |
Removes all menu items from a menu. | |
bool | removeSubMenuItems (const std::vector< String > &hierarchy) |
Removes a all menu items below a (sub) menu. | |
bool | setMenuEnabled (const String &menu, bool enabled) |
Enable or disable an entire menu. | |
bool | getMenuEnabled (const String &menu) const |
Check if an entire menu is enabled or disabled. | |
bool | setMenuItemEnabled (const String &menu, const String &menuItem, bool enabled) |
Enable or disable a menu item. | |
bool | setMenuItemEnabled (const std::vector< String > &hierarchy, bool enabled) |
Enable or disable a menu item. | |
bool | getMenuItemEnabled (const String &menu, const String &menuItem) const |
Check if a menu item is enabled or disabled. | |
bool | getMenuItemEnabled (const std::vector< String > &hierarchy) const |
Check if a menu item is enabled or disabled. | |
void | setMinimumSubMenuWidth (float minimumWidth) |
Changes the minimum width of the submenus. | |
float | getMinimumSubMenuWidth () const |
Returns the minimum width of the submenus. | |
void | setInvertedMenuDirection (bool invertDirection) |
Changes whether the menus open above or below the menu bar. | |
bool | getInvertedMenuDirection () const |
Returns whether the menus open above or below the menu bar. | |
std::vector< GetMenusElement > | getMenus () const |
Returns the menus and their menu items, including submenus. | |
void | closeMenu () override |
Closes the open menu when one of the menus is open. | |
bool | isMouseOnWidget (Vector2f pos) const override |
Returns whether the mouse position (which is relative to the parent widget) lies on top of the widget. | |
bool | leftMousePressed (Vector2f pos) override |
Called by the parent when the left mouse button goes down on top of the widget. | |
void | leftMouseReleased (Vector2f pos) override |
void | mouseMoved (Vector2f pos) override |
void | draw (BackendRenderTarget &target, RenderStates states) const override |
Draw the widget to a render target. | |
void | setSize (Layout width, Layout height) |
Changes the size of the widget. | |
![]() | |
MenuWidgetBase (const MenuWidgetBase &other) | |
MenuWidgetBase (MenuWidgetBase &&other) noexcept | |
MenuWidgetBase & | operator= (const MenuWidgetBase &other) |
MenuWidgetBase & | operator= (MenuWidgetBase &&other) noexcept |
MenuWidgetBaseRenderer * | getSharedRenderer () override |
Returns the renderer, which gives access to functions that determine how the widget is displayed. | |
const MenuWidgetBaseRenderer * | getSharedRenderer () const override |
MenuWidgetBaseRenderer * | getRenderer () override |
Returns the renderer, which gives access to functions that determine how the widget is displayed. | |
![]() | |
Widget (const char *typeName, bool initRenderer) | |
Widget (const Widget &) | |
Copy constructor. | |
Widget (Widget &&) noexcept | |
Move constructor. | |
virtual | ~Widget () |
Destructor. | |
Widget & | operator= (const Widget &) |
Overload of copy assignment operator. | |
Widget & | operator= (Widget &&) noexcept |
Move assignment. | |
void | setRenderer (std::shared_ptr< RendererData > rendererData) |
Sets a new renderer for the widget. The renderer determines how the widget looks. | |
virtual void | setPosition (const Layout2d &position) |
sets the position of the widget | |
void | setPosition (Layout x, Layout y) |
Sets the position of the widget. | |
Vector2f | getPosition () const |
Gets the position of the widget. | |
void | setSize (Layout width, Layout height) |
Changes the size of the widget. | |
void | setWidth (Layout width) |
Changes the width of the widget. | |
void | setHeight (Layout height) |
Changes the height of the widget. | |
Vector2f | getSize () const |
Returns the size of the widget. | |
virtual Vector2f | getFullSize () const |
Returns the entire size that the widget is using. | |
virtual Vector2f | getAbsolutePosition (Vector2f offset={}) const |
Get the absolute position of the widget instead of the relative position to its parent. | |
virtual Vector2f | getWidgetOffset () const |
Returns the distance between the position where the widget is drawn and where the widget is placed. | |
void | setAutoLayout (AutoLayout layout) |
Sets how the position is determined compared to the other widgets in the parent. | |
AutoLayout | getAutoLayout () const |
Returns how the position is determined compared to the other widgets in the parent. | |
void | setOrigin (float x, float y) |
Sets the origin point on which the position, scale and rotation is based. | |
void | setOrigin (Vector2f origin) |
Sets the origin point on which the position, scale and rotation is based. | |
Vector2f | getOrigin () const |
Returns the relative origin point on which the position, scale and rotation is based. | |
void | setScale (Vector2f scaleFactors) |
Sets the scaling to be applied to the widget. | |
void | setScale (Vector2f scaleFactors, Vector2f origin) |
Sets the scaling to be applied to the widget. | |
void | setScale (float scaleFactor) |
Sets the scaling to be applied to the widget. | |
void | setScale (float scaleFactor, Vector2f origin) |
Sets the scaling to be applied to the widget. | |
Vector2f | getScale () const |
Returns the scaling to be applied to the widget. | |
Vector2f | getScaleOrigin () const |
Returns the origin used for scaling. | |
void | setRotation (float angle) |
Sets the rotation to be applied to the widget. | |
void | setRotation (float angle, Vector2f origin) |
Sets the rotation to be applied to the widget. | |
float | getRotation () const |
Returns the rotation to be applied to the widget. | |
Vector2f | getRotationOrigin () const |
Returns the origin used for rotations. | |
void | showWithEffect (ShowEffectType type, Duration duration) |
Shows the widget by introducing it with an animation. | |
void | hideWithEffect (ShowEffectType type, Duration duration) |
Hides the widget by making it leave with an animation. | |
void | moveWithAnimation (Layout2d position, Duration duration) |
Moves the widget from its current position to the given position, over a given duration. | |
void | resizeWithAnimation (Layout2d size, Duration duration) |
Resizes the widget from its current size to the given size, over a given duration. | |
virtual void | setVisible (bool visible) |
Shows or hides a widget. | |
bool | isVisible () const |
Returns true when the widget is visible. | |
bool | isEnabled () const |
Returns true when the widget is enabled. | |
virtual void | setFocused (bool focused) |
Focus or unfocus the widget. | |
bool | isFocused () const |
Returns true when the widget is focused and false otherwise. | |
const String & | getWidgetType () const |
Returns the type of the widget. | |
Container * | getParent () const |
Returns a pointer to the parent widget. | |
BackendGui * | getParentGui () const |
Returns a pointer to the gui to which this widget belongs. | |
bool | isAnimationPlaying () const |
Returns whether there is an active animation (started with showWithEffect or hideWithEffect) | |
void | moveToFront () |
Places the widget before all other widgets. | |
void | moveToBack () |
Places the widget behind all other widgets. | |
void | setUserData (Any userData) |
Stores some data into the widget. | |
template<typename DataType> | |
DataType | getUserData () const |
Returns data stored in the widget. | |
bool | hasUserData () const |
Returns whether data stored in the widget. | |
void | setInheritedFont (const Font &font) |
Sets the font of the widget that is used when no font is set in the renderer. | |
const Font & | getInheritedFont () const |
Returns the font of the widget that is used when no font is set in the renderer. | |
void | setInheritedOpacity (float opacity) |
Sets the opacity of the widget that will be multiplied with the opacity set in the renderer. | |
float | getInheritedOpacity () const |
Returns the opacity of the widget that is multiplied with the opacity set in the renderer. | |
void | setTextSize (unsigned int size) |
Changes the character size of text in this widget if it uses text. | |
unsigned int | getTextSize () const |
Returns the character size of text in this widget. | |
void | setToolTip (Widget::Ptr toolTip) |
Sets the tool tip that should be displayed when hovering over the widget. | |
Widget::Ptr | getToolTip () const |
Returns the tool tip that is displayed when hovering over the widget. | |
void | setWidgetName (const String &name) |
Changes the name of a widget. | |
String | getWidgetName () const |
Returns the name of a widget. | |
void | setMouseCursor (Cursor::Type cursor) |
Changes which mouse cursor is shown when hovering over the widget. | |
Cursor::Type | getMouseCursor () const |
Returns which mouse cursor is shown when hovering over the widget. | |
void | setFocusable (bool focusable) |
Changes whether a widget could be focused. | |
bool | isFocusable () const |
Returns whether a widget could be focused. | |
void | setNavigationUp (const Widget::Ptr &widgetAbove) |
Changes which widget should become focused when navigating upwards from this widget. | |
Widget::Ptr | getNavigationUp () const |
Returns which widget would become focused when navigating upwards from this widget. | |
void | setNavigationDown (const Widget::Ptr &widgetBelow) |
Changes which widget should become focused when navigating downwards from this widget. | |
Widget::Ptr | getNavigationDown () const |
Returns which widget would become focused when navigating downwards from this widget. | |
void | setNavigationLeft (const Widget::Ptr &widgetLeft) |
Changes which widget should become focused when navigating to the left from this widget. | |
Widget::Ptr | getNavigationLeft () const |
Returns which widget would become focused when navigating to the left from this widget. | |
void | setNavigationRight (const Widget::Ptr &widgetRight) |
Changes which widget should become focused when navigating to the right from this widget. | |
Widget::Ptr | getNavigationRight () const |
Returns which widget would become focused when navigating to the right from this widget. | |
void | setIgnoreMouseEvents (bool ignore) |
Sets whether the widget should completely ignore mouse events and let them pass to the widgets behind it. | |
bool | getIgnoreMouseEvents () const |
Returns whether the widget is ignoring mouse events and letting them pass to the widgets behind it. | |
void | finishAllAnimations () |
Makes all animations of the widget finish immediately. | |
virtual bool | canGainFocus () const |
Returns whether the widget can currently gain focus. | |
bool | isContainer () const |
Returns whether the widget is a container widget or not. | |
bool | isMouseDown () const |
Returns whether the left mouse button has been pressed on top of the widget. | |
virtual void | setParent (Container *parent) |
virtual bool | updateTime (Duration elapsedTime) |
void | setAutoLayoutUpdateEnabled (bool enabled) |
virtual void | rightMousePressed (Vector2f pos) |
virtual void | rightMouseReleased (Vector2f pos) |
virtual void | mouseReleased (Event::MouseButton button, Vector2f pos) |
virtual void | keyPressed (const Event::KeyEvent &event) |
virtual bool | canHandleKeyPress (const Event::KeyEvent &event) |
Called by the parent of the widget to check if keyPressed would process the event. | |
virtual void | textEntered (char32_t key) |
virtual bool | scrolled (float delta, Vector2f pos, bool touch) |
Called by the parent on scroll event (either from mouse wheel of from two finger scrolling on a touchscreen) | |
virtual void | mouseNoLongerOnWidget () |
virtual void | leftMouseButtonNoLongerDown () |
virtual void | rightMouseButtonNoLongerDown () |
virtual Widget::Ptr | askToolTip (Vector2f mousePos) |
const Layout2d & | getPositionLayout () const |
const Layout2d & | getSizeLayout () const |
void | bindPositionLayout (Layout *layout) |
void | unbindPositionLayout (Layout *layout) |
void | bindSizeLayout (Layout *layout) |
void | unbindSizeLayout (Layout *layout) |
template<typename WidgetType> | |
std::shared_ptr< const WidgetType > | cast () const |
Downcast const widget. | |
template<typename WidgetType> | |
std::shared_ptr< WidgetType > | cast () |
Downcast widget. | |
void | rendererChangedCallback (const String &property) |
Static Public Member Functions | |
static MenuBar::Ptr | create () |
Creates a new menu bar widget. | |
static MenuBar::Ptr | copy (const MenuBar::ConstPtr &menuBar) |
Makes a copy of another menu bar. | |
Static Public Attributes | |
static constexpr const char | StaticWidgetType [] = "MenuBar" |
Type name of the widget. | |
Protected Member Functions | |
void | rendererChanged (const String &property) override |
Function called when one of the properties of the renderer is changed. | |
std::unique_ptr< DataIO::Node > | save (SavingRenderersMap &renderers) const override |
Saves the widget as a tree node in order to save it to a file. | |
void | load (const std::unique_ptr< DataIO::Node > &node, const LoadingRenderersMap &renderers) override |
Loads the widget from a tree of nodes. | |
void | updateTextSize () override |
Called when the text size is changed (either by setTextSize or via the renderer) | |
Widget::Ptr | clone () const override |
Makes a copy of the widget if you don't know its exact type. | |
void | openMenu (std::size_t menuIndex) |
Opens a menu. | |
void | drawMenusOnBar (BackendRenderTarget &target, RenderStates states) const |
Vector2f | calculateMenuOffset (std::size_t visibleMenuIdx) const |
void | emitMenuItemClick (const std::vector< String > &hierarchy) override |
void | deselectDeepestItem () override |
bool | isMouseOnOpenMenu (Vector2f pos) const override |
float | getDefaultMenuItemHeight () const override |
void | leftMouseReleasedOnMenu () override |
void | mouseMovedOnMenu (Vector2f pos) override |
void | drawOpenMenu (BackendRenderTarget &target, RenderStates states) const override |
![]() | |
MenuWidgetBase (const char *typeName, bool initRenderer) | |
Constructor. | |
Signal & | getSignal (String signalName) override |
Retrieves a signal based on its name. | |
void | rendererChanged (const String &property) override |
Function called when one of the properties of the renderer is changed. | |
void | createMenu (std::vector< Menu > &menus, const String &text) |
Menu * | findMenuItemParent (const std::vector< String > &hierarchy, unsigned int parentIndex, std::vector< Menu > &menus, bool createParents) |
const Menu * | findMenuItemParent (const std::vector< String > &hierarchy, unsigned int parentIndex, const std::vector< Menu > &menus) const |
Menu * | findMenuItem (const std::vector< String > &hierarchy, std::vector< Menu > &menus) |
const Menu * | findMenuItem (const std::vector< String > &hierarchy, const std::vector< Menu > &menus) const |
void | loadMenus (const std::unique_ptr< DataIO::Node > &node, std::vector< Menu > &menus) |
void | closeSubMenus (std::vector< Menu > &menus, int &selectedMenu) |
void | updateMenuTextColor (Menu &menu, bool selected) |
void | updateTextColors (std::vector< Menu > &menus, int selectedMenu) |
void | updateTextOpacity (std::vector< Menu > &menus) |
void | updateTextFont (std::vector< Menu > &menus) |
float | calculateMenuWidth (const Menu &menu) const |
float | getMenuItemHeight (const Menu &menuItem) const |
float | calculateOpenMenuHeight (const std::vector< Menu > &menuItems) const |
Vector2f | calculateSubmenuOffset (const Menu &menu, float globalLeftPos, float menuWidth, float subMenuWidth, bool &openSubMenuToRight) const |
bool | isMouseOnTopOfMenu (Vector2f menuPos, Vector2f mousePos, bool openSubMenuToRight, const Menu &menu, float menuWidth) const |
bool | findMenuItemBelowMouse (Vector2f menuPos, Vector2f mousePos, bool openSubMenuToRight, Menu &menu, float menuWidth, Menu **resultMenu, std::size_t *resultSelectedMenuItem) |
void | drawMenu (BackendRenderTarget &target, RenderStates states, const Menu &menu, float menuWidth, float globalLeftPos, bool openSubMenuToRight) const |
void | leftMouseReleasedOnMenu (const Menu *menu) |
bool | isMouseOnOpenMenu (Vector2f pos, const Menu &menu, Vector2f menuOffset) const |
void | mouseMovedOnMenu (Vector2f pos, Menu &menu, Vector2f menuOffset) |
void | deselectDeepestItem (Menu *menu) |
void | drawOpenMenu (BackendRenderTarget &target, RenderStates states, const Menu &menu, Vector2f menuOffset) const |
![]() | |
virtual void | mouseEnteredWidget () |
This function is called when the mouse enters the widget. | |
virtual void | mouseLeftWidget () |
This function is called when the mouse leaves the widget. | |
void | recalculateBoundPositionLayouts () |
Calls recalculateValue() on each layout in m_boundPositionLayouts. | |
void | recalculateBoundSizeLayouts () |
Calls recalculateValue() on each layout in m_boundSizeLayouts. | |
Protected Attributes | |
std::vector< Menu > | m_menus |
int | m_visibleMenu = -1 |
Sprite | m_spriteBackground |
![]() | |
std::shared_ptr< OpenMenuPlaceholder > | m_openMenuPlaceholder |
float | m_minimumMenuWidth = 125 |
Sprite | m_spriteItemBackground |
Sprite | m_spriteSelectedItemBackground |
Color | m_backgroundColorCached |
Color | m_selectedBackgroundColorCached |
Color | m_textColorCached |
Color | m_selectedTextColorCached |
Color | m_textColorDisabledCached |
Color | m_separatorColorCached = Color::Black |
float | m_separatorThicknessCached = 1 |
float | m_separatorVerticalPaddingCached = 0 |
float | m_separatorSidePaddingCached = 0 |
float | m_distanceToSideCached = 0 |
bool | m_invertedMenuDirection = false |
![]() | |
String | m_type |
String | m_name |
Layout2d | m_position |
Stores the position of this widget. | |
Layout2d | m_size |
Stores the size of this widget. | |
unsigned int | m_textSize = 0 |
Vector2f | m_origin |
Optional< Vector2f > | m_rotationOrigin |
Optional< Vector2f > | m_scaleOrigin |
Vector2f | m_scaleFactors = {1, 1} |
float | m_rotationDeg = 0 |
Vector2f | m_prevPosition |
Vector2f | m_prevSize |
std::unordered_set< Layout * > | m_boundPositionLayouts |
std::unordered_set< Layout * > | m_boundSizeLayouts |
bool | m_enabled = true |
Stores the flag indicating whether this widget is enabled. | |
bool | m_visible = true |
Stores the flag indicating whether this widget is visible. | |
Container * | m_parent = nullptr |
BackendGui * | m_parentGui = nullptr |
bool | m_mouseHover = false |
bool | m_mouseDown = false |
bool | m_focused = false |
bool | m_focusable = true |
std::weak_ptr< Widget > | m_navWidgetUp |
std::weak_ptr< Widget > | m_navWidgetDown |
std::weak_ptr< Widget > | m_navWidgetRight |
std::weak_ptr< Widget > | m_navWidgetLeft |
Duration | m_animationTimeElapsed |
bool | m_containerWidget = false |
Widget::Ptr | m_toolTip = nullptr |
aurora::CopiedPtr< WidgetRenderer > | m_renderer = nullptr |
std::vector< std::unique_ptr< priv::Animation > > | m_showAnimations |
Font | m_inheritedFont |
float | m_inheritedOpacity = 1 |
Any | m_userData |
Cursor::Type | m_mouseCursor = Cursor::Type::Arrow |
AutoLayout | m_autoLayout = AutoLayout::Manual |
bool | m_autoLayoutUpdateEnabled = true |
bool | m_ignoreMouseEvents = false |
Font | m_fontCached = Font::getGlobalFont() |
float | m_opacityCached = 1 |
bool | m_transparentTextureCached = false |
unsigned int | m_textSizeCached = 0 |
Additional Inherited Members | |
![]() | |
SignalItemHierarchy | onMenuItemClick = {"MenuItemClicked"} |
![]() | |
SignalVector2f | onPositionChange = {"PositionChanged"} |
The position of the widget changed. Optional parameter: new position. | |
SignalVector2f | onSizeChange = {"SizeChanged"} |
The size of the widget changed. Optional parameter: new size. | |
Signal | onFocus = {"Focused"} |
The widget was focused. | |
Signal | onUnfocus = {"Unfocused"} |
The widget was unfocused. | |
Signal | onMouseEnter = {"MouseEntered"} |
The mouse entered the widget. | |
Signal | onMouseLeave = {"MouseLeft"} |
The mouse left the widget. | |
SignalShowEffect | onShowEffectFinish = {"ShowEffectFinished"} |
A show or hide effect finished. Optional parameters: effect type, new widget visibility or both. | |
SignalAnimationType | onAnimationFinish = {"AnimationFinished"} |
An animation has finished. | |
![]() | |
using | SavingRenderersMap = std::map<const Widget*, std::pair<std::unique_ptr<DataIO::Node>, String>> |
using | LoadingRenderersMap = std::map<String, std::shared_ptr<RendererData>> |
![]() | |
static bool | isSeparator (const Menu &menuItem) |
static bool | removeMenuImpl (const std::vector< String > &hierarchy, bool removeParentsWhenEmpty, unsigned int parentIndex, std::vector< Menu > &menus) |
static bool | removeSubMenusImpl (const std::vector< String > &hierarchy, unsigned int parentIndex, std::vector< Menu > &menus) |
static void | setTextSizeImpl (std::vector< Menu > &menus, unsigned int textSize) |
static std::vector< GetMenusElement > | getMenusImpl (const std::vector< Menu > &menus) |
static void | saveMenus (const std::unique_ptr< DataIO::Node > &parentNode, const std::vector< Menu > &menus) |
Menu bar widget.
void tgui::MenuBar::addMenu | ( | const String & | text | ) |
Adds a new menu.
text | The text written on the menu |
bool tgui::MenuBar::addMenuItem | ( | const std::vector< String > & | hierarchy, |
bool | createParents = true ) |
Adds a new menu item (or sub menu item)
hierarchy | Hierarchy of the menu items, starting with the menu and ending with menu item to be added |
createParents | Should the hierarchy be created if it did not exist yet? |
If the "-" string is given as menu item then a separator will appear instead of an item.
Adds a new menu item to an existing menu.
menu | The name of the menu to which the menu item will be added |
text | The text written on this menu item |
If the "-" string is given as menu item then a separator will appear instead of an item.
bool tgui::MenuBar::addMenuItem | ( | const String & | text | ) |
Adds a new menu item to the last added menu.
text | The text written on this menu item |
If the "-" string is given as menu item then a separator will appear instead of an item.
Changes the text of an existing menu item.
hierarchy | Hierarchy of the menu items, starting with the menu and ending with menu item that is to be renamed |
text | The new text written on this menu item |
This function can also be used to rename menus, by passing a hierarchy with only one element.
|
nodiscardoverrideprotectedvirtual |
Makes a copy of the widget if you don't know its exact type.
This function should only be used when you don't know the type of the widget. If you know what kind of widget you are copying, you should use the copy function.
Implements tgui::Widget.
|
overridevirtual |
Closes the open menu when one of the menus is open.
Implements tgui::MenuWidgetBase.
|
inline |
Connects a signal handler to the "MenuItemClicked" callback that will only be called when a specific menu item was clicked.
hierarchy | Hierarchy of the menu items, starting with the menu and ending with menu item that should trigger the signal when pressed |
handler | Callback function to call |
args | Optional extra arguments to pass to the signal handler when the signal is emitted |
The hierarchy does not need to exist yet and the signal will still exist when removing and readding the menu items.
|
inline |
Connects a signal handler to the "MenuItemClicked" callback that will only be called when a specific menu item was clicked.
menu | Menu containing the menu item |
menuItem | Menu item which should trigger the signal |
handler | Callback function to call |
args | Optional extra arguments to pass to the signal handler when the signal is emitted |
The hierarchy does not need to exist yet and the signal will still exist when removing and readding the menu items.
|
staticnodiscard |
Makes a copy of another menu bar.
menuBar | The other menu bar |
|
staticnodiscard |
Creates a new menu bar widget.
|
overrideprotectedvirtual |
Implements tgui::MenuWidgetBase.
|
overridevirtual |
Draw the widget to a render target.
target | Render target to draw to |
states | Current render states |
Implements tgui::Widget.
|
overrideprotectedvirtual |
Implements tgui::MenuWidgetBase.
|
overrideprotectedvirtual |
Implements tgui::MenuWidgetBase.
|
nodiscardoverrideprotectedvirtual |
Implements tgui::MenuWidgetBase.
|
nodiscard |
Returns whether the menus open above or below the menu bar.
|
nodiscard |
Check if an entire menu is enabled or disabled.
menu | The name of the menu to check |
|
nodiscard |
Check if a menu item is enabled or disabled.
hierarchy | Hierarchy of menu items, starting with the menu and ending with the menu item to check |
|
nodiscard |
Check if a menu item is enabled or disabled.
menu | The name of the menu in which the menu item is located |
menuItem | The name of the menu item to check |
|
nodiscard |
Returns the menus and their menu items, including submenus.
|
nodiscard |
Returns the minimum width of the submenus.
|
nodiscardoverridevirtual |
Returns the renderer, which gives access to functions that determine how the widget is displayed.
Reimplemented from tgui::Widget.
|
nodiscardoverridevirtual |
Reimplemented from tgui::Widget.
|
nodiscardoverridevirtual |
Returns the renderer, which gives access to functions that determine how the widget is displayed.
Reimplemented from tgui::Widget.
|
nodiscardoverrideprotectedvirtual |
Implements tgui::MenuWidgetBase.
|
nodiscardoverridevirtual |
Returns whether the mouse position (which is relative to the parent widget) lies on top of the widget.
Implements tgui::Widget.
|
overridevirtual |
Called by the parent when the left mouse button goes down on top of the widget.
pos | Mouse position in view coordinates relative to the parent widget |
Reimplemented from tgui::Widget.
|
overridevirtual |
Reimplemented from tgui::Widget.
|
overrideprotectedvirtual |
Implements tgui::MenuWidgetBase.
|
overrideprotectedvirtual |
Loads the widget from a tree of nodes.
Reimplemented from tgui::Widget.
|
overridevirtual |
Reimplemented from tgui::Widget.
|
overrideprotectedvirtual |
Implements tgui::MenuWidgetBase.
|
protected |
Opens a menu.
menuIndex | Index of the menu to open |
bool tgui::MenuBar::removeMenu | ( | const String & | menu | ) |
Removes a menu.
Any menu items that belong to this menu will be removed as well.
menu | The name of the menu to remove |
bool tgui::MenuBar::removeMenuItem | ( | const std::vector< String > & | hierarchy, |
bool | removeParentsWhenEmpty = true ) |
Removes a menu item (or sub menu item)
hierarchy | Hierarchy of the menu item, starting with the menu and ending with menu item to be deleted |
removeParentsWhenEmpty | Also delete the parent of the deleted menu item if it has no other children |
Removes a menu item.
menu | The name of the menu in which the menu item is located |
menuItem | The name of the menu item to remove |
bool tgui::MenuBar::removeMenuItems | ( | const String & | menu | ) |
Removes all menu items from a menu.
menu | The name of the menu for which all menu items should be removed |
bool tgui::MenuBar::removeSubMenuItems | ( | const std::vector< String > & | hierarchy | ) |
Removes a all menu items below a (sub) menu.
hierarchy | Hierarchy of the menu item, starting with the menu and ending with the sub menu containing the items |
|
overrideprotectedvirtual |
Function called when one of the properties of the renderer is changed.
property | Name of the property that was changed |
Reimplemented from tgui::Widget.
|
nodiscardoverrideprotectedvirtual |
Saves the widget as a tree node in order to save it to a file.
Reimplemented from tgui::Widget.
|
overridevirtual |
Enables or disables the widget.
enabled | Is the widget enabled? |
The disabled widget will no longer receive events and thus no longer send callbacks. All widgets are enabled by default.
Reimplemented from tgui::Widget.
void tgui::MenuBar::setInvertedMenuDirection | ( | bool | invertDirection | ) |
Changes whether the menus open above or below the menu bar.
invertDirection | Should the menus open above the bar instead of below like it does by default? |
bool tgui::MenuBar::setMenuEnabled | ( | const String & | menu, |
bool | enabled ) |
Enable or disable an entire menu.
menu | The name of the menu to enable or disable |
enabled | Should the menu be enabled or disabled? |
bool tgui::MenuBar::setMenuItemEnabled | ( | const std::vector< String > & | hierarchy, |
bool | enabled ) |
Enable or disable a menu item.
hierarchy | Hierarchy of menu items, starting with the menu and ending with the menu item to enable/disable |
enabled | Should the menu item be enabled or disabled? |
bool tgui::MenuBar::setMenuItemEnabled | ( | const String & | menu, |
const String & | menuItem, | ||
bool | enabled ) |
Enable or disable a menu item.
menu | The name of the menu in which the menu item is located |
menuItem | The name of the menu item to enable or disable |
enabled | Should the menu item be enabled or disabled? |
void tgui::MenuBar::setMinimumSubMenuWidth | ( | float | minimumWidth | ) |
Changes the minimum width of the submenus.
When a submenu is displayed, the width will be either this or the width of the longest text in the submenu.
minimumWidth | minimum width of the submenus |
|
overridevirtual |
Changes the size of the menu bar.
size | The new size of the menu bar |
By default, the menu bar has the same width as the window and the height is 20 pixels.
Reimplemented from tgui::Widget.
Changes the size of the widget.
width | Width of the widget |
height | Height of the widget |
|
overrideprotectedvirtual |
Called when the text size is changed (either by setTextSize or via the renderer)
Reimplemented from tgui::Widget.