![]() |
Qt 6.x
The Qt SDK
|
#include <qrhimetal_p.h>
Inheritance diagram for QMetalTextureRenderTarget:
Collaboration diagram for QMetalTextureRenderTarget:Public Member Functions | |
| QMetalTextureRenderTarget (QRhiImplementation *rhi, const QRhiTextureRenderTargetDescription &desc, Flags flags) | |
| ~QMetalTextureRenderTarget () | |
| void | destroy () override |
| Releases (or requests deferred releasing of) the underlying native graphics resources. | |
| QSize | pixelSize () const override |
| float | devicePixelRatio () const override |
| int | sampleCount () const override |
| QRhiRenderPassDescriptor * | newCompatibleRenderPassDescriptor () override |
| bool | create () override |
| Creates the corresponding native graphics resources. | |
Public Member Functions inherited from QRhiTextureRenderTarget | |
| QRhiResource::Type | resourceType () const override |
| QRhiTextureRenderTargetDescription | description () const |
| void | setDescription (const QRhiTextureRenderTargetDescription &desc) |
| Sets the render target description desc. | |
| Flags | flags () const |
| void | setFlags (Flags f) |
| Sets the flags to f. | |
| virtual QRhiRenderPassDescriptor * | newCompatibleRenderPassDescriptor ()=0 |
| virtual bool | create ()=0 |
| Creates the corresponding native graphics resources. | |
Public Member Functions inherited from QRhiRenderTarget | |
| virtual QSize | pixelSize () const =0 |
| virtual float | devicePixelRatio () const =0 |
| virtual int | sampleCount () const =0 |
| QRhiRenderPassDescriptor * | renderPassDescriptor () const |
| void | setRenderPassDescriptor (QRhiRenderPassDescriptor *desc) |
| Sets the QRhiRenderPassDescriptor desc for use with this render target. | |
Public Member Functions inherited from QRhiResource | |
| virtual | ~QRhiResource () |
| Destructor. | |
| virtual Type | resourceType () const =0 |
| virtual void | destroy ()=0 |
| Releases (or requests deferred releasing of) the underlying native graphics resources. | |
| void | deleteLater () |
| When called without a frame being recorded, this function is equivalent to deleting the object. | |
| QByteArray | name () const |
| void | setName (const QByteArray &name) |
| Sets a name for the object. | |
| quint64 | globalResourceId () const |
| QRhi * | rhi () const |
Public Attributes | |
| QMetalRenderTargetData * | d |
Friends | |
| class | QRhiMetal |
Definition at line 145 of file qrhimetal_p.h.
| QMetalTextureRenderTarget::QMetalTextureRenderTarget | ( | QRhiImplementation * | rhi, |
| const QRhiTextureRenderTargetDescription & | desc, | ||
| Flags | flags | ||
| ) |
Definition at line 4118 of file qrhimetal.mm.
| QMetalTextureRenderTarget::~QMetalTextureRenderTarget | ( | ) |
|
overridevirtual |
Creates the corresponding native graphics resources.
If there are already resources present due to an earlier create() with no corresponding destroy(), then destroy() is called implicitly first.
true when successful, false when a graphics operation failed. Regardless of the return value, calling destroy() is always safe. Implements QRhiTextureRenderTarget.
Definition at line 4165 of file qrhimetal.mm.
References QMetalRenderTargetData::ColorAtt::arrayLayer, QRhiTextureRenderTargetDescription::cbeginColorAttachments(), QRhiTextureRenderTargetDescription::cendColorAttachments(), QMetalRenderTargetData::colorAtt, QRhiTextureRenderTargetDescription::colorAttachmentCount(), QMetalRenderTargetData::colorAttCount, QMetalRenderTargetData::currentResIdList, QMetalRenderBuffer::d, QMetalTexture::d, d, QMetalRenderTargetData::depthNeedsStore, QRhiTextureRenderTargetDescription::depthStencilBuffer(), QRhiTextureRenderTargetDescription::depthTexture(), QMetalRenderTargetData::dpr, QMetalRenderTargetData::dsAttCount, QMetalRenderTargetData::dsTex, QMetalRenderTargetData::fb, QRhiTexture::flags(), QRhiTexture::format(), QMetalRenderTargetData::hasStencil, it, QMetalRenderTargetData::ColorAtt::level, QRhiTextureRenderTarget::m_desc, QRhiTexture::pixelSize(), QRhiRenderBuffer::pixelSize(), QMetalRenderTargetData::pixelSize, Q_ASSERT, QRHI_RES, QRHI_RES_RHI, QMetalRenderTargetData::ColorAtt::resolveLayer, QMetalRenderTargetData::ColorAtt::resolveLevel, QMetalRenderTargetData::ColorAtt::resolveTex, QMetalRenderTargetData::sampleCount, QMetalRenderBuffer::samples, QMetalTexture::samples, QMetalRenderTargetData::ColorAtt::slice, QMetalRenderBufferData::tex, QMetalTextureData::tex, QMetalRenderTargetData::ColorAtt::tex, and QRhiTexture::ThreeDimensional.
Referenced by QRhiMetal::beginPass(), and pixelSize().
Here is the call graph for this function:
Here is the caller graph for this function:
|
overridevirtual |
Releases (or requests deferred releasing of) the underlying native graphics resources.
Safe to call multiple times, subsequent invocations will be a no-op then.
Once destroy() is called, the QRhiResource instance can be reused, by calling create() again. That will then result in creating new native graphics resources underneath.
The QRhiResource destructor also performs the same task, so calling this function is not necessary before deleting a QRhiResource.
Implements QRhiResource.
Definition at line 4132 of file qrhimetal.mm.
References QRHI_RES_RHI.
Referenced by ~QMetalTextureRenderTarget().
Here is the caller graph for this function:
|
overridevirtual |
Implements QRhiRenderTarget.
Definition at line 4247 of file qrhimetal.mm.
References d, and QMetalRenderTargetData::dpr.
|
overridevirtual |
The returned value is used in two ways: it can be passed to setRenderPassDescriptor() and QRhiGraphicsPipeline::setRenderPassDescriptor(). A render pass descriptor describes the attachments (color, depth/stencil) and the load/store behavior that can be affected by flags(). A QRhiGraphicsPipeline can only be used in combination with a render target that has a \l{QRhiRenderPassDescriptor::isCompatible()}{compatible} QRhiRenderPassDescriptor set.
Two QRhiTextureRenderTarget instances can share the same render pass descriptor as long as they have the same number and type of attachments. The associated QRhiTexture or QRhiRenderBuffer instances are not part of the render pass descriptor so those can differ in the two QRhiTextureRenderTarget instances.
Implements QRhiTextureRenderTarget.
Definition at line 4139 of file qrhimetal.mm.
References QRhiTextureRenderTargetDescription::colorAttachmentAt(), QRhiTextureRenderTargetDescription::colorAttachmentCount(), QMetalRenderPassDescriptor::colorAttachmentCount, QMetalRenderPassDescriptor::colorFormat, QMetalRenderBuffer::d, QMetalTexture::d, QRhiTextureRenderTargetDescription::depthStencilBuffer(), QRhiTextureRenderTargetDescription::depthTexture(), QMetalRenderPassDescriptor::dsFormat, QMetalRenderBufferData::format, QMetalTextureData::format, QMetalRenderPassDescriptor::hasDepthStencil, i, QRhiTextureRenderTarget::m_desc, QRhiResource::m_rhi, QRHI_RES, QRHI_RES_RHI, QRhiColorAttachment::renderBuffer(), QRhiColorAttachment::texture(), and QMetalRenderPassDescriptor::updateSerializedFormat().
Here is the call graph for this function:
|
overridevirtual |
Valid only after create() has been called successfully. Until then the result is a default-constructed QSize.
With QRhiTextureRenderTarget the returned size is the size of the associated attachments at the time of create(), in practice the size of the first color attachment, or the depth/stencil buffer if there are no color attachments. If the associated textures or renderbuffers are resized and rebuilt afterwards, then pixelSize() performs an implicit call to create() in order to rebuild the underlying data structures. This implicit check is similar to what QRhiCommandBuffer::beginPass() does, and ensures that the returned size is always up-to-date.
Implements QRhiRenderTarget.
Definition at line 4239 of file qrhimetal.mm.
References create(), QMetalRenderTargetData::currentResIdList, d, QRhiTextureRenderTarget::m_desc, and QMetalRenderTargetData::pixelSize.
Here is the call graph for this function:
|
overridevirtual |
Implements QRhiRenderTarget.
Definition at line 4252 of file qrhimetal.mm.
References d, and QMetalRenderTargetData::sampleCount.
|
friend |
Definition at line 159 of file qrhimetal_p.h.
| QMetalRenderTargetData* QMetalTextureRenderTarget::d |
Definition at line 158 of file qrhimetal_p.h.
Referenced by ~QMetalTextureRenderTarget(), QRhiMetal::beginPass(), create(), devicePixelRatio(), pixelSize(), and sampleCount().