QAbstractState Class
The QAbstractState class is the base class of states of a QStateMachine. More...
Header: | #include <QAbstractState> |
qmake: | QT += core |
Since: | Qt 4.6 |
Inherits: | QObject |
Inherited By: | QFinalState, QHistoryState, and QState |
This class was introduced in Qt 4.6.
Properties
- active : const bool
Public Functions
virtual | ~QAbstractState() |
bool | active() const |
QStateMachine * | machine() const |
QState * | parentState() const |
Signals
void | activeChanged(bool active) |
void | entered() |
void | exited() |
Protected Functions
QAbstractState(QState *parent = nullptr) | |
virtual void | onEntry(QEvent *event) = 0 |
virtual void | onExit(QEvent *event) = 0 |
Reimplemented Protected Functions
virtual bool | event(QEvent *e) override |
Detailed Description
The QAbstractState class is the abstract base class of states that are part of a QStateMachine. It defines the interface that all state objects have in common. QAbstractState is part of The State Machine Framework.
The entered() signal is emitted when the state has been entered. The exited() signal is emitted when the state has been exited.
The parentState() function returns the state's parent state. The machine() function returns the state machine that the state is part of.
Subclassing
The onEntry() function is called when the state is entered; reimplement this function to perform custom processing when the state is entered.
The onExit() function is called when the state is exited; reimplement this function to perform custom processing when the state is exited.
Property Documentation
active : const bool
This property holds the active property of this state. A state is active between entered() and exited() signals.
This property was introduced in Qt 5.4.
Access functions:
bool | active() const |
Notifier signal:
void | activeChanged(bool active) |
Member Function Documentation
[protected]
QAbstractState::QAbstractState(QState *parent = nullptr)
Constructs a new state with the given parent state.
[signal]
void QAbstractState::activeChanged(bool active)
This signal is emitted when the active property is changed with active as argument.
This function was introduced in Qt 5.4.
Note: Notifier signal for property active.
See also QAbstractState::active, entered(), and exited().
[signal]
void QAbstractState::entered()
This signal is emitted when the state has been entered (after onEntry() has been called).
Note: This is a private signal. It can be used in signal connections but cannot be emitted by the user.
[signal]
void QAbstractState::exited()
This signal is emitted when the state has been exited (after onExit() has been called).
Note: This is a private signal. It can be used in signal connections but cannot be emitted by the user.
[virtual]
QAbstractState::~QAbstractState()
Destroys this state.
bool QAbstractState::active() const
Returns whether this state is active.
Note: Getter function for property active.
See also activeChanged(bool), entered(), and exited().
[override virtual protected]
bool QAbstractState::event(QEvent *e)
Reimplements: QObject::event(QEvent *e).
QStateMachine *QAbstractState::machine() const
Returns the state machine that this state is part of, or nullptr
if the state is not part of a state machine.
[pure virtual protected]
void QAbstractState::onEntry(QEvent *event)
This function is called when the state is entered. The given event is what caused the state to be entered. Reimplement this function to perform custom processing when the state is entered.
[pure virtual protected]
void QAbstractState::onExit(QEvent *event)
This function is called when the state is exited. The given event is what caused the state to be exited. Reimplement this function to perform custom processing when the state is exited.
QState *QAbstractState::parentState() const
Returns this state's parent state, or nullptr
if the state has no parent state.
© 2020 The Qt Company Ltd. Documentation contributions included herein are the copyrights of their respective owners. The documentation provided herein is licensed under the terms of the GNU Free Documentation License version 1.3 as published by the Free Software Foundation. Qt and respective logos are trademarks of The Qt Company Ltd. in Finland and/or other countries worldwide. All other trademarks are property of their respective owners.