QKeyframeAnimation Class

class Qt3DAnimation::QKeyframeAnimation

A class implementing simple keyframe animation to a QTransform. More...

Header: #include <QKeyframeAnimation>
CMake: find_package(Qt6 REQUIRED COMPONENTS 3danimation)
target_link_libraries(mytarget PRIVATE Qt6::3danimation)
qmake: QT += 3danimation
Instantiated By: KeyframeAnimation
Inherits: Qt3DAnimation::QAbstractAnimation

Public Types

enum RepeatMode { None, Constant, Repeat }

Properties

Public Functions

QKeyframeAnimation(QObject *parent = nullptr)
void addKeyframe(Qt3DCore::QTransform *keyframe)
QEasingCurve easing() const
Qt3DAnimation::QKeyframeAnimation::RepeatMode endMode() const
QList<float> framePositions() const
QList<Qt3DCore::QTransform *> keyframeList() const
void removeKeyframe(Qt3DCore::QTransform *keyframe)
void setKeyframes(const QList<Qt3DCore::QTransform *> &keyframes)
Qt3DAnimation::QKeyframeAnimation::RepeatMode startMode() const
Qt3DCore::QTransform *target() const
QString targetName() const

Public Slots

void setEasing(const QEasingCurve &easing)
void setEndMode(Qt3DAnimation::QKeyframeAnimation::RepeatMode mode)
void setFramePositions(const QList<float> &positions)
void setStartMode(Qt3DAnimation::QKeyframeAnimation::RepeatMode mode)
void setTarget(Qt3DCore::QTransform *target)
void setTargetName(const QString &name)

Signals

void easingChanged(const QEasingCurve &easing)
void endModeChanged(Qt3DAnimation::QKeyframeAnimation::RepeatMode endMode)
void framePositionsChanged(const QList<float> &positions)
void startModeChanged(Qt3DAnimation::QKeyframeAnimation::RepeatMode startMode)
void targetChanged(Qt3DCore::QTransform *target)
void targetNameChanged(const QString &name)

Detailed Description

A Qt3DAnimation::QKeyframeAnimation class implements simple keyframe animation that can be used to animate QTransform. The keyframes consists of multiple timed QTransforms, which are interpolated and applied to the target QTransform. QEasingCurve is used between keyframes to control the interpolator. RepeatMode can be set for when the position set to the QKeyframeAnimation is below or above the values defined in the keyframe positions.

Member Type Documentation

enum QKeyframeAnimation::RepeatMode

This enumeration specifies how position values outside keyframe values are handled.

ConstantValueDescription
Qt3DAnimation::QKeyframeAnimation::None0The animation is not applied to the target transform.
Qt3DAnimation::QKeyframeAnimation::Constant1The edge keyframe value is used.
Qt3DAnimation::QKeyframeAnimation::Repeat2The animation is repeated.

Property Documentation

easing : QEasingCurve

Holds the easing curve of the interpolator between keyframes.

Access functions:

QEasingCurve easing() const
void setEasing(const QEasingCurve &easing)

Notifier signal:

void easingChanged(const QEasingCurve &easing)

endMode : RepeatMode

Holds the repeat mode for the position values greater than the last frame position.

Access functions:

Qt3DAnimation::QKeyframeAnimation::RepeatMode endMode() const
void setEndMode(Qt3DAnimation::QKeyframeAnimation::RepeatMode mode)

Notifier signal:

void endModeChanged(Qt3DAnimation::QKeyframeAnimation::RepeatMode endMode)

framePositions : QList<float>

Holds the positions of the keyframes. Each position in the list specifies the position of the corresponding keyframe with the same index. The values must be in an ascending order. Values can be positive or negative and do not have any predefined unit.

Access functions:

QList<float> framePositions() const
void setFramePositions(const QList<float> &positions)

Notifier signal:

void framePositionsChanged(const QList<float> &positions)

startMode : RepeatMode

Holds the repeat mode for the position values less than the first frame position.

Access functions:

Qt3DAnimation::QKeyframeAnimation::RepeatMode startMode() const
void setStartMode(Qt3DAnimation::QKeyframeAnimation::RepeatMode mode)

Notifier signal:

void startModeChanged(Qt3DAnimation::QKeyframeAnimation::RepeatMode startMode)

target : Qt3DCore::QTransform*

Holds the target QTransform the animation is applied to.

Access functions:

Qt3DCore::QTransform *target() const
void setTarget(Qt3DCore::QTransform *target)

Notifier signal:

void targetChanged(Qt3DCore::QTransform *target)

targetName : QString

Holds the name of the target transform. This is a convenience property making it easier to match the target transform to the keyframe animation. The name is usually same as the name of the parent entity of the target transform, but does not have to be.

Access functions:

QString targetName() const
void setTargetName(const QString &name)

Notifier signal:

void targetNameChanged(const QString &name)

Member Function Documentation

[explicit] QKeyframeAnimation::QKeyframeAnimation(QObject *parent = nullptr)

Constructs an QKeyframeAnimation with parent.

void QKeyframeAnimation::addKeyframe(Qt3DCore::QTransform *keyframe)

Adds new keyframe at the end of the animation. The QTransform can be added to the animation multiple times.

QList<Qt3DCore::QTransform *> QKeyframeAnimation::keyframeList() const

Returns the list of keyframes.

void QKeyframeAnimation::removeKeyframe(Qt3DCore::QTransform *keyframe)

Removes a keyframe from the animation. If the same QTransform is set as keyframe multiple times, all occurrences are removed.

void QKeyframeAnimation::setKeyframes(const QList<Qt3DCore::QTransform *> &keyframes)

Sets the keyframes of the animation. Old keyframes are cleared.