TGUI  1.5
Loading...
Searching...
No Matches
tgui::SignalItem Class Reference

Signal to which the user can subscribe to get callbacks from. More...

#include <TGUI/Signal.hpp>

Inheritance diagram for tgui::SignalItem:
tgui::Signal

Public Member Functions

 SignalItem (String &&name)
 Constructor.
 
template<typename Func , typename... BoundArgs>
unsigned int operator() (const Func &func, const BoundArgs &... args)
 Connects a signal handler that will be called when this signal is emitted.
 
template<typename Func , typename... BoundArgs, typename std::enable_if_t< std::is_convertible< Func, std::function< void(const BoundArgs &...)> >::value > * = nullptr>
unsigned int connect (const Func &func, const BoundArgs &... args)
 Connects a signal handler that will be called when this signal is emitted.
 
template<typename Func , typename... BoundArgs, typename std::enable_if_t< std::is_convertible< Func, std::function< void(const BoundArgs &..., int)> >::value > * = nullptr>
unsigned int connect (const Func &func, const BoundArgs &... args)
 Connects a signal handler that will be called when this signal is emitted.
 
template<typename Func , typename... BoundArgs, typename std::enable_if_t< std::is_convertible< Func, std::function< void(const BoundArgs &..., const String &)> >::value > * = nullptr>
unsigned int connect (const Func &func, const BoundArgs &... args)
 Connects a signal handler that will be called when this signal is emitted.
 
template<typename Func , typename... BoundArgs, typename std::enable_if_t< std::is_convertible< Func, std::function< void(const BoundArgs &..., const String &, const String &)> >::value > * = nullptr>
unsigned int connect (const Func &func, const BoundArgs &... args)
 Connects a signal handler that will be called when this signal is emitted.
 
bool emit (const Widget *widget, int index, const String &item, const String &id)
 Call all connected signal handlers.
 
- Public Member Functions inherited from tgui::Signal
virtual ~Signal ()=default
 Default destructor.
 
 Signal (String &&name, std::size_t extraParameters=0)
 Constructor.
 
 Signal (const Signal &other)
 Copy constructor which will not copy the signal handlers.
 
 Signal (Signal &&other) noexcept=default
 Default move constructor.
 
Signaloperator= (const Signal &other)
 Copy assignment operator which will not copy the signal handlers.
 
Signaloperator= (Signal &&other) noexcept=default
 Default move assignment operator.
 
template<typename Func , typename... BoundArgs>
unsigned int operator() (const Func &func, const BoundArgs &... args)
 Connects a signal handler that will be called when this signal is emitted.
 
template<typename Func , typename... BoundArgs, typename std::enable_if_t< std::is_convertible< Func, std::function< void(const BoundArgs &...)> >::value > * = nullptr>
unsigned int connect (const Func &func, const BoundArgs &... args)
 Connects a signal handler that will be called when this signal is emitted.
 
template<typename Func , typename... BoundArgs, typename std::enable_if_t< std::is_convertible< Func, std::function< void(const BoundArgs &..., const std::shared_ptr< Widget > &, const String &)> >::value , * = nullptr>
unsigned int connectEx (const Func &func, const BoundArgs &... args)
 Connects a signal handler that will be called when this signal is emitted.
 
bool disconnect (unsigned int id)
 Disconnect a signal handler from this signal.
 
void disconnectAll ()
 Disconnect all signal handler from this signal.
 
bool emit (const Widget *widget)
 Call all connected signal handlers.
 
TGUI_NODISCARD String getName () const
 Returns the name given to the signal.
 
void setEnabled (bool enabled)
 Changes whether this signal calls the connected functions when triggered.
 
TGUI_NODISCARD bool isEnabled () const
 Returns whether this signal calls the connected functions when triggered.
 

Additional Inherited Members

- Static Protected Member Functions inherited from tgui::Signal
static std::shared_ptr< WidgetgetWidget ()
 Extracts the widget stored in the first parameter.
 
