#pragma once #include "log.hpp" #include "gfx.hpp" #include "gfx_device.hpp" #include #include #include namespace engine { struct Vertex { glm::vec3 pos; glm::vec3 norm; glm::vec2 uv; }; } namespace engine::resources { class Mesh { public: Mesh(GFXDevice* gfx, const std::vector& vertices) : m_gfx(gfx) { std::vector indices(vertices.size()); for (uint32_t i = 0; i < indices.size(); i++) { indices[i] = i; } initMesh(vertices, indices); } Mesh(GFXDevice* gfx, const std::vector& vertices, const std::vector& indices) : m_gfx(gfx) { initMesh(vertices, indices); } ~Mesh() { m_gfx->destroyBuffer(m_ib); m_gfx->destroyBuffer(m_vb); } Mesh(const Mesh&) = delete; Mesh& operator=(const Mesh&) = delete; auto getVB() { return m_vb; } auto getIB() { return m_ib; } auto getCount() { return m_count; } private: GFXDevice* const m_gfx; const gfx::Buffer* m_vb; const gfx::Buffer* m_ib; uint32_t m_count; void initMesh(const std::vector& vertices, const std::vector& indices) { m_vb = m_gfx->createBuffer(gfx::BufferType::VERTEX, vertices.size() * sizeof(Vertex), vertices.data()); m_ib = m_gfx->createBuffer(gfx::BufferType::INDEX, indices.size() * sizeof(uint32_t), indices.data()); m_count = indices.size(); INFO("Loaded mesh, vertices: {}, indices: {}", vertices.size(), indices.size()); } }; }