summaryrefslogtreecommitdiffstats
path: root/src/render/jobs/renderqueue_p.h
blob: 084865986c889ad0a6dfd75a103e62b7546438dc (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
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
// Copyright (C) 2014 Klaralvdalens Datakonsult AB (KDAB).
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only

#ifndef QT3DRENDER_RENDER_RENDERQUEUE_H
#define QT3DRENDER_RENDER_RENDERQUEUE_H

//
//  W A R N I N G
//  -------------
//
// This file is not part of the Qt API.  It exists for the convenience
// of other Qt classes.  This header file may change from version to
// version without notice, or even be removed.
//
// We mean it.
//

#include <vector>
#include <QMutex>
#include <Qt3DCore/private/vector_helper_p.h>

QT_BEGIN_NAMESPACE

namespace Qt3DRender {

namespace Render {

template<class RenderView>
class RenderQueue
{
public:
    RenderQueue()
        : m_noRender(false)
        , m_wasReset(true)
        , m_targetRenderViewCount(0)
        , m_currentRenderViewCount(0)
        , m_currentWorkQueue(1)
    {}

    /*
     Sets the number \a targetRenderViewCount of RenderView objects that make
     up a frame.
     */
    void setTargetRenderViewCount(int targetRenderViewCount)
    {
        Q_ASSERT(!m_noRender);
        m_targetRenderViewCount = targetRenderViewCount;
        m_currentWorkQueue.resize(targetRenderViewCount);
        m_wasReset = false;
    }

    inline int targetRenderViewCount() const { return m_targetRenderViewCount; }
    inline int currentRenderViewCount() const { return m_currentRenderViewCount; }

    /*
     Returns true if all the RenderView objects making up the current frame
     have been queued. Returns false otherwise.
     \note a frameQueue or size 0 is considered incomplete.
     */
    inline bool isFrameQueueComplete() const
    {
        return (m_noRender
                || (m_targetRenderViewCount > 0 && m_targetRenderViewCount == m_currentRenderViewCount));
    }

    /*
     Queue up a RenderView for the frame being built.
     Thread safe as this is called from the renderer which is locked.
     Returns true if the renderView is complete
     */
    bool queueRenderView(RenderView *renderView, uint submissionOrderIndex)
    {
        Q_ASSERT(!m_noRender);
        m_currentWorkQueue[submissionOrderIndex] = renderView;
        ++m_currentRenderViewCount;
        Q_ASSERT(m_currentRenderViewCount <= m_targetRenderViewCount);
        return isFrameQueueComplete();
    }

    /*
     Called by the Rendering Thread to retrieve the a frame queue to render.
     A call to reset is required after rendering of the frame. Otherwise under some
     conditions the current but then invalidated frame queue could be reused.
     */
    inline const std::vector<RenderView *> &nextFrameQueue() const { return m_currentWorkQueue; }

    /*
     In case the framegraph changed or when the current number of render queue
     needs to be reset.
     */
    void reset()
    {
        m_currentRenderViewCount = 0;
        m_targetRenderViewCount = 0;
        Qt3DCore::deleteAll(m_currentWorkQueue);
        m_currentWorkQueue.clear();
        m_noRender = false;
        m_wasReset = true;
    }

    void setNoRender()
    {
        Q_ASSERT(m_targetRenderViewCount == 0);
        m_noRender = true;
    }
    inline bool isNoRender() const { return m_noRender; }

    inline bool wasReset() const { return m_wasReset; }

    inline QMutex *mutex() { return &m_mutex; }

private:
    bool m_noRender;
    bool m_wasReset;
    int m_targetRenderViewCount;
    int m_currentRenderViewCount;
    std::vector<RenderView *> m_currentWorkQueue;
    QMutex m_mutex;
};

} // namespace Render

} // namespace Qt3DRender

QT_END_NAMESPACE

#endif // QT3DRENDER_RENDER_RENDERQUEUE_H