Texture implementation basics
This commit is contained in:
@@ -16,6 +16,7 @@ namespace OpenVulkano::Vulkan
|
||||
format = imageCreateInfo.format;
|
||||
extent = imageCreateInfo.extent;
|
||||
|
||||
// TODO allocate from resource manager
|
||||
const vk::MemoryRequirements memRequirements = device->device.getImageMemoryRequirements(image);
|
||||
size = allocSize = memRequirements.size;
|
||||
const vk::MemoryAllocateInfo memAllocInfo = { allocSize, device->GetMemoryType(memRequirements.memoryTypeBits, memoryPropertyFlags) };
|
||||
@@ -38,27 +39,19 @@ namespace OpenVulkano::Vulkan
|
||||
{
|
||||
this->device = device->device;
|
||||
|
||||
vk::ImageCreateInfo imgCreateInfo;
|
||||
imgCreateInfo.imageType = vk::ImageType::e2D;
|
||||
imgCreateInfo.extent = resolution;
|
||||
imgCreateInfo.mipLevels = 1;
|
||||
imgCreateInfo.arrayLayers = 1;
|
||||
imgCreateInfo.format = vk::Format::eR8G8B8Srgb;
|
||||
imgCreateInfo.tiling = vk::ImageTiling::eOptimal;
|
||||
imgCreateInfo.initialLayout = vk::ImageLayout::eUndefined;
|
||||
imgCreateInfo.usage = vk::ImageUsageFlagBits::eTransferDst | vk::ImageUsageFlagBits::eSampled;
|
||||
imgCreateInfo.sharingMode = vk::SharingMode::eExclusive;
|
||||
imgCreateInfo.samples = vk::SampleCountFlagBits::e1;
|
||||
vk::ImageCreateInfo imgCreateInfo { {}, vk::ImageType::e2D, vk::Format::eB8G8R8A8Unorm, resolution, 1, 1 };
|
||||
|
||||
vk::ImageViewCreateInfo imgViewCreateInfo;
|
||||
imgViewCreateInfo.image = image;
|
||||
imgViewCreateInfo.format = imgCreateInfo.format;
|
||||
imgViewCreateInfo.viewType = vk::ImageViewType::e2D;
|
||||
imgCreateInfo.usage = vk::ImageUsageFlagBits::eTransferDst | vk::ImageUsageFlagBits::eSampled;
|
||||
imgCreateInfo.tiling = vk::ImageTiling::eOptimal;
|
||||
imgCreateInfo.sharingMode = vk::SharingMode::eExclusive;
|
||||
imgCreateInfo.initialLayout = vk::ImageLayout::eUndefined;
|
||||
|
||||
vk::ImageViewCreateInfo imgViewCreateInfo { {}, image, vk::ImageViewType::e2D, imgCreateInfo.format };
|
||||
imgViewCreateInfo.subresourceRange.aspectMask = vk::ImageAspectFlagBits::eColor;
|
||||
imgViewCreateInfo.subresourceRange.baseMipLevel = 0;
|
||||
imgViewCreateInfo.subresourceRange.levelCount = 1;
|
||||
imgViewCreateInfo.subresourceRange.baseArrayLayer = 0;
|
||||
imgViewCreateInfo.subresourceRange.levelCount = 1;
|
||||
imgViewCreateInfo.subresourceRange.layerCount = VK_REMAINING_ARRAY_LAYERS;
|
||||
|
||||
Init(device, imgCreateInfo, imgViewCreateInfo);
|
||||
CreateSampler();
|
||||
|
||||
@@ -148,7 +148,7 @@ namespace OpenVulkano::Vulkan
|
||||
const std::unique_lock lock(mutex);
|
||||
if (material->texture && !material->texture->renderTexture)
|
||||
{
|
||||
material->texture->renderTexture = PrepareTexture(material->texture);
|
||||
PrepareTexture(material->texture);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -291,6 +291,21 @@ namespace OpenVulkano::Vulkan
|
||||
vk::BufferImageCopy region(0, 0, 0, { vk::ImageAspectFlagBits::eColor, 0, 0, 1 }, { 0, 0, 0 }, image->extent);
|
||||
cmdBuffers[currentBuffer].copyBufferToImage(uploadBuffer->buffer, image->image, vk::ImageLayout::eTransferDstOptimal, 1, ®ion);
|
||||
|
||||
vk::ImageMemoryBarrier barrier {};
|
||||
barrier.oldLayout = vk::ImageLayout::eUndefined;
|
||||
barrier.newLayout = vk::ImageLayout::eShaderReadOnlyOptimal;
|
||||
barrier.image = image->image;
|
||||
barrier.subresourceRange.aspectMask = vk::ImageAspectFlagBits::eColor;
|
||||
barrier.subresourceRange.baseMipLevel = 0;
|
||||
barrier.subresourceRange.levelCount = 1;
|
||||
barrier.subresourceRange.baseArrayLayer = 0;
|
||||
barrier.subresourceRange.layerCount = 1;
|
||||
barrier.setSrcAccessMask({});
|
||||
barrier.setDstAccessMask(vk::AccessFlagBits::eTransferWrite);
|
||||
|
||||
// TODO set access masks for mip and array layers
|
||||
cmdBuffers[currentBuffer].pipelineBarrier(vk::PipelineStageFlagBits::eTopOfPipe, vk::PipelineStageFlagBits::eTransfer, {}, 0, nullptr, 0, nullptr, 1, &barrier );
|
||||
|
||||
FreeBuffer(uploadBuffer);
|
||||
}
|
||||
|
||||
@@ -365,8 +380,7 @@ namespace OpenVulkano::Vulkan
|
||||
{
|
||||
VulkanTexture* vkTexture = new VulkanTexture();
|
||||
|
||||
vkTexture->Init(this, texture);
|
||||
//vkTexture->
|
||||
vkTexture->Init(this, texture, GetDescriptorLayoutSet(Scene::Texture::DESCRIPTOR_SET_LAYOUT_BINDING), Scene::Texture::DESCRIPTOR_SET_LAYOUT_BINDING, 2);
|
||||
|
||||
return vkTexture;
|
||||
}
|
||||
|
||||
@@ -40,6 +40,7 @@ namespace OpenVulkano
|
||||
class ResourceManager : public ICloseable, public IShaderOwner
|
||||
{
|
||||
friend UniformBuffer;
|
||||
friend VulkanTexture;
|
||||
|
||||
Context* context;
|
||||
vk::Device device = nullptr;
|
||||
|
||||
@@ -10,6 +10,7 @@
|
||||
#include "Vulkan/Image.hpp"
|
||||
#include "Vulkan/Context.hpp"
|
||||
#include "Vulkan/Resources/ResourceManager.hpp"
|
||||
#include "Vulkan/Scene/VulkanShader.hpp"
|
||||
#include "Scene/Texture.hpp"
|
||||
|
||||
namespace OpenVulkano::Vulkan
|
||||
@@ -18,22 +19,36 @@ namespace OpenVulkano::Vulkan
|
||||
{
|
||||
public:
|
||||
Scene::Texture* m_texture = nullptr;
|
||||
vk::DescriptorSet m_descriptorSet;
|
||||
uint32_t m_setId;
|
||||
|
||||
virtual void Init(ResourceManager* resManager, Scene::Texture* texture)
|
||||
virtual void Init(ResourceManager* resManager, Scene::Texture* texture, vk::DescriptorSetLayout* descriptorSetLayout, const DescriptorSetLayoutBinding& binding, uint32_t setId)
|
||||
{
|
||||
this->m_texture = texture;
|
||||
m_texture = texture;
|
||||
m_setId = setId;
|
||||
Image::Init(resManager->GetContext()->device.get(), { texture->resolution.x, texture->resolution.y, texture->resolution.z });
|
||||
resManager->CopyDataToImage(m_texture->size, m_texture->textureBuffer, this);
|
||||
texture->updated = false;
|
||||
|
||||
// Setup Descriptor set
|
||||
const vk::DescriptorSetAllocateInfo descSetAllocInfo = { ResourceManager::INSTANCE->descriptorPool, 1, descriptorSetLayout };
|
||||
m_descriptorSet = resManager->GetContext()->device->device.allocateDescriptorSets(descSetAllocInfo)[0];
|
||||
vk::DescriptorImageInfo imageInfo = { sampler, view, vk::ImageLayout::eShaderReadOnlyOptimal };
|
||||
vk::WriteDescriptorSet writeDescriptorSet = { m_descriptorSet, binding.bindingId, 0, 1 };
|
||||
writeDescriptorSet.descriptorType = static_cast<vk::DescriptorType>(binding.descriptorType);
|
||||
writeDescriptorSet.pImageInfo = &imageInfo;
|
||||
resManager->GetContext()->device->device.updateDescriptorSets(1, &writeDescriptorSet, 0, nullptr);
|
||||
|
||||
texture->renderTexture = this;
|
||||
}
|
||||
|
||||
void Record(VulkanDrawContext* context) override
|
||||
{
|
||||
//cmdBuffer.bindDescriptorSets(vk::PipelineBindPoint::eGraphics, )
|
||||
context->commandBuffer.bindDescriptorSets(vk::PipelineBindPoint::eGraphics, context->GetShader()->pipelineLayout, m_setId, 1, &m_descriptorSet, 0, nullptr);
|
||||
}
|
||||
};
|
||||
|
||||
class VulkanTextureDynamic : VulkanTexture
|
||||
/*class VulkanTextureDynamic : VulkanTexture
|
||||
{
|
||||
public:
|
||||
uint32_t lastUpdate = -1;
|
||||
@@ -48,13 +63,13 @@ namespace OpenVulkano::Vulkan
|
||||
|
||||
void Record(VulkanDrawContext* context) override
|
||||
{
|
||||
/*if(bufferId != lastUpdate && m_texture->updated)
|
||||
if(bufferId != lastUpdate && m_texture->updated)
|
||||
{
|
||||
lastUpdate = bufferId;
|
||||
resourceManager->CopyDataToImage(m_texture->size, m_texture->textureBuffer, this);
|
||||
m_texture->updated = false;
|
||||
}
|
||||
VulkanTexture::Record(cmdBuffer, bufferId);*/
|
||||
VulkanTexture::Record(cmdBuffer, bufferId);
|
||||
}
|
||||
};
|
||||
};*/
|
||||
}
|
||||
Reference in New Issue
Block a user