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
|