TGUI  1.7
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
180 void addMultipleItems(const std::vector<String>& itemNames);
181
199 bool setSelectedItem(const String& itemName);
200
219
232 bool setSelectedItemByIndex(std::size_t index);
233
240
252 bool removeItem(const String& itemName);
253
265 bool removeItemById(const String& id);
266
279 bool removeItemByIndex(std::size_t index);
280
285
295 TGUI_NODISCARD String getItemById(const String& id) const;
296
306 TGUI_NODISCARD String getItemByIndex(std::size_t index) const;
307
319 TGUI_NODISCARD int getIndexById(const String& id) const;
320
330 TGUI_NODISCARD String getIdByIndex(std::size_t index) const;
331
338 TGUI_NODISCARD String getSelectedItem() const;
339
346 TGUI_NODISCARD String getSelectedItemId() const;
347
353 TGUI_NODISCARD int getSelectedItemIndex() const;
354
367 bool changeItem(const String& originalValue, const String& newValue);
368
381 bool changeItemById(const String& id, const String& newValue);
382
393 bool changeItemByIndex(std::size_t index, const String& newValue);
394
400 TGUI_NODISCARD std::size_t getItemCount() const;
401
407 TGUI_NODISCARD std::vector<String> getItems() const;
408
416 TGUI_NODISCARD std::vector<String> getItemIds() const;
417
432 void setItemData(std::size_t index, Any data);
433
442 template <typename DataType>
443 TGUI_NODISCARD DataType getItemData(std::size_t index) const
444 {
445 return m_listBox->getItemData<DataType>(index);
446 }
447
456 void setMaximumItems(std::size_t maximumItems = 0);
457
464 TGUI_NODISCARD std::size_t getMaximumItems() const;
465
471 void setDefaultText(const String& defaultText);
472
478 TGUI_NODISCARD const String& getDefaultText() const;
479
485
490 TGUI_NODISCARD ExpandDirection getExpandDirection() const;
491
496 TGUI_NODISCARD bool contains(const String& item) const;
497
502 TGUI_NODISCARD bool containsId(const String& id) const;
503
509 void setChangeItemOnScroll(bool changeOnScroll);
510
516 TGUI_NODISCARD bool getChangeItemOnScroll() const;
517
523 void setParent(Container* parent) override;
524
530 TGUI_NODISCARD bool isMouseOnWidget(Vector2f pos) const override;
531
535 bool leftMousePressed(Vector2f pos) override;
536
540 bool scrolled(float delta, Vector2f pos, bool touch) override;
541
548 void draw(BackendRenderTarget& target, RenderStates states) const override;
549
551 protected:
552
562 TGUI_NODISCARD Signal& getSignal(String signalName) override;
563
569 void rendererChanged(const String& property) override;
570
574 TGUI_NODISCARD std::unique_ptr<DataIO::Node> save(SavingRenderersMap& renderers) const override;
575
579 void load(const std::unique_ptr<DataIO::Node>& node, const LoadingRenderersMap& renderers) override;
580
584 void updateTextSize() override;
585
587 // Returns the size without the borders
589 TGUI_NODISCARD Vector2f getInnerSize() const;
590
592 // Update the height of the internal list box
594 void updateListBoxHeight();
595
597 // Shows the list of items.
599 void showListBox();
600
602 // Hides the list of items.
604 void hideListBox();
605
607 // Initialize the internal list box
609 void initListBox();
610
612 // Makes a copy of the widget
614 TGUI_NODISCARD Widget::Ptr clone() const override;
615
617 public:
618
619 SignalItem onItemSelect = {"ItemSelected"};
620
622 protected:
623
624 // The number of items to display. If there is a scrollbar then you can scroll to see the other.
625 // If there is no scrollbar then this will be the maximum amount of items.
626 std::size_t m_nrOfItemsToDisplay = 0;
627
628 // Internally a list box is used to store all items
629 ListBox::Ptr m_listBox = ListBox::create();
630
631 Text m_text;
632 Text m_defaultText;
633
634 int m_previousSelectedItemIndex = -1;
635 bool m_changeItemOnScroll = false;
636
637 ExpandDirection m_expandDirection = ExpandDirection::Automatic;
638
639 Sprite m_spriteBackground;
640 Sprite m_spriteBackgroundDisabled;
641 Sprite m_spriteArrow;
642 Sprite m_spriteArrowHover;
643 Sprite m_spriteArrowDisabled;
644
645 // Cached renderer properties
646 Borders m_bordersCached;
647 Padding m_paddingCached;
648 Color m_borderColorCached;
649 Color m_backgroundColorCached;
650 Color m_backgroundColorDisabledCached;
651 Color m_arrowColorCached;
652 Color m_arrowColorHoverCached;
653 Color m_arrowColorDisabledCached;
654 Color m_arrowBackgroundColorCached;
655 Color m_arrowBackgroundColorHoverCached;
656 Color m_arrowBackgroundColorDisabledCached;
657 Color m_textColorCached;
658 Color m_textColorDisabledCached;
659
661 };
662
664}
665
667
668#endif // TGUI_COMBO_BOX_HPP
669
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
static ComboBox::Ptr create()
Creates a new combo box widget.
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.
Signal & getSignal(String signalName) override
Retrieves a signal based on its name.
bool contains(const String &item) const
Returns whether the combo box contains the given item.
void setSize(const Layout2d &size) override
Changes the size of the combo box.
ComboBoxRenderer * getRenderer() override
Returns the renderer, which gives access to functions that determine how the widget is displayed.
void draw(BackendRenderTarget &target, RenderStates states) const override
Draw the widget to a render target.
String getIdByIndex(std::size_t index) const
Returns the id of the item at the given index.
std::size_t getItemCount() const
Returns the amount of items in the combo box.
bool setSelectedItemByIndex(std::size_t index)
Selects an item in the list.
String getSelectedItemId() const
Gets the id of the selected item.
std::vector< String > getItemIds() const
Returns a copy of the item ids in the combo box.
String getSelectedItem() const
Returns the currently selected item.
bool getChangeItemOnScroll() const
Returns whether the mouse wheel can be used to change the selected item while the list is closed.
int getIndexById(const String &id) const
Returns the index of the item with the given id.
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.
bool removeItem(const String &itemName)
Removes the item from the list with the given name.
const String & getDefaultText() const
Returns the default text of the combo box. This is the text drawn when no item is selected.
static ComboBox::Ptr copy(const ComboBox::ConstPtr &comboBox)
Makes a copy of another combo box.
std::shared_ptr< const ComboBox > ConstPtr
Shared constant widget pointer.
Definition ComboBox.hpp:53
Widget::Ptr clone() const override
Makes a copy of the widget if you don't know its exact type.
bool containsId(const String &id) const
Returns whether the combo box contains an item with the given id.
int getSelectedItemIndex() const
Gets the index of the selected item.
void removeAllItems()
Removes all items from the list.
void setExpandDirection(ExpandDirection direction)
Changes the side where the list is displayed.
void deselectItem()
Deselects the selected item.
void setItemsToDisplay(std::size_t nrOfItemsInListToDisplay)
Changes the number of items that are displayed in the list.
std::size_t getMaximumItems() const
Returns the maximum items that the combo box can contain.
void load(const std::unique_ptr< DataIO::Node > &node, const LoadingRenderersMap &renderers) override
Loads the widget from a tree of nodes.
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.
bool isMouseOnWidget(Vector2f pos) const override
Returns whether the mouse position (which is relative to the parent widget) lies on top of the widget...
DataType getItemData(std::size_t index) const
Returns user data stored in the item.
Definition ComboBox.hpp:443
void setMaximumItems(std::size_t maximumItems=0)
Changes the maximum items that the combo box can contain.
std::size_t getItemsToDisplay() const
Returns the number of items that are displayed in the list.
bool leftMousePressed(Vector2f pos) override
Called by the parent when the left mouse button goes down on top of the widget.
bool setSelectedItemById(const String &id)
Selects an item from the list.
String getItemById(const String &id) const
Returns the item name of the item with the given id.
void addMultipleItems(const std::vector< String > &itemNames)
Adds multiple items to the list.
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...
ExpandDirection getExpandDirection() const
Returns the side where the list is displayed.
ComboBoxRenderer * getSharedRenderer() override
Returns the renderer, which gives access to functions that determine how the widget is displayed.
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
String getItemByIndex(std::size_t index) const
Returns the item name of the item at the given index.
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.
std::vector< String > getItems() const
Returns a copy of the items in the combo box.
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.
Container widget.
Definition Container.hpp:48
Class to store the position or size of a widget.
Definition Layout.hpp:323
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