60 lines
1.8 KiB
C++
60 lines
1.8 KiB
C++
#pragma once
|
|
|
|
#include "shader.h"
|
|
#include "../event/event.h"
|
|
#include "vao.h"
|
|
#include "vbo.h"
|
|
#include "../vertex.h"
|
|
#include "../renderable.h"
|
|
#include "../transformable.h"
|
|
#include "material.h"
|
|
#include "../vector.h"
|
|
|
|
#include <optional>
|
|
#include <vector>
|
|
|
|
namespace simpleengine::gfx {
|
|
/**
|
|
* @brief A Mesh is a object that will be shown on the screen by a renderer.
|
|
*
|
|
*/
|
|
class Mesh : public simpleengine::Event, public simpleengine::Transformable {
|
|
public:
|
|
std::optional<Material> material;
|
|
std::vector<LitVertex> vertices;
|
|
std::vector<GLuint> indicies;
|
|
|
|
std::vector<simpleengine::Vectorf> tangents;
|
|
gfx::VBO tangent_vbo;
|
|
|
|
bool are_buffers_created = false;
|
|
gfx::VBO ebo;
|
|
gfx::VBO vbo;
|
|
gfx::VAO vao;
|
|
|
|
Mesh(std::vector<LitVertex> vertices, std::vector<GLuint> indicies, Material material);
|
|
Mesh(std::vector<LitVertex> vertices, std::vector<GLuint> indicies = std::vector<GLuint>(), std::optional<Material> material = std::nullopt);
|
|
Mesh(std::vector<LitVertex> vertices, std::vector<GLuint> indicies, Material material, gfx::VBO ebo, gfx::VBO vbo, gfx::VAO vao, gfx::VBO tangent_vbo);
|
|
|
|
virtual void destroy() override;
|
|
|
|
virtual void update(const float& delta_time) override;
|
|
|
|
glm::vec3 compute_face_normal(const glm::vec3& p1, const glm::vec3& p2, const glm::vec3& p3);
|
|
|
|
/**
|
|
* @brief Calculate the normals of the model.
|
|
*
|
|
* @note This **will** overwrite the existing normals.
|
|
*
|
|
*/
|
|
void calculate_normals();
|
|
|
|
/**
|
|
* @brief Calculate tangents and bi-tangents (tangent space) for the model.
|
|
*
|
|
* @note This **will** overwrite the existing tangents and bi-tangents.
|
|
*/
|
|
void calculate_tangents();
|
|
};
|
|
} |