summaryrefslogtreecommitdiffstats
path: root/tests/manual/rhi/rhiwidget/examplewidget.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'tests/manual/rhi/rhiwidget/examplewidget.cpp')
-rw-r--r--tests/manual/rhi/rhiwidget/examplewidget.cpp182
1 files changed, 0 insertions, 182 deletions
diff --git a/tests/manual/rhi/rhiwidget/examplewidget.cpp b/tests/manual/rhi/rhiwidget/examplewidget.cpp
deleted file mode 100644
index 942766ac5c..0000000000
--- a/tests/manual/rhi/rhiwidget/examplewidget.cpp
+++ /dev/null
@@ -1,182 +0,0 @@
-// Copyright (C) 2021 The Qt Company Ltd.
-// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause
-
-#include "examplewidget.h"
-#include "../shared/cube.h"
-#include <QFile>
-#include <QPainter>
-
-static const QSize CUBE_TEX_SIZE(512, 512);
-
-ExampleRhiWidget::ExampleRhiWidget(QWidget *parent, Qt::WindowFlags f)
- : QRhiWidget(parent, f)
-{
- setDebugLayer(true);
-}
-
-void ExampleRhiWidget::initialize(QRhi *rhi, QRhiTexture *outputTexture)
-{
- if (m_rhi != rhi) {
- m_rt.reset();
- m_rp.reset();
- m_ds.reset();
- scene.vbuf.reset();
- } else if (m_output != outputTexture) {
- m_rt.reset();
- m_rp.reset();
- }
-
- m_rhi = rhi;
- m_output = outputTexture;
-
- if (!m_ds) {
- m_ds.reset(m_rhi->newRenderBuffer(QRhiRenderBuffer::DepthStencil, m_output->pixelSize()));
- m_ds->create();
- } else if (m_ds->pixelSize() != m_output->pixelSize()) {
- m_ds->setPixelSize(m_output->pixelSize());
- m_ds->create();
- }
-
- if (!m_rt) {
- m_rt.reset(m_rhi->newTextureRenderTarget({ { m_output }, m_ds.data() }));
- m_rp.reset(m_rt->newCompatibleRenderPassDescriptor());
- m_rt->setRenderPassDescriptor(m_rp.data());
- m_rt->create();
- }
-
- if (!scene.vbuf) {
- initScene();
- updateCubeTexture();
- }
-
- const QSize outputSize = m_output->pixelSize();
- scene.mvp = m_rhi->clipSpaceCorrMatrix();
- scene.mvp.perspective(45.0f, outputSize.width() / (float) outputSize.height(), 0.01f, 1000.0f);
- scene.mvp.translate(0, 0, -4);
- updateMvp();
-}
-
-void ExampleRhiWidget::updateMvp()
-{
- QMatrix4x4 mvp = scene.mvp * QMatrix4x4(QQuaternion::fromEulerAngles(QVector3D(30, itemData.cubeRotation, 0)).toRotationMatrix());
- if (!scene.resourceUpdates)
- scene.resourceUpdates = m_rhi->nextResourceUpdateBatch();
- scene.resourceUpdates->updateDynamicBuffer(scene.ubuf.data(), 0, 64, mvp.constData());
-}
-
-void ExampleRhiWidget::updateCubeTexture()
-{
- QImage image(CUBE_TEX_SIZE, QImage::Format_RGBA8888);
- const QRect r(QPoint(0, 0), CUBE_TEX_SIZE);
- QPainter p(&image);
- p.fillRect(r, QGradient::DeepBlue);
- QFont font;
- font.setPointSize(24);
- p.setFont(font);
- p.drawText(r, itemData.cubeText);
- p.end();
-
- if (!scene.resourceUpdates)
- scene.resourceUpdates = m_rhi->nextResourceUpdateBatch();
- scene.resourceUpdates->uploadTexture(scene.cubeTex.data(), image);
-}
-
-static QShader getShader(const QString &name)
-{
- QFile f(name);
- if (f.open(QIODevice::ReadOnly))
- return QShader::fromSerialized(f.readAll());
-
- return QShader();
-}
-
-void ExampleRhiWidget::initScene()
-{
- scene.vbuf.reset(m_rhi->newBuffer(QRhiBuffer::Immutable, QRhiBuffer::VertexBuffer, sizeof(cube)));
- scene.vbuf->create();
-
- scene.resourceUpdates = m_rhi->nextResourceUpdateBatch();
- scene.resourceUpdates->uploadStaticBuffer(scene.vbuf.data(), cube);
-
- scene.ubuf.reset(m_rhi->newBuffer(QRhiBuffer::Dynamic, QRhiBuffer::UniformBuffer, 68));
- scene.ubuf->create();
-
- const qint32 flip = 0;
- scene.resourceUpdates->updateDynamicBuffer(scene.ubuf.data(), 64, 4, &flip);
-
- scene.cubeTex.reset(m_rhi->newTexture(QRhiTexture::RGBA8, CUBE_TEX_SIZE));
- scene.cubeTex->create();
-
- scene.sampler.reset(m_rhi->newSampler(QRhiSampler::Linear, QRhiSampler::Linear, QRhiSampler::None,
- QRhiSampler::ClampToEdge, QRhiSampler::ClampToEdge));
- scene.sampler->create();
-
- scene.srb.reset(m_rhi->newShaderResourceBindings());
- scene.srb->setBindings({
- QRhiShaderResourceBinding::uniformBuffer(0, QRhiShaderResourceBinding::VertexStage | QRhiShaderResourceBinding::FragmentStage, scene.ubuf.data()),
- QRhiShaderResourceBinding::sampledTexture(1, QRhiShaderResourceBinding::FragmentStage, scene.cubeTex.data(), scene.sampler.data())
- });
- scene.srb->create();
-
- scene.ps.reset(m_rhi->newGraphicsPipeline());
- scene.ps->setDepthTest(true);
- scene.ps->setDepthWrite(true);
- scene.ps->setDepthOp(QRhiGraphicsPipeline::Less);
- scene.ps->setCullMode(QRhiGraphicsPipeline::Back);
- scene.ps->setFrontFace(QRhiGraphicsPipeline::CCW);
- QShader vs = getShader(QLatin1String(":/texture.vert.qsb"));
- Q_ASSERT(vs.isValid());
- QShader fs = getShader(QLatin1String(":/texture.frag.qsb"));
- Q_ASSERT(fs.isValid());
- scene.ps->setShaderStages({
- { QRhiShaderStage::Vertex, vs },
- { QRhiShaderStage::Fragment, fs }
- });
- QRhiVertexInputLayout inputLayout;
- inputLayout.setBindings({
- { 3 * sizeof(float) },
- { 2 * sizeof(float) }
- });
- inputLayout.setAttributes({
- { 0, 0, QRhiVertexInputAttribute::Float3, 0 },
- { 1, 1, QRhiVertexInputAttribute::Float2, 0 }
- });
- scene.ps->setVertexInputLayout(inputLayout);
- scene.ps->setShaderResourceBindings(scene.srb.data());
- scene.ps->setRenderPassDescriptor(m_rp.data());
- scene.ps->create();
-}
-
-void ExampleRhiWidget::render(QRhiCommandBuffer *cb)
-{
- if (itemData.cubeRotationDirty) {
- itemData.cubeRotationDirty = false;
- updateMvp();
- }
-
- if (itemData.cubeTextDirty) {
- itemData.cubeTextDirty = false;
- updateCubeTexture();
- }
-
- QRhiResourceUpdateBatch *rub = scene.resourceUpdates;
- if (rub)
- scene.resourceUpdates = nullptr;
-
- const QColor clearColor = QColor::fromRgbF(0.4f, 0.7f, 0.0f, 1.0f);
-
- cb->beginPass(m_rt.data(), clearColor, { 1.0f, 0 }, rub);
-
- cb->setGraphicsPipeline(scene.ps.data());
- const QSize outputSize = m_output->pixelSize();
- cb->setViewport(QRhiViewport(0, 0, outputSize.width(), outputSize.height()));
- cb->setShaderResources();
- const QRhiCommandBuffer::VertexInput vbufBindings[] = {
- { scene.vbuf.data(), 0 },
- { scene.vbuf.data(), quint32(36 * 3 * sizeof(float)) }
- };
- cb->setVertexInput(0, 2, vbufBindings);
- cb->draw(36);
-
- cb->endPass();
-}