File: tst_fcurve.cpp

package info (click to toggle)
qt3d-opensource-src 5.15.15%2Bdfsg-3
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 119,316 kB
  • sloc: cpp: 220,927; ansic: 904; python: 467; objc: 244; javascript: 158; pascal: 155; xml: 28; makefile: 25
file content (123 lines) | stat: -rw-r--r-- 4,009 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
/****************************************************************************
**
** Copyright (C) 2015 Klaralvdalens Datakonsult AB (KDAB).
** Contact: https://www.qt.io/licensing/
**
** This file is part of the Qt3D module of the Qt Toolkit.
**
** $QT_BEGIN_LICENSE:GPL-EXCEPT$
** Commercial License Usage
** Licensees holding valid commercial Qt licenses may use this file in
** accordance with the commercial license agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and The Qt Company. For licensing terms
** and conditions see https://www.qt.io/terms-conditions. For further
** information use the contact form at https://www.qt.io/contact-us.
**
** GNU General Public License Usage
** Alternatively, this file may be used under the terms of the GNU
** General Public License version 3 as published by the Free Software
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
** included in the packaging of this file. Please review the following
** information to ensure the GNU General Public License requirements will
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
**
** $QT_END_LICENSE$
**
****************************************************************************/

#include <QtTest/QTest>
#include <private/fcurve_p.h>

using namespace Qt3DAnimation;
using namespace Qt3DAnimation::Animation;

class tst_FCurve : public QObject
{
    Q_OBJECT

private Q_SLOTS:
    void checkDefaultConstruction()
    {
        // WHEN
        FCurve fcurve;

        // THEN
        QCOMPARE(fcurve.keyframeCount(), 0);
        QCOMPARE(fcurve.startTime(), 0.0f);
        QCOMPARE(fcurve.endTime(), 0.0f);
    }

    void checkAddingKeyframes()
    {
        // GIVEN
        FCurve fcurve;

        // WHEN
        const Keyframe kf0{0.0f, {-5.0f, 0.0f}, {5.0f, 0.0f}, QKeyFrame::BezierInterpolation};
        fcurve.appendKeyframe(0.0f, kf0);

        // THEN
        QCOMPARE(fcurve.keyframeCount(), 1);
        QCOMPARE(fcurve.startTime(), 0.0f);
        QCOMPARE(fcurve.endTime(), 0.0f);

        // WHEN
        const Keyframe kf1{5.0f, {45.0f, 5.0f}, {55.0f, 5.0f}, QKeyFrame::BezierInterpolation};
        fcurve.appendKeyframe(50.0f, kf1);

        // THEN
        QCOMPARE(fcurve.keyframeCount(), 2);
        QCOMPARE(fcurve.startTime(), 0.0f);
        QCOMPARE(fcurve.endTime(), 50.0f);
        QCOMPARE(fcurve.keyframe(0), kf0);
        QCOMPARE(fcurve.keyframe(1), kf1);
    }

    void checkClearKeyframes()
    {
        // GIVEN
        FCurve fcurve;
        fcurve.appendKeyframe(0.0f, Keyframe{0.0f, {-5.0f, 0.0f}, {5.0f, 0.0f}, QKeyFrame::BezierInterpolation});
        fcurve.appendKeyframe(50.0f, Keyframe{5.0f, {45.0f, 5.0f}, {55.0f, 5.0f}, QKeyFrame::BezierInterpolation});

        // WHEN
        fcurve.clearKeyframes();

        // THEN
        QCOMPARE(fcurve.keyframeCount(), 0);
        QCOMPARE(fcurve.startTime(), 0.0f);
        QCOMPARE(fcurve.endTime(), 0.0f);
    }

    void checkEvaluateAtTime_data()
    {

        QTest::addColumn<float>("time");
        QTest::addColumn<float>("expectedValue");

        QTest::addRow("Constant_before_time") << 0.0f << 1.0f;
        QTest::addRow("Constant_1.5") << 1.5f << 1.0f;
        QTest::addRow("Constant_2.5") << 2.5f << 2.0f;
        QTest::addRow("Constant_after_time") << 3.5f << 4.0f;
    }

    void checkEvaluateAtTime()
    {
        QFETCH(float, time);
        QFETCH(float, expectedValue);

        FCurve curve;
        curve.appendKeyframe(1.0, Keyframe{1.0, {0.0, 0.0}, {0.0,0.0}, QKeyFrame::ConstantInterpolation});
        curve.appendKeyframe(2.0, Keyframe{2.0, {0.0, 0.0}, {0.0,0.0}, QKeyFrame::ConstantInterpolation});
        curve.appendKeyframe(3.0, Keyframe{4.0, {0.0, 0.0}, {0.0,0.0}, QKeyFrame::ConstantInterpolation});

        float actualValue = curve.evaluateAtTime(time);

        QCOMPARE(expectedValue, actualValue);
    }
};

QTEST_APPLESS_MAIN(tst_FCurve)

#include "tst_fcurve.moc"