28 QSSGMeshBVHBuilder(
const QSSGMesh::Mesh &mesh);
29 QSSGMeshBVHBuilder(
const QByteArray &vertexBuffer,
34 bool hasIndexBuffer =
false,
35 const QByteArray &indexBuffer = QByteArray(),
36 QSSGRenderComponentType indexBufferType = QSSGRenderComponentType::Int32);
38 std::unique_ptr<QSSGMeshBVH> buildTree();
53 QSSGMeshBVHTriangles calculateTriangleBounds(quint32 indexOffset, quint32 indexCount)
const;
55 static QSSGMeshBVHNode::Handle splitNode(QSSGMeshBVH &bvh, QSSGMeshBVHNode::Handle node, quint32 offset, quint32 count, quint32 depth = 0);
56 static QSSGBounds3 getBounds(
const QSSGMeshBVH &bvh, quint32 offset, quint32 count);
57 static Split getOptimalSplit(
const QSSGMeshBVH &bvh,
const QSSGBounds3 &nodeBounds, quint32 offset, quint32 count);
58 static Axis getLongestDimension(
const QSSGBounds3 &nodeBounds);
59 static float getAverageValue(
const QSSGMeshBVH &bvh, quint32 offset, quint32 count, Axis axis);
60 static quint32 partition(QSSGMeshBVH &bvh, quint32 offset, quint32 count,
const Split &split);
62 QSSGMesh::Mesh m_mesh;
63 QSSGRenderComponentType m_indexBufferComponentType;
64 QByteArray m_indexBufferData;
65 QByteArray m_vertexBufferData;
66 quint32 m_vertexStride;
67 bool m_hasPositionData =
false;
68 quint32 m_vertexPosOffset;
69 bool m_hasUVData =
false;
70 quint32 m_vertexUVOffset;
71 bool m_hasIndexBuffer =
true;
static void calculateTriangleBoundsImpl(quint32 indexOffset, quint32 indexCount, const QByteArray &indexBufferData, const QByteArray &vertexBufferData, const quint32 vertexStride, const quint32 vertexUVOffset, const quint32 vertexPosOffset, QSSGMeshBVHTriangles &triangleBounds)