nice
This commit is contained in:
47
include/td/render/Renderer.h
Normal file
47
include/td/render/Renderer.h
Normal file
@@ -0,0 +1,47 @@
|
||||
#pragma once
|
||||
|
||||
#include <td/render/Camera.h>
|
||||
#include <td/render/loader/GLLoader.h>
|
||||
#include <memory>
|
||||
|
||||
namespace td {
|
||||
namespace render {
|
||||
|
||||
class Renderer {
|
||||
protected:
|
||||
Camera& m_Camera;
|
||||
|
||||
public:
|
||||
Renderer(Camera& a_Camera) : m_Camera(a_Camera) {}
|
||||
virtual ~Renderer() {}
|
||||
|
||||
virtual void Render() = 0;
|
||||
|
||||
void Render(const GL::VertexArray& a_Vao);
|
||||
};
|
||||
|
||||
class RenderPipeline {
|
||||
private:
|
||||
std::vector<std::unique_ptr<Renderer>> m_Renderers;
|
||||
|
||||
public:
|
||||
RenderPipeline();
|
||||
~RenderPipeline() = default;
|
||||
|
||||
void AddRenderer(std::unique_ptr<Renderer>&& a_Renderer) {
|
||||
m_Renderers.push_back(std::move(a_Renderer));
|
||||
}
|
||||
|
||||
void Clear() {
|
||||
m_Renderers.clear();
|
||||
}
|
||||
|
||||
void Render() {
|
||||
for (auto& renderer : m_Renderers) {
|
||||
renderer->Render();
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
} // namespace render
|
||||
} // namespace td
|
||||
Reference in New Issue
Block a user