QtBase  v6.3.1
animation.h
Go to the documentation of this file.
1 /****************************************************************************
2 **
3 ** Copyright (C) 2016 The Qt Company Ltd.
4 ** Contact: https://www.qt.io/licensing/
5 **
6 ** This file is part of the QtCore module of the Qt Toolkit.
7 **
8 ** $QT_BEGIN_LICENSE:BSD$
9 ** Commercial License Usage
10 ** Licensees holding valid commercial Qt licenses may use this file in
11 ** accordance with the commercial license agreement provided with the
12 ** Software or, alternatively, in accordance with the terms contained in
13 ** a written agreement between you and The Qt Company. For licensing terms
14 ** and conditions see https://www.qt.io/terms-conditions. For further
15 ** information use the contact form at https://www.qt.io/contact-us.
16 **
17 ** BSD License Usage
18 ** Alternatively, you may use this file under the terms of the BSD license
19 ** as follows:
20 **
21 ** "Redistribution and use in source and binary forms, with or without
22 ** modification, are permitted provided that the following conditions are
23 ** met:
24 ** * Redistributions of source code must retain the above copyright
25 ** notice, this list of conditions and the following disclaimer.
26 ** * Redistributions in binary form must reproduce the above copyright
27 ** notice, this list of conditions and the following disclaimer in
28 ** the documentation and/or other materials provided with the
29 ** distribution.
30 ** * Neither the name of The Qt Company Ltd nor the names of its
31 ** contributors may be used to endorse or promote products derived
32 ** from this software without specific prior written permission.
33 **
34 **
35 ** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
36 ** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
37 ** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
38 ** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
39 ** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
40 ** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
41 ** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
42 ** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
43 ** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
44 ** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
45 ** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
46 **
47 ** $QT_END_LICENSE$
48 **
49 ****************************************************************************/
50 
51 #ifndef ANIMATION_H
52 #define ANIMATION_H
53 
54 #include <QtWidgets>
55 
56 #include <QtCore/qpropertyanimation.h>
57 
58 class Animation : public QPropertyAnimation {
59 public:
60  enum PathType {
64  };
66  : QPropertyAnimation(target, prop)
67  {
69  }
70 
71  void setPathType(PathType pathType)
72  {
73  if (pathType >= NPathTypes)
74  qWarning("Unknown pathType %d", pathType);
75 
76  m_pathType = pathType;
77  m_path = QPainterPath();
78  }
79 
80  void updateCurrentTime(int currentTime) override
81  {
82  if (m_pathType == CirclePath) {
83  if (m_path.isEmpty()) {
84  QPointF to = endValue().toPointF();
85  QPointF from = startValue().toPointF();
86  m_path.moveTo(from);
87  m_path.addEllipse(QRectF(from, to));
88  }
89  int dura = duration();
90  const qreal progress = ((dura == 0) ? 1 : ((((currentTime - 1) % dura) + 1) / qreal(dura)));
91 
92  qreal easedProgress = easingCurve().valueForProgress(progress);
93  if (easedProgress > 1.0) {
94  easedProgress -= 1.0;
95  } else if (easedProgress < 0) {
96  easedProgress += 1.0;
97  }
98  QPointF pt = m_path.pointAtPercent(easedProgress);
100  emit valueChanged(pt);
101  } else {
103  }
104  }
105 
108 };
109 
110 #endif // ANIMATION_H
@ LinearPath
Definition: animation.h:61
@ CirclePath
Definition: animation.h:62
@ NPathTypes
Definition: animation.h:63
void setPathType(PathType pathType)
Definition: animation.h:71
PathType m_pathType
Definition: animation.h:107
Animation(QObject *target, const QByteArray &prop)
Definition: animation.h:65
void updateCurrentTime(int currentTime) override
Definition: animation.h:80
QPainterPath m_path
Definition: animation.h:106
int currentTime
the current time and progress of the animation
The QByteArray class provides an array of bytes.
Definition: qbytearray.h:85
qreal valueForProgress(qreal progress) const
The QObject class is the base class of all Qt objects.
Definition: qobject.h:125
The QPainterPath class provides a container for painting operations, enabling graphical shapes to be ...
Definition: qpainterpath.h:65
void moveTo(const QPointF &p)
void addEllipse(const QRectF &rect)
bool isEmpty() const
QPointF pointAtPercent(qreal t) const
The QPointF class defines a point in the plane using floating point precision.
Definition: qpoint.h:242
The QPropertyAnimation class animates Qt properties.
void updateCurrentValue(const QVariant &value) override
The QRectF class defines a finite rectangle in the plane using floating point precision.
Definition: qrect.h:511
int duration
the duration of the animation
QEasingCurve easingCurve
the easing curve of the animation
void valueChanged(const QVariant &value)
QVariant startValue
the optional start value of the animation
void updateCurrentTime(int) override
QVariant endValue
the end value of the animation
QPointF toPointF() const
Definition: qvariant.cpp:1627
QT_END_INCLUDE_NAMESPACE typedef double qreal
Definition: qglobal.h:341
#define qWarning
Definition: qlogging.h:179
GLenum target
#define emit
Definition: qtmetamacros.h:85