File: mesh.cpp

package info (click to toggle)
qt6-base 6.9.1%2Bdfsg-4
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 316,752 kB
  • sloc: cpp: 2,112,334; ansic: 381,848; xml: 142,587; python: 21,632; java: 8,505; asm: 4,009; javascript: 2,290; sh: 1,657; perl: 1,028; makefile: 131
file content (51 lines) | stat: -rw-r--r-- 1,253 bytes parent folder | download | duplicates (3)
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;
}