![]() |
Qt 6.x
The Qt SDK
|
Public Member Functions | |
QCGImageVideoBuffer (CGImageRef image) | |
~QCGImageVideoBuffer () override | |
QVideoFrame::MapMode | mapMode () const override |
MapData | map (QVideoFrame::MapMode mode) override |
Independently maps the planes of a video buffer to memory. | |
void | unmap () override |
Releases the memory mapped by the map() function. | |
![]() | |
QAbstractVideoBuffer (QVideoFrame::HandleType type, QRhi *rhi=nullptr) | |
Constructs an abstract video buffer of the given type. | |
virtual | ~QAbstractVideoBuffer () |
Destroys an abstract video buffer. | |
QVideoFrame::HandleType | handleType () const |
Returns the type of a video buffer's handle. | |
QRhi * | rhi () const |
Returns the QRhi instance. | |
virtual QVideoFrame::MapMode | mapMode () const =0 |
virtual MapData | map (QVideoFrame::MapMode mode)=0 |
Independently maps the planes of a video buffer to memory. | |
virtual void | unmap ()=0 |
Releases the memory mapped by the map() function. | |
virtual std::unique_ptr< QVideoFrameTextures > | mapTextures (QRhi *) |
virtual quint64 | textureHandle (int) const |
Returns a texture handle to the data buffer. | |
virtual QMatrix4x4 | externalTextureMatrix () const |
Additional Inherited Members | |
![]() | |
QVideoFrame::HandleType | m_type |
QRhi * | m_rhi = nullptr |
Definition at line 39 of file qcgwindowcapture.mm.
|
inline |
Definition at line 42 of file qcgwindowcapture.mm.
|
inlineoverride |
Definition at line 49 of file qcgwindowcapture.mm.
|
inlineoverridevirtual |
Independently maps the planes of a video buffer to memory.
The map mode indicates whether the contents of the mapped memory should be read from and/or written to the buffer. If the map mode includes the QVideoFrame::ReadOnly
flag the mapped memory will be populated with the content of the buffer when initially mapped. If the map mode includes the QVideoFrame::WriteOnly
flag the content of the possibly modified mapped memory will be written back to the buffer when unmapped.
When access to the data is no longer needed be sure to call the unmap() function to release the mapped memory and possibly update the buffer contents.
Returns the number of planes in the mapped video data. For each plane the line stride of that plane will be returned in bytesPerLine, and a pointer to the plane data will be returned in data. The accumulative size of the mapped data is returned in numBytes.
Not all buffer implementations will map more than the first plane, if this returns a single plane for a planar format the additional planes will have to be calculated from the line stride of the first plane and the frame height. Mapping a buffer with QVideoFrame will do this for you.
To implement this function create a derivative of QAbstractPlanarVideoBuffer and implement its map function instance instead.
Implements QAbstractVideoBuffer.
Definition at line 53 of file qcgwindowcapture.mm.
References QAbstractVideoBuffer::MapData::bytesPerLine, QAbstractVideoBuffer::MapData::data, mapData(), QVideoFrame::NotMapped, QAbstractVideoBuffer::MapData::nPlanes, and QAbstractVideoBuffer::MapData::size.
|
inlineoverridevirtual |
Implements QAbstractVideoBuffer.
Definition at line 51 of file qcgwindowcapture.mm.
|
inlineoverridevirtual |
Releases the memory mapped by the map() function.
If the \l {QVideoFrame::MapMode}{MapMode} included the QVideoFrame::WriteOnly
flag this will write the current content of the mapped memory back to the video frame.
Implements QAbstractVideoBuffer.
Definition at line 68 of file qcgwindowcapture.mm.
References QVideoFrame::NotMapped.