blob: 79c4649c7e0e2cc1185da921e83e2f8d3819c5dc (
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
|
// Copyright (C) 2023 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only
#include "scatterinstancing_p.h"
ScatterInstancing::ScatterInstancing() {}
QByteArray ScatterInstancing::getInstanceBuffer(int *instanceCount)
{
if (m_dirty) {
m_instanceData.resize(0);
int instanceNumber = 0;
for (int i = 0; i < m_dataArray.size(); ++i) {
auto item = m_dataArray.at(i);
float x = item.position.x();
float y = item.position.y();
float z = item.position.z();
QVector4D customData{};
if (m_rangeGradient)
customData.setX(m_customData.at(i));
if (item.hide) {
// Setting the scale to zero breaks instanced picking.
item.scale = {0.001f, 0.001f, 0.001f};
}
auto entry = calculateTableEntryFromQuaternion({x, y, z},
item.scale,
item.rotation,
QColor(Qt::white),
customData);
m_instanceData.append(reinterpret_cast<char *>(&entry), sizeof(entry));
instanceNumber++;
}
m_instanceCount = instanceNumber;
m_dirty = false;
}
if (instanceCount)
*instanceCount = m_instanceCount;
return m_instanceData;
}
bool ScatterInstancing::rangeGradient() const
{
return m_rangeGradient;
}
void ScatterInstancing::setRangeGradient(bool newRangeGradient)
{
m_rangeGradient = newRangeGradient;
}
void ScatterInstancing::setTransparency(bool transparency)
{
setDepthSortingEnabled(transparency);
}
const QList<float> &ScatterInstancing::customData() const
{
return m_customData;
}
void ScatterInstancing::setCustomData(const QList<float> &newCustomData)
{
m_customData = newCustomData;
markDataDirty();
}
void ScatterInstancing::markDataDirty()
{
m_dirty = true;
markDirty();
}
const QList<DataItemHolder> &ScatterInstancing::dataArray() const
{
return m_dataArray;
}
void ScatterInstancing::setDataArray(const QList<DataItemHolder> &newDataArray)
{
m_dataArray = newDataArray;
markDataDirty();
}
void ScatterInstancing::hideDataItem(qsizetype index)
{
unhidePreviousDataItem();
Q_ASSERT(index < m_dataArray.size());
m_dataArray[index].hide = true;
m_previousHideIndex = index;
}
void ScatterInstancing::unhidePreviousDataItem()
{
if (m_previousHideIndex >= 0) {
m_dataArray[m_previousHideIndex].hide = false;
markDataDirty();
}
}
void ScatterInstancing::resetVisibilty()
{
for (auto &dih : m_dataArray)
dih.hide = false;
markDataDirty();
}
|