template<typename Type >
static TGUI_NODISCARD const std::decay_t< Type > & dereferenceParam (std::size_t paramIndex)
 Turns the void* parameters back into its original type right before calling the callback function.
 
template<typename Func , typename... Args, typename std::enable_if_t< std::is_member_pointer< std::decay_t< Func > >::value > * = nullptr>
static void invokeFunc (Func &&func, Args &&... args)
 
template<typename Func , typename... Args, typename std::enable_if_t<!std::is_member_pointer< std::decay_t< Func > >::value > * = nullptr>
static void invokeFunc (Func &&func, Args &&... args)
 
- Protected Attributes inherited from tgui::Signal
bool m_enabled = true
 
String m_name
 
std::unordered_map< unsigned int, std::function< void()> > m_handlers
 
- Static Protected Attributes inherited from tgui::Signal
static unsigned int m_lastSignalId
 
static std::deque< const void * > m_parameters
 

Detailed Description

Signal to which the user can subscribe to get callbacks from.

Optional unbound parameters:

Member Function Documentation

◆ connect() [1/4]

template<typename Func , typename... BoundArgs, typename std::enable_if_t< std::is_convertible< Func, std::function< void(const BoundArgs &...)> >::value > * = nullptr>
unsigned int tgui::SignalItem::connect ( const Func & func,
const BoundArgs &... args )
inline

Connects a signal handler that will be called when this signal is emitted.

Parameters
funcCallback function without unbound parameters
argsAdditional arguments to pass to the function
Returns
Unique id of the connection

◆ connect() [2/4]

template<typename Func , typename... BoundArgs, typename std::enable_if_t< std::is_convertible< Func, std::function< void(const BoundArgs &..., int)> >::value > * = nullptr>
unsigned int tgui::SignalItem::connect ( const Func & func,
const BoundArgs &... args )
inline

Connects a signal handler that will be called when this signal is emitted.

Parameters
funcCallback function that has an unbound integer (for the index) as last parameter
argsAdditional arguments to pass to the function
Returns
Unique id of the connection

◆ connect() [3/4]

template<typename Func , typename... BoundArgs, typename std::enable_if_t< std::is_convertible< Func, std::function< void(const BoundArgs &..., const String &)> >::value > * = nullptr>
unsigned int tgui::SignalItem::connect ( const Func & func,
const BoundArgs &... args )
inline

Connects a signal handler that will be called when this signal is emitted.

Parameters
funcCallback function that has an unbound string (for the item text) as last parameter
argsAdditional arguments to pass to the function
Returns
Unique id of the connection

◆ connect() [4/4]

template<typename Func , typename... BoundArgs, typename std::enable_if_t< std::is_convertible< Func, std::function< void(const BoundArgs &..., const String &, const String &)> >::value > * = nullptr>
unsigned int tgui::SignalItem::connect ( const Func & func,
const BoundArgs &... args )
inline

Connects a signal handler that will be called when this signal is emitted.

Parameters
funcCallback function that has 2 unbound strings (for the item text and id) as last parameters
argsAdditional arguments to pass to the function
Returns
Unique id of the connection

◆ emit()

bool tgui::SignalItem::emit ( const Widget * widget,
int index,
const String & item,
const String & id )

Call all connected signal handlers.

Parameters
widgetWidget that is triggering the signal
indexIndex of the item, or -1 if there is no item
itemText of the item, or an empty string if there is no item
idId of the item, or an empty string if there is no item
Returns
True when a callback function was executed, false when there weren't any connected callback functions

◆ operator()()

template<typename Func , typename... BoundArgs>
unsigned int tgui::SignalItem::operator() ( const Func & func,
const BoundArgs &... args )
inline

Connects a signal handler that will be called when this signal is emitted.

Parameters
funcCallback function that can be passed to the connect function
argsAdditional arguments to pass to the function
Returns
Unique id of the connection

The documentation for this class was generated from the following file: