aboutsummaryrefslogtreecommitdiffstats
path: root/tests/auto/quick/scenegraph/data/render_MovingOverlap.qml
blob: 7b1cef32f2b749502a8d1dc1819a8f02f05b5d14 (plain)
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
// Copyright (C) 2016 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0

import QtQuick 2.2

/*
    This test verifies that items that go from being batched because
    of no overlap will be split into multiple batches because of an
    overlap and that no rendering errors occur as a result of this.

    #samples: 8
                 PixelPos     R    G    B    Error-tolerance
    #base:         0   0     0.0  0.0  0.0       0.0
    #base:        10  10     0.5  0.0  0.0       0.05
    #base:       100 100     0.0  0.0  0.0       0.0
    #base:       110 110     0.5  0.0  0.0       0.05
    #final:       40  40     0.0  0.0  0.0       0.0
    #final:       50  50     0.5  0.0  0.0       0.05
    #final:       60  60     0.0  0.0  0.0       0.0
    #final:       70  70     0.5  0.0  0.0       0.05
*/

RenderTestBase {
    id: root

    Rectangle {
        id: one
        x: 0
        y: x
        width: 80
        height: 80
        color: "black"

        Rectangle {
            anchors.fill: parent
            anchors.margins: 10
            color: "red"
            opacity: 0.5
        }
    }

    Rectangle {
        id: two
        x: 100
        y: x
        width: 80
        height: 80
        color: "black"

        Rectangle {
            anchors.fill: parent
            anchors.margins: 10
            color: "red"
            opacity: 0.5
        }
    }

    SequentialAnimation {
        id: animation
        ParallelAnimation {
            NumberAnimation { target: one; property: "x"; from: 0; to: 40; duration: 100 }
            NumberAnimation { target: two; property: "x"; from: 100; to: 60; duration: 100 }
        }
        PropertyAction { target: root; property: "finalStageComplete"; value: true; }
    }

    onEnterFinalStage: {
        animation.running = true;
    }

}