TGUI  1.5
Loading...
Searching...
No Matches
ComboBox.hpp
1
2//
3// TGUI - Texus' Graphical User Interface
4// Copyright (C) 2012-2024 Bruno Van de Velde (vdv_b@tgui.eu)
5//
6// This software is provided 'as-is', without any express or implied warranty.
7// In no event will the authors be held liable for any damages 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 freely,
11// subject to the following restrictions:
12//
13// 1. The origin of this software must not be misrepresented;
14// you must not claim that you wrote the original software.
15// If you use this software in a product, an acknowledgment
16// in the product documentation would be appreciated but is not required.
17//
18// 2. Altered source versions must be plainly marked as such,
19// and must not be misrepresented as being the original software.
20//
21// 3. This notice may not be removed or altered from any source distribution.
22//
24
25#ifndef TGUI_COMBO_BOX_HPP
26#define TGUI_COMBO_BOX_HPP
27
28#include <TGUI/Widgets/ListBox.hpp>
29#include <TGUI/Renderers/ComboBoxRenderer.hpp>
30
32
33TGUI_MODULE_EXPORT namespace tgui
34{
38 class TGUI_API ComboBox : public Widget
39 {
40 public:
41
43 enum class ExpandDirection
44 {
45 Down,
46 Up,
47 Automatic
48 };
49
50 public:
51
52 using Ptr = std::shared_ptr<ComboBox>;
53 using ConstPtr = std::shared_ptr<const ComboBox>;
54
55 static constexpr const char StaticWidgetType[] = "ComboBox";
56
64 ComboBox(const char* typeName = StaticWidgetType, bool initRenderer = true);
65
67 // Copy constructor
69 ComboBox(const ComboBox& other);
70
72 // Move constructor
74 ComboBox(ComboBox&& other) noexcept;
75
77 // Copy assignment operator
79 ComboBox& operator= (const ComboBox& other);
80
82 // Move assignment operator
84 ComboBox& operator= (ComboBox&& other) noexcept;
85
91 TGUI_NODISCARD static ComboBox::Ptr create();
92
100 TGUI_NODISCARD static ComboBox::Ptr copy(const ComboBox::ConstPtr& comboBox);
101
106 TGUI_NODISCARD ComboBoxRenderer* getSharedRenderer() override;
107 TGUI_NODISCARD const ComboBoxRenderer* getSharedRenderer() const override;
108
114 TGUI_NODISCARD TGUI_NODISCARD ComboBoxRenderer* getRenderer() override;
115
123 void setSize(const Layout2d& size) override;
124 using Widget::setSize;
125
133 void setEnabled(bool enabled) override;
134
145 void setItemsToDisplay(std::size_t nrOfItemsInListToDisplay);
146
157 TGUI_NODISCARD std::size_t getItemsToDisplay() const;
158
169 std::size_t addItem(const String& itemName, const String& id = "");
170
188 bool setSelectedItem(const String& itemName);
189
208
221 bool setSelectedItemByIndex(std::size_t index);
222
229
241 bool removeItem(const String& itemName);
242
254 bool removeItemById(const String& id);
255
268 bool removeItemByIndex(std::size_t index);
269
274
284 TGUI_NODISCARD String getItemById(const String& id) const;
285
292 TGUI_NODISCARD String getSelectedItem() const;
293
300 TGUI_NODISCARD String getSelectedItemId() const;
301
307 TGUI_NODISCARD int getSelectedItemIndex() const;
308
321 bool changeItem(const String& originalValue, const String& newValue);
322
335 bool changeItemById(const String& id, const String& newValue);
336
347 bool changeItemByIndex(std::size_t index, const String& newValue);
348
354 TGUI_NODISCARD std::size_t getItemCount() const;
355
361 TGUI_NODISCARD std::vector<String> getItems() const;
362
370 TGUI_NODISCARD std::vector<String> getItemIds() const;
371
386 void setItemData(std::size_t index, Any data);
387
396 template <typename DataType>
397 TGUI_NODISCARD DataType getItemData(std::size_t index) const
398 {
399 return m_listBox->getItemData<DataType>(index);
400 }
401
410 void setMaximumItems(std::size_t maximumItems = 0);
411
418 TGUI_NODISCARD std::size_t getMaximumItems() const;
419
425 void setDefaultText(const String& defaultText);
426
432 TGUI_NODISCARD const String& getDefaultText() const;
433
439
444 TGUI_NODISCARD ExpandDirection getExpandDirection() const;
445
450 TGUI_NODISCARD bool contains(const String& item) const;
451
456 TGUI_NODISCARD bool containsId(const String& id) const;
457
463 void setChangeItemOnScroll(bool changeOnScroll);
464
470 TGUI_NODISCARD bool getChangeItemOnScroll() const;
471
477 void setParent(Container* parent) override;
478
484 TGUI_NODISCARD bool isMouseOnWidget(Vector2f pos) const override;
485
489 bool leftMousePressed(Vector2f pos) override;
490
494 bool scrolled(float delta, Vector2f pos, bool touch) override;
495
502 void draw(BackendRenderTarget& target, RenderStates states) const override;
503
505 protected:
506
516 TGUI_NODISCARD Signal& getSignal(String signalName) override;
517
523 void rendererChanged(const String& property) override;
524
528 TGUI_NODISCARD std::unique_ptr<DataIO::Node> save(SavingRenderersMap& renderers) const override;
529
533 void load(const std::unique_ptr<DataIO::Node>& node, const LoadingRenderersMap& renderers) override;
534
538 void updateTextSize() override;
539
541 // Returns the size without the borders
543 TGUI_NODISCARD Vector2f getInnerSize() const;
544
546 // Update the height of the internal list box
548 void updateListBoxHeight();
549
551 // Shows the list of items.
553 void showListBox();
554
556 // Hides the list of items.
558 void hideListBox();
559
561 // Initialize the internal list box
563 void initListBox();
564
566 // Makes a copy of the widget
568 TGUI_NODISCARD Widget::Ptr clone() const override;
569
571 public:
572
573 SignalItem onItemSelect = {"ItemSelected"};
574
576 protected:
577
578 // The number of items to display. If there is a scrollbar then you can scroll to see the other.
579 // If there is no scrollbar then this will be the maximum amount of items.
580 std::size_t m_nrOfItemsToDisplay = 0;
581
582 // Internally a list box is used to store all items
583 ListBox::Ptr m_listBox = ListBox::create();
584
585 Text m_text;
586 Text m_defaultText;
587
588 int m_previousSelectedItemIndex = -1;
589 bool m_changeItemOnScroll = false;
590
591 ExpandDirection m_expandDirection = ExpandDirection::Automatic;
592
593 Sprite m_spriteBackground;
594 Sprite m_spriteBackgroundDisabled;
595 Sprite m_spriteArrow;
596 Sprite m_spriteArrowHover;
597 Sprite m_spriteArrowDisabled;
598
599 // Cached renderer properties
600 Borders m_bordersCached;
601 Padding m_paddingCached;
602 Color m_borderColorCached;
603 Color m_backgroundColorCached;
604 Color m_backgroundColorDisabledCached;
605 Color m_arrowColorCached;
606 Color m_arrowColorHoverCached;
607 Color m_arrowColorDisabledCached;
608 Color m_arrowBackgroundColorCached;
609 Color m_arrowBackgroundColorHoverCached;
610 Color m_arrowBackgroundColorDisabledCached;
611 Color m_textColorCached;
612 Color m_textColorDisabledCached;
613
615 };
616
618}
619
621
622#endif // TGUI_COMBO_BOX_HPP
623
Base class for render targets.
Definition BackendRenderTarget.hpp:46
Wrapper for colors.
Definition Color.hpp:73
Definition ComboBoxRenderer.hpp:35
Combo box widget.
Definition ComboBox.hpp:39
TGUI_NODISCARD std::size_t getMaximumItems() const
Returns the maximum items that the combo box can contain.
TGUI_NODISCARD Widget::Ptr clone() const override
Makes a copy of the widget if you don't know its exact type.
void updateTextSize() override
Called when the text size is changed (either by setTextSize or via the renderer)
bool removeItemById(const String &id)
Removes the item that were added with the given id.
TGUI_NODISCARD std::size_t getItemsToDisplay() const
Returns the number of items that are displayed in the list.
void setSize(const Layout2d &size) override
Changes the size of the combo box.
void draw(BackendRenderTarget &target, RenderStates states) const override
Draw the widget to a render target.
TGUI_NODISCARD std::size_t getItemCount() const
Returns the amount of items in the combo box.
TGUI_NODISCARD bool contains(const String &item) const
Returns whether the combo box contains the given item.
bool setSelectedItemByIndex(std::size_t index)
Selects an item in the list.
TGUI_NODISCARD ComboBoxRenderer * getSharedRenderer() override
Returns the renderer, which gives access to functions that determine how the widget is displayed.
TGUI_NODISCARD Signal & getSignal(String signalName) override
Retrieves a signal based on its name.
TGUI_NODISCARD std::vector< String > getItems() const
Returns a copy of the items in the combo box.
TGUI_NODISCARD ExpandDirection getExpandDirection() const
Returns the side where the list is displayed.
TGUI_NODISCARD 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.
bool setSelectedItem(const String &itemName)
Selects an item from the list.
bool changeItemByIndex(std::size_t index, const String &newValue)
Changes the name of an item at the given index to newValue.
ExpandDirection
The side where the list will be displayed.
Definition ComboBox.hpp:44
void setDefaultText(const String &defaultText)
Changes the default text of the combo box. This is the text drawn when no item is selected.
bool changeItem(const String &originalValue, const String &newValue)
Changes an item with name originalValue to newValue.
void setChangeItemOnScroll(bool changeOnScroll)
Changes whether the mouse wheel can be used to change the selected item while the list is closed.
TGUI_NODISCARD bool containsId(const String &id) const
Returns whether the combo box contains an item with the given id.
TGUI_NODISCARD DataType getItemData(std::size_t index) const
Returns user data stored in the item.
Definition ComboBox.hpp:397
bool removeItem(const String &itemName)
Removes the item from the list with the given name.
std::shared_ptr< const ComboBox > ConstPtr
Shared constant widget pointer.
Definition ComboBox.hpp:53
static TGUI_NODISCARD ComboBox::Ptr create()
Creates a new combo box widget.
TGUI_NODISCARD bool getChangeItemOnScroll() const
Returns whether the mouse wheel can be used to change the selected item while the list is closed.
void removeAllItems()
Removes all items from the list.
void setExpandDirection(ExpandDirection direction)
Changes the side where the list is displayed.
TGUI_NODISCARD String getItemById(const String &id) const
Returns the item name of the item with the given id.
void deselectItem()
Deselects the selected item.
void setItemsToDisplay(std::size_t nrOfItemsInListToDisplay)
Changes the number of items that are displayed in the list.
void load(const std::unique_ptr< DataIO::Node > &node, const LoadingRenderersMap &renderers) override
Loads the widget from a tree of nodes.
TGUI_NODISCARD TGUI_NODISCARD ComboBoxRenderer * getRenderer() override
Returns the renderer, which gives access to functions that determine how the widget is displayed.
void setEnabled(bool enabled) override
Enables or disables the widget.
std::size_t addItem(const String &itemName, const String &id="")
Adds an item to the list, so that it can be selected later.
void rendererChanged(const String &property) override
Function called when one of the properties of the renderer is changed.
void setMaximumItems(std::size_t maximumItems=0)
Changes the maximum items that the combo box can contain.
bool leftMousePressed(Vector2f pos) override
Called by the parent when the left mouse button goes down on top of the widget.
TGUI_NODISCARD String getSelectedItemId() const
Gets the id of the selected item.
TGUI_NODISCARD String getSelectedItem() const
Returns the currently selected item.
bool setSelectedItemById(const String &id)
Selects an item from the list.
static TGUI_NODISCARD ComboBox::Ptr copy(const ComboBox::ConstPtr &comboBox)
Makes a copy of another combo box.
TGUI_NODISCARD bool isMouseOnWidget(Vector2f pos) const override
Returns whether the mouse position (which is relative to the parent widget) lies on top of the widget...
TGUI_NODISCARD int getSelectedItemIndex() const
Gets the index of the selected item.
bool scrolled(float delta, Vector2f pos, bool touch) override
Called by the parent on scroll event (either from mouse wheel of from two finger scrolling on a touch...
TGUI_NODISCARD const String & getDefaultText() const
Returns the default text of the combo box. This is the text drawn when no item is selected.
void setItemData(std::size_t index, Any data)
Store some user data with the item.
std::shared_ptr< ComboBox > Ptr
Shared widget pointer.
Definition ComboBox.hpp:52
TGUI_NODISCARD std::vector< String > getItemIds() const
Returns a copy of the item ids in the combo box.
bool removeItemByIndex(std::size_t index)
Removes the item from the list.
bool changeItemById(const String &id, const String &newValue)
Changes the name of an item with the given id to newValue.
Container widget.
Definition Container.hpp:48
Class to store the position or size of a widget.
Definition Layout.hpp:313
std::shared_ptr< ListBox > Ptr
Shared widget pointer.
Definition ListBox.hpp:43
Definition Outline.hpp:38
Signal to which the user can subscribe to get callbacks from.
Definition Signal.hpp:522
Signal to which the user can subscribe to get callbacks from.
Definition Signal.hpp:61
Definition Sprite.hpp:47
Wrapper class to store strings.
Definition String.hpp:96
Backend-independent wrapper around the backend-specific text class.
Definition Text.hpp:48
The parent class for every widget.
Definition Widget.hpp:83
std::shared_ptr< Widget > Ptr
Shared widget pointer.
Definition Widget.hpp:86
Namespace that contains all TGUI functions and classes.
Definition AbsoluteOrRelativeValue.hpp:38
States used for drawing.
Definition RenderStates.hpp:38