descriptor
This commit is contained in:
parent
9f62233a07
commit
962cc4b8cb
2 changed files with 13 additions and 8 deletions
|
|
@ -40,6 +40,7 @@ export namespace Crafter {
|
|||
public:
|
||||
inline static Event<void> onDescriptorRefresh;
|
||||
inline static std::uint32_t setIndex = 0;
|
||||
inline static std::uint32_t setsCount = 0;
|
||||
inline static std::vector<VkDescriptorSet> sets;
|
||||
inline static VkDescriptorPool descriptorPool[PoolCount] = { VK_NULL_HANDLE };
|
||||
|
||||
|
|
@ -116,19 +117,19 @@ export namespace Crafter {
|
|||
public:
|
||||
static void BuildPool(std::uint32_t poolIndex) {
|
||||
if(descriptorPool[poolIndex] != VK_NULL_HANDLE) {
|
||||
vkDestroyDescriptorPool(VulkanDevice::device, descriptorPool, nullptr);
|
||||
vkDestroyDescriptorPool(VulkanDevice::device, descriptorPool[poolIndex], nullptr);
|
||||
}
|
||||
|
||||
std::array<VkDescriptorPoolSize, uniqueDescriptorCount> poolSizes = GetPoolSizes();
|
||||
for(VkDescriptorPoolSize& size : poolSizes) {
|
||||
size.descriptorCount *= sets.size();
|
||||
size.descriptorCount *= setsCount;
|
||||
}
|
||||
|
||||
VkDescriptorPoolCreateInfo descriptorPoolInfo {
|
||||
.sType = VK_STRUCTURE_TYPE_DESCRIPTOR_POOL_CREATE_INFO,
|
||||
.maxSets = static_cast<std::uint32_t>(setsCount),
|
||||
.poolSizeCount = uniqueDescriptorCount,
|
||||
.pPoolSizes = poolSizes.data(),
|
||||
.maxSets = sets.size()
|
||||
.pPoolSizes = poolSizes.data()
|
||||
};
|
||||
|
||||
VulkanDevice::CheckVkResult(vkCreateDescriptorPool(VulkanDevice::device, &descriptorPoolInfo, nullptr, &descriptorPool[poolIndex]));
|
||||
|
|
@ -141,8 +142,8 @@ export namespace Crafter {
|
|||
constexpr std::array<VkDescriptorSetLayoutBinding, Shaders::descriptorCount> setLayoutBindingsMesh = GetDescriptorSet<Shaders>();
|
||||
VkDescriptorSetLayoutCreateInfo descriptorLayoutInfoMesh = {
|
||||
.sType = VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_CREATE_INFO,
|
||||
.pBindings = setLayoutBindingsMesh.data(),
|
||||
.bindingCount = Shaders::descriptorCount
|
||||
.bindingCount = Shaders::descriptorCount,
|
||||
.pBindings = setLayoutBindingsMesh.data()
|
||||
};
|
||||
VulkanDevice::CheckVkResult(vkCreateDescriptorSetLayout(VulkanDevice::device, &descriptorLayoutInfoMesh, nullptr, &descriptorSetLayout[shaderIndex++]));
|
||||
}(),
|
||||
|
|
@ -151,10 +152,11 @@ export namespace Crafter {
|
|||
VkDescriptorSetAllocateInfo allocInfo {
|
||||
.sType = VK_STRUCTURE_TYPE_DESCRIPTOR_SET_ALLOCATE_INFO,
|
||||
.descriptorPool = descriptorPool[poolIndex],
|
||||
.descriptorSetCount = setsCount,
|
||||
.pSetLayouts = descriptorSetLayout,
|
||||
.descriptorSetCount = sets.size()
|
||||
};
|
||||
|
||||
sets.resize(setsCount);
|
||||
VulkanDevice::CheckVkResult(vkAllocateDescriptorSets(VulkanDevice::device, &allocInfo, sets.data()));
|
||||
|
||||
setIndex = 0;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue