summaryrefslogtreecommitdiffstats
path: root/examples/vulkan/hellovulkancubes/mesh.cpp
blob: ff7672d405a6f2bcc1bb48694cf5b52040d7c08d (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
// Copyright (C) 2017 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause

#include "mesh.h"
#include <QtConcurrentRun>
#include <QFile>

void Mesh::load(const QString &fn)
{
    reset();
    m_maybeRunning = true;
    m_future = QtConcurrent::run([fn]() {
        MeshData md;
        QFile f(fn);
        if (!f.open(QIODevice::ReadOnly)) {
            qWarning("Failed to open %s", qPrintable(fn));
            return md;
        }
        QByteArray buf = f.readAll();
        const char *p = buf.constData();
        quint32 format;
        memcpy(&format, p, 4);
        if (format != 1) {
            qWarning("Invalid format in %s", qPrintable(fn));
            return md;
        }
        int ofs = 4;
        memcpy(&md.vertexCount, p + ofs, 4);
        ofs += 4;
        memcpy(md.aabb, p + ofs, 6 * 4);
        ofs += 6 * 4;
        const int byteCount = md.vertexCount * 8 * 4;
        md.geom.resize(byteCount);
        memcpy(md.geom.data(), p + ofs, byteCount);
        return md;
    });
}

MeshData *Mesh::data()
{
    if (m_maybeRunning && !m_data.isValid())
        m_data = m_future.result();

    return &m_data;
}

void Mesh::reset()
{
    *data() = MeshData();
    m_maybeRunning = false;
}