-
Notifications
You must be signed in to change notification settings - Fork 434
DescriptorHeap
In order to render with resources like textures, DirectX 12 uses a descriptor to provide the meta-data required. This helper provides a simple manager for the GPU memory heap of resource descriptors.
See also DescriptorPile
Related tutorial: Sprites and textures
#include "DescriptorHeap.h"
The client application maintains a list of identifiers for each resource, such as:
enum Descriptors
{
WindowsLogo,
Count = 256
};
resourceDescriptors = std::make_unique<DescriptorHeap>(device,
D3D12_DESCRIPTOR_HEAP_TYPE_CBV_SRV_UAV,
D3D12_DESCRIPTOR_HEAP_FLAG_SHADER_VISIBLE,
Descriptors::Count);
You can then use this to create shader resource view as a resource descriptor:
D3D12_SHADER_RESOURCE_VIEW_DESC desc = {};
...
device->CreateShaderResourceView(tex, &desc,
resourceDescriptors->GetCpuHandle(Descriptors::WindowsLogo));
To render, the descriptor heap must be made active on the current command list:
ID3D12DescriptorHeap* heaps[] = { resourceDescriptors->Heap() };
commandList->SetDescriptorHeaps(_countof(heaps), heaps);
References to elements on the heap are made using the client identifiers:
// Returns a D3D12_GPU_DESCRIPTOR_HANDLE
resourceDescriptors->GetGpuHandle(Descriptors::WindowsLogo)
// Returns a D3D12_CPU_DESCRIPTOR_HANDLE
resourceDescriptors->GetCpuHandle(Descriptors::WindowsLogo)
To provide flexibility, setting the proper descriptor heaps to render with via
SetDescriptorHeaps
is left to the caller.
DescriptorHeap can also be used for creating Render Target View Descriptors or Depth/Stencil View Descriptors:
enum RTDescriptors
{
SceneRT,
Blur1RT,
Blur2RT,
RTCount
};
renderDescriptors = std::make_unique<DescriptorHeap>(device,
D3D12_DESCRIPTOR_HEAP_TYPE_RTV,
D3D12_DESCRIPTOR_HEAP_FLAG_NONE,
RTDescriptors::RTCount);
device->CreateRenderTargetView(sceneTex.Get(),
nullptr,
renderDescriptors->GetCpuHandle(RTDescriptors::SceneRT));
auto rtvDescriptor = m_renderDescriptors->GetCpuHandle(RTDescriptors::SceneRT);
commandList->OMSetRenderTargets(1, &rtvDescriptor, FALSE, &dsvDescriptor);
Strongly typed enums (a.k.a.
enum class
) are not recommended here as this requires adding astatic_cast<int>
when usingGetCpuHandle
or `GetGpuHandle``.
You can use DescriptorHeap
to create your own sampler descriptor heap, but you can also make use of CommonStates which provides common combinations of sampler state. When used in conjunction with DescriptorHeap
for the texture descriptors, the built-in effects expect drawing with the following heap settings:
ID3D12DescriptorHeap* heaps[] = { resourceDescriptors->Heap(), states->Heap() };
commandList->SetDescriptorHeaps(_countof(heaps), heaps);
You can create as many heaps as you wish in your application, but remember that you can have only a single texture descriptor heap and a single sampler descriptor heap active at a given time.
Creation of resources is fully asynchronous, so you can create many heaps at the same time.
All content and source code for this package are subject to the terms of the MIT License.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact [email protected] with any additional questions or comments.
- Universal Windows Platform apps
- Windows desktop apps
- Windows 11
- Windows 10
- Xbox One
- Xbox Series X|S
- x86
- x64
- ARM64
- Visual Studio 2022
- Visual Studio 2019 (16.11)
- clang/LLVM v12 - v18
- MinGW 12.2, 13.2
- CMake 3.20