QAbstractState Class
The QAbstractState class is the base class of states of a QStateMachine. More...
Header: | #include <QAbstractState> |
CMake: | find_package(Qt6 REQUIRED COMPONENTS StateMachine) target_link_libraries(mytarget PRIVATE Qt6::StateMachine) |
qmake: | QT += statemachine |
Inherits: | QObject |
Inherited By: | QFinalState, QHistoryState, and QState |
Properties
- active : bool
Public Functions
virtual | ~QAbstractState() |
bool | active() const |
QBindable<bool> | bindableActive() |
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 Qt 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
[bindable read-only]
active : bool
Note: This property supports QProperty bindings.
This property holds the active property of this state. A state is active between entered() and exited() signals.
Member Function Documentation
[protected]
QAbstractState::QAbstractState(QState *parent = nullptr)
Constructs a new state with the given parent state.
[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().
[signal]
void QAbstractState::activeChanged(bool active)
This signal is emitted when the active property is changed with active as argument.
Note: Notifier signal for property active.
See also QAbstractState::active, entered(), and exited().
[private 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.
[override virtual protected]
bool QAbstractState::event(QEvent *e)
Reimplements: QObject::event(QEvent *e).
[private 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.
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.
© 2025 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.