TGUI  1.7
Loading...
Searching...
No Matches
PanelListBox.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_PANEL_LIST_BOX_HPP
26#define TGUI_PANEL_LIST_BOX_HPP
27
28#include <TGUI/Widgets/ScrollablePanel.hpp>
29#include <TGUI/Renderers/PanelListBoxRenderer.hpp>
30
32
33TGUI_MODULE_EXPORT namespace tgui
34{
35
39 class TGUI_API PanelListBox : public ScrollablePanel
40 {
41 public:
42 using Ptr = std::shared_ptr<PanelListBox>;
43 using ConstPtr = std::shared_ptr<const PanelListBox>;
44
45 static constexpr const char StaticWidgetType[] = "PanelListBox";
46
54 PanelListBox(const char* typeName = StaticWidgetType, bool initRenderer = true);
55
60 static Ptr create();
61
67 static Ptr copy(const ConstPtr& panelListBox);
68
73 TGUI_NODISCARD PanelListBoxRenderer* getSharedRenderer() override;
74 TGUI_NODISCARD const PanelListBoxRenderer* getSharedRenderer() const override;
75
81 TGUI_NODISCARD PanelListBoxRenderer* getRenderer() override;
82
87 void setSize(const Layout2d& size) override;
88 using ScrollablePanel::setSize;
89
96 Panel::Ptr addItem(const String& id = {}, int index = -1);
97
103 TGUI_NODISCARD Panel::Ptr getPanelTemplate() const;
104
110 TGUI_NODISCARD Layout getItemsWidth() const;
111
117 void setItemsHeight(const Layout& height);
118
124 TGUI_NODISCARD Layout getItemsHeight() const;
125
139 bool setSelectedItem(const Panel::Ptr& panelPtr);
140
155
168 bool setSelectedItemByIndex(std::size_t index);
169
174
186 bool removeItem(const Panel::Ptr& panelPtr);
187
199 bool removeItemById(const String& id);
200
213 bool removeItemByIndex(std::size_t index);
214
219
229 TGUI_NODISCARD Panel::Ptr getItemById(const String& id) const;
230
238 TGUI_NODISCARD Panel::Ptr getItemByIndex(std::size_t index) const;
239
249 int getIndexById(const String& id) const;
250
258 int getIndexByItem(const Panel::Ptr& panelPtr) const;
259
267 String getIdByIndex(std::size_t index) const;
268
275 TGUI_NODISCARD Panel::Ptr getSelectedItem() const;
276
283 TGUI_NODISCARD String getSelectedItemId() const;
284
290 TGUI_NODISCARD int getSelectedItemIndex() const;
291
297 TGUI_NODISCARD int getHoveredItemIndex() const;
298
304 TGUI_NODISCARD std::size_t getItemCount() const;
305
311 TGUI_NODISCARD std::vector<Panel::Ptr> getItems() const;
312
318 TGUI_NODISCARD std::vector<String> getItemIds() const;
319
326 void setMaximumItems(std::size_t maximumItems = 0);
327
334 TGUI_NODISCARD std::size_t getMaximumItems() const;
335
343 bool contains(const Panel::Ptr& panelPtr) const;
344
352 bool containsId(const String& id) const;
353
357 void mouseMoved(Vector2f pos) override;
358
362 void mouseNoLongerOnWidget() override;
363
367 bool leftMousePressed(Vector2f pos) override;
368
370 protected:
371
381 TGUI_NODISCARD Signal& getSignal(String signalName) override;
382
388 void rendererChanged(const String& property) override;
389
393 TGUI_NODISCARD std::unique_ptr<DataIO::Node> save(SavingRenderersMap& renderers) const override;
394
398 void load(const std::unique_ptr<DataIO::Node>& node, const LoadingRenderersMap& renderers) override;
399
401 // Updates the position of the items
403 void updateItemsPositions() const;
404
406 // Updates the size of the items
408 void updateItemsSize() const;
409
411 // Returns all items height
413 TGUI_NODISCARD float getAllItemsHeight() const;
414
416 // Returns height of the items
417 //
420 TGUI_NODISCARD float getItemsHeightUpToIndex(std::size_t index) const;
421
423 // Update which item is selected
425 void updateSelectedItem(int item);
426
428 // Update on which item the mouse is standing
430 void updateHoveringItem(int item);
431
433 // Update the colors and style of the selected and hovered items
435 void updateSelectedAndHoveringItemColorsAndStyle() const;
436
438 // Clear item style
439 //
442 void clearItemStyle(int item) const;
443
445 // Clear all items style
447 void clearAllItemsStyle() const;
448
450 // Makes a copy of the widget
452 TGUI_NODISCARD Widget::Ptr clone() const override;
453
455 public:
456
457 SignalPanelListBoxItem onItemSelect = {"ItemSelected"};
458
460 protected:
461 struct Item
462 {
463 Panel::Ptr panel;
464 String id;
465 };
466
467 std::vector<Item> m_items;
468 std::size_t m_maxItems = 0;
469 Panel::Ptr m_panelTemplate = Panel::create();
470
471 int m_selectedItem = -1;
472 int m_hoveringItem = -1;
473
474 // Cached renderer properties
475 Color m_itemsBackgroundColorCached;
476 Color m_itemsBackgroundColorHoverCached;
477 Color m_selectedItemsBackgroundColorCached;
478 Color m_selectedItemsBackgroundColorHoverCached;
479
481 };
482
484}
485
487
488#endif // TGUI_PANEL_LIST_BOX_HPP
Wrapper for colors.
Definition Color.hpp:73
Class to store the position or size of a widget.
Definition Layout.hpp:323
Class to store the left, top, width or height of a widget.
Definition Layout.hpp:102
Definition PanelListBoxRenderer.hpp:36
List of panels, which can be flexible changed.
Definition PanelListBox.hpp:40
Widget::Ptr clone() const override
Makes a copy of the widget if you don't know its exact type.
bool removeItemById(const String &id)
Removes the item that were added with the given id.
bool setSelectedItemById(const String &id)
Selects an item in the panel list box.
PanelListBoxRenderer * getRenderer() override
Returns the renderer, which gives access to functions that determine how the widget is displayed.
std::shared_ptr< PanelListBox > Ptr
Shared widget pointer.
Definition PanelListBox.hpp:42
void rendererChanged(const String &property) override
Function called when one of the properties of the renderer is changed.
int getSelectedItemIndex() const
Gets the index of the selected item.
bool setSelectedItem(const Panel::Ptr &panelPtr)
Selects an item in the panel list box.
bool leftMousePressed(Vector2f pos) override
Called by the parent when the left mouse button goes down on top of the widget.
Layout getItemsWidth() const
Returns the width of the items in the list box.
String getIdByIndex(std::size_t index) const
Returns the id of the item at the given index.
std::vector< String > getItemIds() const
Returns a vector of stored items ids.
Panel::Ptr addItem(const String &id={}, int index=-1)
Adds an item to the list.
Panel::Ptr getItemByIndex(std::size_t index) const
Returns the item name of the item at the given index.
bool containsId(const String &id) const
Returns whether the panel list box contains an item with the given id.
PanelListBoxRenderer * getSharedRenderer() override
Returns the renderer, which gives access to functions that determine how the widget is displayed.
static Ptr copy(const ConstPtr &panelListBox)
Makes a copy of another panel list box.
Panel::Ptr getPanelTemplate() const
Get panel template from which new elements are created.
Panel::Ptr getSelectedItem() const
Returns the currently selected item.
std::size_t getItemCount() const
Returns the amount of items in the panel list box.
void load(const std::unique_ptr< DataIO::Node > &node, const LoadingRenderersMap &renderers) override
Loads the widget from a tree of nodes.
void setItemsHeight(const Layout &height)
Changes the height of the items in the list box.
std::size_t getMaximumItems() const
Returns the maximum items that the list box can contain.
Layout getItemsHeight() const
Returns the height of the items in the list box.
Signal & getSignal(String signalName) override
Retrieves a signal based on its name.
void clearItemStyle(int item) const
std::vector< Panel::Ptr > getItems() const
Returns a copy of the items in the list box.
void setMaximumItems(std::size_t maximumItems=0)
Changes the maximum items that the list box can contain.
std::shared_ptr< const PanelListBox > ConstPtr
Shared constant widget pointer.
Definition PanelListBox.hpp:43
String getSelectedItemId() const
Gets the id of the selected item.
static Ptr create()
Creates a new panel list box widget.
float getItemsHeightUpToIndex(std::size_t index) const
void deselectItem()
Deselects the selected item.
Panel::Ptr getItemById(const String &id) const
Returns the item name of the item with the given id.
bool removeItem(const Panel::Ptr &panelPtr)
Removes the item from the panel list with the given pointer.
bool removeItemByIndex(std::size_t index)
Removes the item from the panel list box.
bool contains(const Panel::Ptr &panelPtr) const
Returns whether the panel list box contains the given item.
int getIndexByItem(const Panel::Ptr &panelPtr) const
Returns the index of the given item.
int getHoveredItemIndex() const
Gets the index of the item below the mouse cursor.
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 setSize(const Layout2d &size) override
Changes the size of the panel list box.
void removeAllItems()
Removes all items from the list.
bool setSelectedItemByIndex(std::size_t index)
Selects an item in the panel list box.
int getIndexById(const String &id) const
Returns the index of the item with the given id.
std::shared_ptr< Panel > Ptr
Shared widget pointer.
Definition Panel.hpp:42
Group of widgets that has a background color and optional borders.
Definition ScrollablePanel.hpp:44
Signal to which the user can subscribe to get callbacks from.
Definition Signal.hpp:630
Signal to which the user can subscribe to get callbacks from.
Definition Signal.hpp:61
Wrapper class to store strings.
Definition String.hpp:96
std::shared_ptr< Widget > Ptr
Shared widget pointer.
Definition Widget.hpp:86
Namespace that contains all TGUI functions and classes.
Definition AbsoluteOrRelativeValue.hpp:38
Definition PanelListBox.hpp:462