summaryrefslogtreecommitdiffstats
path: root/tests/benchmarks/mapitems_framecount/main.cpp
blob: 2aae5e86e1c62fb37f8d39c2db90bed5b59cc18e (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
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
// Copyright (C) 2023 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only

#include <QApplication>
#include <QQuickWidget>
#include <QTime>
#include <QList>

class TimerWidget : public QQuickWidget
{
    Q_OBJECT
public:
    TimerWidget(const QList<QString> &scripts, QWidget *parent = nullptr)
        : QQuickWidget(parent)
    {
        qmlFiles = scripts;
        QObject::connect(this->quickWindow(), &QQuickWindow::beforeFrameBegin, this, &TimerWidget::startTimer);
        QObject::connect(this->quickWindow(), &QQuickWindow::afterFrameEnd, this, &TimerWidget::endTimer);
        QObject::connect(this, &TimerWidget::finishedSampleSize, this, &TimerWidget::loadNext);
    }

public slots:
    void startTimer()
    {
        renderStartAt = QTime::currentTime().msecsSinceStartOfDay();
    }

    void endTimer()
    {
        if (renderStartAt < 0) return;

        const int now = QTime::currentTime().msecsSinceStartOfDay();
        const int renderTime = now-renderStartAt;

        numberOfRenders++;
        sumOfRenderTime += renderTime;

        qInfo() << "    Rendering took" << renderTime << "msec. Average:" << sumOfRenderTime/numberOfRenders << "msec (sample size:" << numberOfRenders << ")";

        renderStartAt = -1;

        if (numberOfRenders >= runSampleSize)
        {
            executionDuration.insert(currentScript, sumOfRenderTime);
            emit finishedSampleSize();
        }
    }

    void loadNext()
    {
        if (qmlFiles.isEmpty())
        {
            writeResult();
            return;
        }
        currentScript = qmlFiles.takeFirst();
        numberOfRenders = 0;
        sumOfRenderTime = 0;
        QUrl url(currentScript);
        setSource(url);
    }

    void runScripts()
    {
        loadNext();
    }

    void writeResult()
    {
        for (const auto &i : executionDuration.keys())
        {
            qInfo() << "Render duration for" << runSampleSize << "Frames of script" << i << ":" << executionDuration[i] << "msec.";
        }
        this->deleteLater();
        QApplication::exit(0);
    }

signals:
    void finishedSampleSize();

private:
    int runSampleSize = 100;
    int renderStartAt = -1;
    int sumOfRenderTime = 0;
    int numberOfRenders = 0;

    QString currentScript;
    QList<QString> qmlFiles;
    QMap<QString, int> executionDuration;
};

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);

    TimerWidget *w = new TimerWidget({
                                         "qrc:/circles.qml",
                                         "qrc:/rectangles.qml",
                                         "qrc:/polylines.qml",
                                         "qrc:/polygons.qml"
                                     });
    w->show();
    w->runScripts();
    return a.exec();
}

#include "main.moc"