light/modules/asset_manager/src/asset_manager.cpp

86 lines
2.6 KiB
C++
Raw Normal View History

#include <asset_parser/assets/text.hpp>
#include <asset_parser/assets/texture.hpp>
#include <renderer/graphics_context.hpp>
#include <renderer/shader.hpp>
#include <renderer/texture.hpp>
#include <asset_manager/asset_manager.hpp>
#include <logger/logger.hpp>
2025-07-05 13:28:41 +03:30
namespace Light {
void AssetManager::load_shader_impl(
2025-07-05 13:28:41 +03:30
const std::string &name,
const std::filesystem::path &vertex_path,
const std::filesystem::path &pixel_path
2025-07-05 13:28:41 +03:30
)
{
try
{
log_trc("Loading shader:");
log_trc("\tname : {}", name);
log_trc("\tvertex path: {}", vertex_path.string());
log_trc("\tpixel path : {}", pixel_path.string());
auto vertex_asset = Assets::TextAsset { vertex_path };
auto pixel_asset = Assets::TextAsset { pixel_path };
2025-07-05 13:28:41 +03:30
auto vertex_blob_metadata = vertex_asset.get_blob_metadata(Assets::BlobMetadata::Tag::text);
auto pixel_blob_metadata = pixel_asset.get_blob_metadata(Assets::BlobMetadata::Tag::text);
2025-07-05 13:28:41 +03:30
auto vertex_blob = Assets::Blob(vertex_blob_metadata.uncompressed_size);
auto pixel_blob = Assets::Blob(pixel_blob_metadata.uncompressed_size);
2025-07-05 13:28:41 +03:30
vertex_asset.unpack_blob(vertex_blob_metadata.tag, vertex_blob.data(), vertex_blob.size());
pixel_asset.unpack_blob(pixel_blob_metadata.tag, pixel_blob.data(), pixel_blob.size());
2025-07-05 13:28:41 +03:30
m_shaders[name] = Ref<Shader>(Shader::create(
std::move(vertex_blob),
std::move(pixel_blob),
GraphicsContext::get_shared_context()
));
}
catch (const std::exception &exp)
{
log_err("Failed to load shader:");
log_err("\tname : {}", name);
log_err("\tvertex path: {}", vertex_path.string());
log_err("\tpixel path : {}", pixel_path.string());
log_err("\texception : {}", exp.what());
}
2025-07-05 13:28:41 +03:30
}
void AssetManager::load_texture_impl(const std::string &name, const std::filesystem::path &path)
2025-07-05 13:28:41 +03:30
{
try
{
log_trc("Loading texture:");
log_trc("\tname: {}", name);
log_trc("\tpath: {}", path.string());
auto asset = Assets::TextureAsset { path };
const auto metadata = asset.get_metadata();
const auto blob_metadata = asset.get_blob_metadata(Assets::BlobMetadata::Tag::color);
2025-07-05 13:28:41 +03:30
auto blob = std::vector<std::byte>(blob_metadata.uncompressed_size);
asset.unpack_blob(blob_metadata.tag, blob.data(), blob.size());
2025-07-05 13:28:41 +03:30
m_textures[name] = Ref<Texture>(Texture::create(
metadata.pixel_size[0],
metadata.pixel_size[1],
metadata.num_components,
std::bit_cast<unsigned char *>(blob.data()),
GraphicsContext::get_shared_context(),
path
));
}
catch (const std::exception &exp)
2025-07-05 13:28:41 +03:30
{
log_err("Failed to load texture:");
log_err("\tname : {}", name);
log_err("\tpath : {}", path.string());
log_err("\texception: {}", exp.what());
2025-07-05 13:28:41 +03:30
}
}
} // namespace Light