aboutsummaryrefslogtreecommitdiffstats
path: root/tests/auto/quick/qquickgridview/data/negativeDisplayMargin.qml
blob: 3d5c8494a6d8853adc3c094bf066435ee3c52d60 (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
72
73
74
75
76
77
78
// Copyright (C) 2016 Canonical Limited and/or its subsidiary(-ies).
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only

import QtQuick 2.3

ListView {
    id: list
    width: 400
    height: 600
    model: ListModel {
        ListElement { kind: "Bought" }
        ListElement { kind: "Available To Buy" }
    }

    delegate: GridView {
        id: grid
        objectName: "grid"
        height: Math.ceil(count / (width / cellWidth)) * cellHeight / 1
        width: list.width
        interactive: false
        property int count: 50
        cellHeight: 200
        cellWidth: cellHeight
        model: count
        property int createdItems: 0
        property int destroyedItems: 0

        delegate: Item {
            objectName: "delegate"
            width: cellWidth
            height: cellHeight
            Rectangle {
                width: parent.width - 20
                height: parent.height - 20
                anchors.centerIn: parent
                color: Math.random() * 2 > 1 ? "green" : "yellow";
                Text {
                    text: index
                }
                Component.onCompleted: createdItems++
                Component.onDestruction: destroyedItems++
            }
        }

        displayMarginBeginning: 0
        displayMarginEnd: -height

        function updatedDelegateCreationRange() {
            if (list.contentY + list.height <= grid.y) {
                // Not visible
                grid.displayMarginBeginning = 0
                grid.displayMarginEnd = -grid.height
            } else if (grid.y + grid.height <= list.contentY) {
                // Not visible
                grid.displayMarginBeginning = -grid.height
                grid.displayMarginEnd = 0
            } else {
                grid.displayMarginBeginning = -Math.max(list.contentY - grid.y, 0)
                grid.displayMarginEnd = -Math.max(grid.height - list.height - list.contentY + grid.y, 0)
            }
        }

        Component.onCompleted: updatedDelegateCreationRange();
        onHeightChanged: updatedDelegateCreationRange();
        Connections {
            target: list
            onContentYChanged: updatedDelegateCreationRange();
            onHeightChanged: updatedDelegateCreationRange();
        }
    }

    section.property: "kind"
    section.delegate: Text {
        height: 40
        font.pixelSize: 30
        text: section
    }
}