QSignalTransition露
- PyQt5.QtCore.QSignalTransition
Inherits from QAbstractTransition.
Description露
The QSignalTransition class provides a transition based on a Qt signal.
Typically you would use the overload of addTransition() that takes a sender and signal as arguments, rather than creating QSignalTransition objects directly. QSignalTransition is part of The State Machine Framework.
You can subclass QSignalTransition and reimplement eventTest() to make a signal transition conditional; the event object passed to eventTest() will be a SignalEvent object. Example:
class CheckedTransition : public QSignalTransition
{
public:
CheckedTransition(QCheckBox *check)
: QSignalTransition(check, SIGNAL(stateChanged(int))) {}
protected:
bool eventTest(QEvent *e) {
if (!QSignalTransition::eventTest(e))
return false;
QStateMachine::SignalEvent *se = static_cast<QStateMachine::SignalEvent*>(e);
return (se->arguments().at(0).toInt() == Qt::Checked);
}
};
...
QCheckBox *check = new QCheckBox();
check->setTristate(true);
QState *s1 = new QState();
QState *s2 = new QState();
CheckedTransition *t1 = new CheckedTransition(check);
t1->setTargetState(s2);
s1->addTransition(t1);
Methods露
- __init__(sourceState: QState = None)
Constructs a new signal transition with the given sourceState.
- __init__(pyqtBoundSignal, sourceState: QState = None)
TODO
- event(QEvent) → bool
TODO
- eventTest(QEvent) → bool
TODO
- onTransition(QEvent)
TODO
- senderObject() → QObject
Returns the sender object associated with this signal transition.
See also
- setSenderObject(QObject)
Sets the sender object associated with this signal transition.
See also
- setSignal(Union[QByteArray, bytes, bytearray])
Sets the signal associated with this signal transition.
See also
- signal() → QByteArray
Returns the signal associated with this signal transition.
See also