blob: bcbbe7e59e47d25f2dda80f4035c1604d5564935 (
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
|
// Copyright (C) 2016 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
#include "qmemoryvideobuffer_p.h"
QT_BEGIN_NAMESPACE
/*!
\class QMemoryVideoBuffer
\brief The QMemoryVideoBuffer class provides a system memory allocated video data buffer.
\internal
QMemoryVideoBuffer is the default video buffer for allocating system memory. It may be used to
allocate memory for a QVideoFrame without implementing your own QAbstractVideoBuffer.
*/
/*!
Constructs a video buffer with an image stride of \a bytesPerLine from a byte \a array.
*/
QMemoryVideoBuffer::QMemoryVideoBuffer(QByteArray data, int bytesPerLine)
: QAbstractVideoBuffer(QVideoFrame::NoHandle),
m_bytesPerLine(bytesPerLine),
m_data(std::move(data))
{
}
/*!
Destroys a system memory allocated video buffer.
*/
QMemoryVideoBuffer::~QMemoryVideoBuffer() = default;
/*!
\reimp
*/
QVideoFrame::MapMode QMemoryVideoBuffer::mapMode() const
{
return m_mapMode;
}
/*!
\reimp
*/
QAbstractVideoBuffer::MapData QMemoryVideoBuffer::map(QVideoFrame::MapMode mode)
{
MapData mapData;
if (m_mapMode == QVideoFrame::NotMapped && m_data.size() && mode != QVideoFrame::NotMapped) {
m_mapMode = mode;
mapData.nPlanes = 1;
mapData.bytesPerLine[0] = m_bytesPerLine;
// avoid detaching and extra copying in case the underlyingByteArray is
// being held by textures or anything else.
if (mode == QVideoFrame::ReadOnly)
mapData.data[0] = reinterpret_cast<uchar *>(const_cast<char*>(m_data.constData()));
else
mapData.data[0] = reinterpret_cast<uchar *>(m_data.data());
mapData.size[0] = m_data.size();
}
return mapData;
}
/*!
\reimp
*/
void QMemoryVideoBuffer::unmap()
{
m_mapMode = QVideoFrame::NotMapped;
}
/*!
\reimp
*/
QByteArray QMemoryVideoBuffer::underlyingByteArray(int plane) const
{
return plane == 0 ? m_data : QByteArray{};
}
QT_END_NAMESPACE
|