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
110
|
// Copyright (C) 2015 Klaralvdalens Datakonsult AB (KDAB).
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
#include <QtQml/QJSValue>
#include <QtQml/QQmlEngine>
#include <Qt3DQuick/private/quick3dbuffer_p.h>
#include <QtQml/private/qqmlengine_p.h>
#include <QtQml/private/qjsvalue_p.h>
#include <QtQml/private/qv4typedarray_p.h>
#include <QtQml/private/qv4arraybuffer_p.h>
#include <Qt3DCore/private/qurlhelper_p.h>
#include <QtCore/qfile.h>
QT_BEGIN_NAMESPACE
namespace Qt3DCore {
namespace Quick {
namespace {
const int jsValueTypeId = qMetaTypeId<QJSValue>();
}
Quick3DBuffer::Quick3DBuffer(Qt3DCore::QNode *parent)
: Qt3DCore::QBuffer(parent)
, m_engine(nullptr)
, m_v4engine(nullptr)
{
QObject::connect(this, &Qt3DCore::QBuffer::dataChanged, this, &Quick3DBuffer::bufferDataChanged);
}
QByteArray Quick3DBuffer::convertToRawData(const QJSValue &jsValue)
{
initEngines();
Q_ASSERT(m_v4engine);
QV4::Scope scope(m_v4engine);
QV4::Scoped<QV4::TypedArray> typedArray(scope,
#if QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)
QJSValuePrivate::convertToReturnedValue(m_v4engine, jsValue));
char *dataPtr = reinterpret_cast<char *>(typedArray->arrayData());
#else
QJSValuePrivate::convertedToValue(m_v4engine, jsValue));
char *dataPtr = reinterpret_cast<char *>(typedArray->arrayData()->data());
#endif
if (!typedArray)
return QByteArray();
dataPtr += typedArray->d()->byteOffset;
uint byteLength = typedArray->byteLength();
return QByteArray(dataPtr, byteLength);
}
QVariant Quick3DBuffer::bufferData() const
{
return QVariant::fromValue(data());
}
void Quick3DBuffer::setBufferData(const QVariant &bufferData)
{
if (bufferData.userType() == QMetaType::QByteArray) {
QBuffer::setData(bufferData.toByteArray());
} else if (bufferData.userType() == jsValueTypeId) {
QJSValue jsValue = bufferData.value<QJSValue>();
QBuffer::setData(convertToRawData(jsValue));
}
}
void Quick3DBuffer::updateData(int offset, const QVariant &bufferData)
{
if (bufferData.userType() == QMetaType::QByteArray) {
QBuffer::updateData(offset, bufferData.toByteArray());
} else if (bufferData.userType() == jsValueTypeId) {
QJSValue jsValue = bufferData.value<QJSValue>();
QBuffer::updateData(offset, convertToRawData(jsValue));
}
}
/*!
\qmlmethod string Quick3DBuffer::readBinaryFile(url &fileUrl)
Reads the binary at \a fileUrl and return it as a QByteArray wrapped in a
QVariant
\note this is provided as convenience for QML where reading files and creating
QByteArray is not possible
*/
QVariant Quick3DBuffer::readBinaryFile(const QUrl &fileUrl)
{
QFile f(Qt3DCore::QUrlHelper::urlToLocalFileOrQrc(fileUrl));
QByteArray data;
if (f.open(QIODevice::ReadOnly))
data = f.readAll();
return QVariant(data);
}
void Quick3DBuffer::initEngines()
{
if (m_engine == nullptr) {
m_engine = qmlEngine(parent());
m_v4engine = QQmlEnginePrivate::getV4Engine(m_engine);
}
}
} // Quick
} // Qt3DCore
QT_END_NAMESPACE
#include "moc_quick3dbuffer_p.cpp"
|