mirror of
https://github.com/seekrs/MacroLibX.git
synced 2026-01-12 07:03:34 +00:00
working on code refactor
This commit is contained in:
@@ -1,79 +1,78 @@
|
||||
/* ************************************************************************** */
|
||||
/* */
|
||||
/* ::: :::::::: */
|
||||
/* vk_ubo.cpp :+: :+: :+: */
|
||||
/* UniformBuffer.cpp :+: :+: :+: */
|
||||
/* +:+ +:+ +:+ */
|
||||
/* By: maldavid <kbz_8.dev@akel-engine.com> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2022/10/06 18:45:52 by maldavid #+# #+# */
|
||||
/* Updated: 2024/03/25 17:48:07 by maldavid ### ########.fr */
|
||||
/* Updated: 2024/04/23 14:25:17 by maldavid ### ########.fr */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
#include <pre_compiled.h>
|
||||
#include <PreCompiled.h>
|
||||
|
||||
#include "vk_ubo.h"
|
||||
#include <renderer/renderer.h>
|
||||
#include <core/profiler.h>
|
||||
#include <Renderer/Buffers/UniformBuffer.h>
|
||||
#include <Renderer/Renderer.h>
|
||||
|
||||
namespace mlx
|
||||
{
|
||||
void UBO::create(Renderer* renderer, std::uint32_t size, [[maybe_unused]] const char* name)
|
||||
void UniformBuffer::create(NonOwningPtr<Renderer> renderer, std::uint32_t size, [[maybe_unused]] const char* name)
|
||||
{
|
||||
MLX_PROFILE_FUNCTION();
|
||||
_renderer = renderer;
|
||||
p_renderer = renderer;
|
||||
|
||||
for(int i = 0; i < MAX_FRAMES_IN_FLIGHT; i++)
|
||||
{
|
||||
#ifdef DEBUG
|
||||
std::string name_frame = name;
|
||||
name_frame.append(std::to_string(i));
|
||||
_buffers[i].create(Buffer::kind::uniform, size, VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT, name_frame.c_str());
|
||||
m_buffers[i].create(BufferType::HighDynamic, size, VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT, name_frame.c_str());
|
||||
#else
|
||||
_buffers[i].create(Buffer::kind::uniform, size, VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT, nullptr);
|
||||
_buffers[i].Create(BufferType::HighDynamic, size, VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT, nullptr);
|
||||
#endif
|
||||
_buffers[i].mapMem(&_maps[i]);
|
||||
if(_maps[i] == nullptr)
|
||||
core::error::report(e_kind::fatal_error, "Vulkan : unable to map a uniform buffer");
|
||||
m_buffers[i].MapMem(&_maps[i]);
|
||||
if(m_maps[i] == nullptr)
|
||||
FatalError("Vulkan : unable to map a uniform buffer");
|
||||
}
|
||||
}
|
||||
|
||||
void UBO::setData(std::uint32_t size, const void* data)
|
||||
void UniformBuffer::SetData(std::uint32_t size, const void* data)
|
||||
{
|
||||
MLX_PROFILE_FUNCTION();
|
||||
std::memcpy(_maps[_renderer->getActiveImageIndex()], data, static_cast<std::size_t>(size));
|
||||
std::memcpy(m_maps[p_renderer->GetActiveImageIndex()], data, static_cast<std::size_t>(size));
|
||||
}
|
||||
|
||||
void UBO::setDynamicData(std::uint32_t size, const void* data)
|
||||
void UniformBuffer::SetDynamicData(std::uint32_t size, const void* data)
|
||||
{
|
||||
MLX_PROFILE_FUNCTION();
|
||||
std::memcpy(_maps[_renderer->getActiveImageIndex()], data, static_cast<std::size_t>(size));
|
||||
_buffers[_renderer->getActiveImageIndex()].flush();
|
||||
std::memcpy(m_maps[p_renderer->GetActiveImageIndex()], data, static_cast<std::size_t>(size));
|
||||
m_buffers[p_renderer->GetActiveImageIndex()].Flush();
|
||||
}
|
||||
|
||||
unsigned int UBO::getSize() noexcept
|
||||
unsigned int UniformBuffer::GetSize() noexcept
|
||||
{
|
||||
return _buffers[_renderer->getActiveImageIndex()].getSize();
|
||||
return m_buffers[p_renderer->GetActiveImageIndex()].GetSize();
|
||||
}
|
||||
|
||||
unsigned int UBO::getOffset() noexcept
|
||||
unsigned int UniformBuffer::GetOffset() noexcept
|
||||
{
|
||||
return _buffers[_renderer->getActiveImageIndex()].getOffset();
|
||||
return m_buffers[p_renderer->GetActiveImageIndex()].GetOffset();
|
||||
}
|
||||
|
||||
VkBuffer& UBO::operator()() noexcept
|
||||
VkBuffer& UniformBuffer::operator()() noexcept
|
||||
{
|
||||
return _buffers[_renderer->getActiveImageIndex()].get();
|
||||
return m_buffers[p_renderer->GetActiveImageIndex()].Get();
|
||||
}
|
||||
|
||||
VkBuffer& UBO::get() noexcept
|
||||
VkBuffer& UniformBuffer::Get() noexcept
|
||||
{
|
||||
return _buffers[_renderer->getActiveImageIndex()].get();
|
||||
return m_buffers[p_renderer->GetActiveImageIndex()].Get();
|
||||
}
|
||||
|
||||
void UBO::destroy() noexcept
|
||||
void UniformBuffer::Destroy() noexcept
|
||||
{
|
||||
for(int i = 0; i < MAX_FRAMES_IN_FLIGHT; i++)
|
||||
_buffers[i].destroy();
|
||||
m_buffers[i].Destroy();
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user