QtBase
v6.3.1
tests
manual
rhi
triquadcube
quadrenderer.h
Go to the documentation of this file.
1
/****************************************************************************
2
**
3
** Copyright (C) 2018 The Qt Company Ltd.
4
** Contact: https://www.qt.io/licensing/
5
**
6
** This file is part of the examples of the Qt Toolkit.
7
**
8
** $QT_BEGIN_LICENSE:BSD$
9
** Commercial License Usage
10
** Licensees holding valid commercial Qt licenses may use this file in
11
** accordance with the commercial license agreement provided with the
12
** Software or, alternatively, in accordance with the terms contained in
13
** a written agreement between you and The Qt Company. For licensing terms
14
** and conditions see https://www.qt.io/terms-conditions. For further
15
** information use the contact form at https://www.qt.io/contact-us.
16
**
17
** BSD License Usage
18
** Alternatively, you may use this file under the terms of the BSD license
19
** as follows:
20
**
21
** "Redistribution and use in source and binary forms, with or without
22
** modification, are permitted provided that the following conditions are
23
** met:
24
** * Redistributions of source code must retain the above copyright
25
** notice, this list of conditions and the following disclaimer.
26
** * Redistributions in binary form must reproduce the above copyright
27
** notice, this list of conditions and the following disclaimer in
28
** the documentation and/or other materials provided with the
29
** distribution.
30
** * Neither the name of The Qt Company Ltd nor the names of its
31
** contributors may be used to endorse or promote products derived
32
** from this software without specific prior written permission.
33
**
34
**
35
** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
36
** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
37
** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
38
** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
39
** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
40
** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
41
** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
42
** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
43
** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
44
** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
45
** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
46
**
47
** $QT_END_LICENSE$
48
**
49
****************************************************************************/
50
51
#ifndef QUADRENDERER_H
52
#define QUADRENDERER_H
53
54
#include <QtGui/private/qrhi_p.h>
55
56
class
QuadRenderer
57
{
58
public
:
59
void
setRhi
(
QRhi
*
r
) { m_r =
r
; }
60
void
setSampleCount
(
int
samples
) { m_sampleCount =
samples
; }
61
int
sampleCount
()
const
{
return
m_sampleCount; }
62
void
setTranslation
(
const
QVector3D
&
v
) { m_translation =
v
; }
63
void
initResources
(
QRhiRenderPassDescriptor
*rp);
64
void
releaseResources
();
65
void
setPipeline
(
QRhiGraphicsPipeline
*
ps
);
66
void
resize
(
const
QSize
&pixelSize);
67
void
queueResourceUpdates
(
QRhiResourceUpdateBatch
*resourceUpdates);
68
void
queueDraw
(
QRhiCommandBuffer
*
cb
,
const
QSize
&outputSizeInPixels);
69
70
private
:
71
QRhi
*m_r;
72
73
QRhiBuffer
*m_vbuf =
nullptr
;
74
bool
m_vbufReady =
false
;
75
QRhiBuffer
*m_ibuf =
nullptr
;
76
bool
m_opacityReady =
false
;
77
QRhiBuffer
*m_ubuf =
nullptr
;
78
QRhiGraphicsPipeline
*m_ps =
nullptr
;
79
QRhiShaderResourceBindings
*m_srb =
nullptr
;
80
81
QVector3D
m_translation;
82
QMatrix4x4
m_proj;
83
float
m_rotation = 0;
84
int
m_sampleCount = 1;
// no MSAA by default
85
};
86
87
#endif
QMatrix4x4
The QMatrix4x4 class represents a 4x4 transformation matrix in 3D space.
Definition:
qmatrix4x4.h:61
QRhiBuffer
Definition:
qrhi_p.h:714
QRhiCommandBuffer
Definition:
qrhi_p.h:1397
QRhiGraphicsPipeline
Definition:
qrhi_p.h:1099
QRhi
Definition:
qrhi_p.h:1536
QRhiRenderPassDescriptor
Definition:
qrhi_p.h:986
QRhiResourceUpdateBatch
Definition:
qrhi_p.h:1481
QRhiShaderResourceBindings
Definition:
qrhi_p.h:1048
QSize
The QSize class defines the size of a two-dimensional object using integer point precision.
Definition:
qsize.h:55
QVector3D
The QVector3D class represents a vector or vertex in 3D space.
Definition:
qvectornd.h:205
QuadRenderer
Definition:
quadrenderer.h:57
QuadRenderer::setTranslation
void setTranslation(const QVector3D &v)
Definition:
quadrenderer.h:62
QuadRenderer::queueResourceUpdates
void queueResourceUpdates(QRhiResourceUpdateBatch *resourceUpdates)
Definition:
quadrenderer.cpp:119
QuadRenderer::setRhi
void setRhi(QRhi *r)
Definition:
quadrenderer.h:59
QuadRenderer::setSampleCount
void setSampleCount(int samples)
Definition:
quadrenderer.h:60
QuadRenderer::releaseResources
void releaseResources()
Definition:
quadrenderer.cpp:104
QuadRenderer::initResources
void initResources(QRhiRenderPassDescriptor *rp)
Definition:
quadrenderer.cpp:73
QuadRenderer::queueDraw
void queueDraw(QRhiCommandBuffer *cb, const QSize &outputSizeInPixels)
Definition:
quadrenderer.cpp:140
QuadRenderer::resize
void resize(const QSize &pixelSize)
Definition:
quadrenderer.cpp:97
QuadRenderer::sampleCount
int sampleCount() const
Definition:
quadrenderer.h:61
QuadRenderer::setPipeline
void setPipeline(QRhiGraphicsPipeline *ps)
Definition:
quadrenderer.cpp:92
ps
QRhiGraphicsPipeline * ps
Definition:
compressedtexture_bc1.cpp:62
v
GLsizei const GLfloat * v
[13]
Definition:
qopengles2ext.h:788
samples
GLsizei samples
Definition:
qopengles2ext.h:738
r
GLboolean r
[2]
Definition:
qopengles2ext.h:337
cb
SSL_CTX int(* cb)(SSL *ssl, unsigned char **out, unsigned char *outlen, const unsigned char *in, unsigned int inlen, void *arg)
Definition:
qsslsocket_openssl_symbols.cpp:434
Generated by
1.9.1