|  | 
|  | QStateMachine (QObject *parent=nullptr) | 
|  | 
|  | ~QStateMachine () | 
|  | 
| void | addDefaultAnimation (QAbstractAnimation *animation) | 
|  | 
| void | addState (QAbstractState *state) | 
|  | 
| bool | cancelDelayedEvent (int id) | 
|  | 
| void | clearError () | 
|  | 
| QSet< QAbstractState * > | configuration () const | 
|  | 
| QList< QAbstractAnimation * > | defaultAnimations () const | 
|  | 
| Error | error () const | 
|  | 
| QString | errorString () const | 
|  | 
| bool | eventFilter (QObject *watched, QEvent *event) override | 
|  | 
| QState::RestorePolicy | globalRestorePolicy () const | 
|  | 
| bool | isAnimated () const | 
|  | 
| bool | isRunning () const | 
|  | 
| int | postDelayedEvent (QEvent *event, int delay) | 
|  | 
| void | postEvent (QEvent *event, EventPriority priority=NormalPriority) | 
|  | 
| void | removeDefaultAnimation (QAbstractAnimation *animation) | 
|  | 
| void | removeState (QAbstractState *state) | 
|  | 
| void | setAnimated (bool enabled) | 
|  | 
| void | setGlobalRestorePolicy (QState::RestorePolicy restorePolicy) | 
|  | 
|  | QState (ChildMode childMode, QState *parent=nullptr) | 
|  | 
|  | QState (QState *parent=nullptr) | 
|  | 
|  | ~QState () | 
|  | 
| QAbstractTransition * | addTransition (QAbstractState *target) | 
|  | 
| void | addTransition (QAbstractTransition *transition) | 
|  | 
| template<class SignalClass , class... SignalArgs> | 
| QSignalTransition * | addTransition (QObject *sender, void (SignalClass::*signal)(SignalArgs...), QAbstractState *target) | 
|  | 
| void | assignProperty (QObject *object, const QString &name, const QVariant &value) | 
|  | 
| ChildMode | childMode () const | 
|  | 
| QAbstractState * | errorState () const | 
|  | 
| QAbstractState * | initialState () const | 
|  | 
| void | removeTransition (QAbstractTransition *transition) | 
|  | 
| void | setChildMode (ChildMode mode) | 
|  | 
| void | setErrorState (QAbstractState *state) | 
|  | 
| void | setInitialState (QAbstractState *state) | 
|  | 
| QList< QAbstractTransition * > | transitions () const | 
|  | 
|  | ~QAbstractState () | 
|  | 
| bool | active () const | 
|  | 
| QStateMachine * | machine () const | 
|  | 
| QState * | parentState () const | 
|  | 
|  | QObject (QObject *parent=nullptr) | 
|  | 
|  | ~QObject () | 
|  | 
| bool | blockSignals (bool block) | 
|  | 
| const QList< QObject * > & | children () const | 
|  | 
| bool | connect (const QObject *sender, const QString &signalMethod, const QString &location, const QString &slotMethod, Qt::ConnectionType type=Qt::AutoConnection) | 
|  | 
| bool | connect (const QObject *sender, const QString &signalMethod, const QString &slotMethod, Qt::ConnectionType type=Qt::AutoConnection) | 
|  | 
| bool | disconnect (const QObject *receiver, const QString &slotMethod=QString ()) const | 
|  | 
| bool | disconnect (const QString &signalMethod, const QString &location, const QObject *receiver=nullptr, const QString &slotMethod=QString ()) const | 
|  | 
| bool | disconnect (const QString &signalMethod=QString (), const QObject *receiver=nullptr, const QString &slotMethod=QString ()) const | 
|  | 
| void | dumpObjectInfo () | 
|  | 
| void | dumpObjectTree () | 
|  | 
| QList< QString > | dynamicPropertyNames () const | 
|  | 
| template<typename T > | 
| T | findChild (const QString &childName=QString ()) const | 
|  | 
| template<class T > | 
| QList< T > | findChildren (const QRegularExpression ®Exp, Qt::FindChildOptions options=Qt::FindChildrenRecursively) const | 
|  | 
| template<class T > | 
| QList< T > | findChildren (const QString &childName=QString (), Qt::FindChildOptions options=Qt::FindChildrenRecursively) const | 
|  | 
| bool | inherits (const QString &className) const | 
|  | 
| void | installEventFilter (QObject *filterObj) | 
|  | 
| bool | isWidgetType () const | 
|  | 
| bool | isWindowType () const | 
|  | 
| void | killTimer (int id) | 
|  | 
| const QMetaObject * | metaObject () const | 
|  | 
| void | moveToThread (QThread *targetThread) | 
|  | 
| QString | objectName () const | 
|  | 
| QObject * | parent () const | 
|  | 
| template<class T  = QVariant> | 
| T | property (const QString &name) const | 
|  | 
| void | removeEventFilter (QObject *obj) | 
|  | 
| void | setObjectName (const QString &name) | 
|  | 
| void | setParent (QObject *parent) | 
|  | 
| bool | setProperty (const QString &name, const QVariant &value) | 
|  | 
| bool | signalsBlocked () const | 
|  | 
| int | startTimer (int interval, Qt::TimerType timerType=Qt::CoarseTimer) | 
|  | 
| QThread * | thread () const | 
|  | 
|  | 
| static bool | connect (const QObject *sender, const QMetaMethod &signalMethod, const QObject *receiver, const QMetaMethod &slotMethod, Qt::ConnectionType type=Qt::AutoConnection) | 
|  | 
| static bool | connect (const QObject *sender, const QString &signalMethod, const QObject *receiver, const QString &slotMethod, Qt::ConnectionType type=Qt::AutoConnection, const QString &location=QString ()) | 
|  | 
| static bool | connect (const QObject *sender, const QString &signalMethod, const QString &location, const QObject *receiver, const QString &slotMethod, Qt::ConnectionType type=Qt::AutoConnection) | 
|  | 
| template<class Sender , class SignalClass , class... SignalArgs, class Receiver , class SlotClass , class... SlotArgs, class SlotReturn > | 
| static bool | connect (const Sender *sender, void (SignalClass::*signalMethod)(SignalArgs...), const Receiver *receiver, SlotReturn (SlotClass::*slotMethod)(SlotArgs...), Qt::ConnectionType type=Qt::AutoConnection) | 
|  | 
| template<class Sender , class SignalClass , class... SignalArgs, class Receiver , class T > | 
| static bool | connect (const Sender *sender, void (SignalClass::*signalMethod)(SignalArgs...), const Receiver *receiver, T slotLambda, Qt::ConnectionType type=Qt::AutoConnection) | 
|  | 
| static bool | disconnect (const QObject *sender, const QMetaMethod &signalMethod, const QObject *receiver, const QMetaMethod &slotMethod) | 
|  | 
| static bool | disconnect (const QObject *sender, const QString &signalMethod, const QObject *receiver, const QString &slotMethod) | 
|  | 
| static bool | disconnect (const QObject *sender, const QString &signalMethod, const QString &location, const QObject *receiver, const QString &slotMethod) | 
|  | 
| static bool | disconnect (const QObject *sender, std::nullptr_t, const QObject *receiver, std::nullptr_t) | 
|  | 
| template<class Sender , class SignalClass , class... SignalArgs, class Receiver , class SlotClass , class... SlotArgs, class SlotReturn > | 
| static bool | disconnect (const Sender *sender, void (SignalClass::*signalMethod)(SignalArgs...), const Receiver *receiver, SlotReturn (SlotClass::*slotMethod)(SlotArgs...)) | 
|  | 
| template<class Sender , class SignalClass , class... SignalArgs, class Receiver > | 
| static bool | disconnect (const Sender *sender, void (SignalClass::*signalMethod)(SignalArgs...), const Receiver *receiver, std::nullptr_t slotMethod=nullptr) | 
|  | 
| template<class Sender , class SignalClass , class... SignalArgs, class Receiver , class T > | 
| static bool | disconnect (const Sender *sender, void (SignalClass::*signalMethod)(SignalArgs...), const Receiver *receiver, T slotMethod) | 
|  | 
| static QMetaObject & | staticMetaObject () | 
|  | 
| static QString | tr (const char *text, const char *comment=nullptr, std::optional< int > numArg=std::optional< int >()) | 
|  | 
| T | qobject_cast (QObject *object) | 
|  | 
|  | QObjectList | 
|  | 
The QStateMachine class provides a hierarchical finite state machine. This class is based on the concepts and notation of "Statecharts: A visual formalism for complex systems".
A state machine manages a set of states (classes that inherit from QAbstractState) and transitions (descendants of QAbstractTransition) between those states; these states and transitions define a state graph. Once a state graph has been built, the state machine can execute it. QStateMachine's execution algorithm is based on the "State Chart XML: State Machine Notation for Control Abstraction" algorithm. The State Machine gives several state graphs and the code to build them.
Use the addState() function to add a top-level state to the state machine. States are removed with the removeState() function. Removing states while the machine is running is discouraged.
Before the machine can be started, the initial state must be set. The initial state is the state that the machine enters when started. You can then start() the state machine. The started() signal is emitted when the initial state is entered.
The machine is event driven and keeps its own event loop. Events are posted to the machine through postEvent(). Note that this means that it executes asynchronously, and that it will not progress without a running event loop. You will normally not have to post events to the machine directly as the CopperSpice transitions, e.g., QEventTransition and its subclasses, handle this. But for custom transitions triggered by events, postEvent() is useful.
The state machine processes events and takes transitions until a top-level final state is entered; the state machine then emits the finished() signal. You can also stop() the state machine explicitly. The stopped() signal is emitted in this case.
The following code shows a state machine that will finish when a button is clicked:
 
s1->assignProperty(&button, "text", "Click me");
 
s1->addTransition(&button, SIGNAL(clicked()), s2);
 
 
This code example uses QState, which inherits QAbstractState. The QState class provides a state that you can use to set properties and invoke methods on QObjects when the state is entered or exited. It also contains convenience functions for adding transitions, e.g., QSignalTransitions as in this example. See the QState class description for further details.
If an error is encountered, the machine will look for an error state, and if one is available, it will enter this state. The types of errors possible are described by the Error enum. After the error state is entered, the type of the error can be retrieved with error(). The execution of the state graph will not stop when the error state is entered. If no error state applies to the erroneous state, the machine will stop executing and an error message will be printed to the console.
- See also
- QAbstractState, QAbstractTransition, QState, State Machine