Throbbing Trapezoid

The trapezoid now throbs between black and white. This was made to
test out the element buffers using MyBatch. Next up for the
batches should probably be to figure out the recommended way of
specifying more than one element buffer. Currently it is done
by specifying the number of elements to be stored and the number
of element vbos needed but maybe there is some way to get it to
work using variadic templates. There is a comment about this in
the Batch.h file.
This commit is contained in:
elipzer 2018-09-07 00:41:34 -04:00
parent 3485bcb2a0
commit 0a9fde252a
11 changed files with 160 additions and 17 deletions

View File

@ -12,7 +12,10 @@ namespace
struct EmptyElement {}; struct EmptyElement {};
} }
template <typename VertexType, typename IndexType, typename ElementType = EmptyElement, typename RenderableType = Renderable<VertexType, IndexType> > // TODO: Element buffer count as just the number of element types and allow multiple
// element types to be passed via Variadic Templates (see http://www.cplusplus.com/articles/EhvU7k9E/ )
// This is effectively just support for more than one element vbo per rendered instance
template <typename VertexType, typename IndexType, int element_buffer_count = 0, typename ElementType = EmptyElement, typename RenderableType = Renderable<VertexType, IndexType> >
class Batch class Batch
{ {
public: public:
@ -23,7 +26,7 @@ public:
const SizeType& element_count, const SizeType& element_count,
const SizeType& element_render_count const SizeType& element_render_count
) )
: m_p_renderable(renderable), m_elements(element_count), m_element_render_count(element_render_count) : m_p_renderable(renderable), m_elements(element_count), m_element_render_count(element_render_count), m_element_buffers(element_buffer_count)
{ {
if (std::is_same<unsigned int, IndexType>::value) if (std::is_same<unsigned int, IndexType>::value)
{ {
@ -45,6 +48,8 @@ public:
glGenVertexArrays(1, &m_vao); glGenVertexArrays(1, &m_vao);
glGenBuffers(1, &m_vertex_vbo); glGenBuffers(1, &m_vertex_vbo);
glGenBuffers(1, &m_index_vbo); glGenBuffers(1, &m_index_vbo);
glGenBuffers(element_buffer_count, m_element_buffers.data());
} }
virtual ~Batch() virtual ~Batch()
@ -52,6 +57,8 @@ public:
glDeleteVertexArrays(1, &m_vao); glDeleteVertexArrays(1, &m_vao);
glDeleteBuffers(1, &m_vertex_vbo); glDeleteBuffers(1, &m_vertex_vbo);
glDeleteBuffers(1, &m_index_vbo); glDeleteBuffers(1, &m_index_vbo);
glDeleteBuffers(element_buffer_count, m_element_buffers.data());
} }
void init() void init()
@ -63,10 +70,9 @@ public:
glBufferData(GL_ELEMENT_ARRAY_BUFFER, m_p_renderable->get_mesh()->index_count * sizeof(IndexType), m_p_renderable->get_mesh()->indices, GL_STATIC_DRAW); glBufferData(GL_ELEMENT_ARRAY_BUFFER, m_p_renderable->get_mesh()->index_count * sizeof(IndexType), m_p_renderable->get_mesh()->indices, GL_STATIC_DRAW);
glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, NULL); glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, NULL);
setup_element_buffer(); setup_element_buffers();
glBindVertexArray(m_vao); // Possibly want to move these three lines into the init function glBindVertexArray(m_vao); // Possibly want to move these three lines into the init function
glBindBuffer(GL_ARRAY_BUFFER, m_vertex_vbo);
glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, m_index_vbo); glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, m_index_vbo);
setup_vao(); setup_vao();
@ -74,6 +80,11 @@ public:
glBindVertexArray(NULL); glBindVertexArray(NULL);
} }
void prerender()
{
update_element_buffers();
}
void render() const void render() const
{ {
glBindVertexArray(m_vao); glBindVertexArray(m_vao);
@ -101,17 +112,21 @@ public:
const ElementType& get_element(const SizeType& index) const { return m_elements[index]; } const ElementType& get_element(const SizeType& index) const { return m_elements[index]; }
protected: protected:
virtual void setup_element_buffer() {} virtual void setup_element_buffers() {}
virtual void setup_vao() = 0; virtual void setup_vao() = 0;
virtual void update_element_buffers() {}
const RenderableType* m_p_renderable; const RenderableType* m_p_renderable;
std::vector<ElementType> m_elements; std::vector<ElementType> m_elements;
SizeType m_element_render_count; SizeType m_element_render_count;
GLuint m_vertex_vbo;
std::vector<GLuint> m_element_buffers;
private: private:
GLuint m_vao; GLuint m_vao;
GLuint m_vertex_vbo;
GLuint m_index_vbo; GLuint m_index_vbo;
GLenum m_gl_index_type; GLenum m_gl_index_type;
}; };

View File

@ -1,8 +1,30 @@
#include "MyBatch.h" #include "MyBatch.h"
void MyBatch::setup_element_buffers()
{
glBindBuffer(GL_ARRAY_BUFFER, m_element_buffers[0]);
// TODO: Maybe make the next line use a typedef instead of MyShaderProgram::ColorType
glBufferData(GL_ARRAY_BUFFER, m_elements.size() * sizeof(MyBatchTestShaderProgram::ColorType), NULL, GL_STREAM_DRAW);
}
void MyBatch::setup_vao() void MyBatch::setup_vao()
{ {
glBindBuffer(GL_ARRAY_BUFFER, m_vertex_vbo);
glEnableVertexAttribArray(0); glEnableVertexAttribArray(0);
glVertexAttribPointer(0, 3, GL_FLOAT, GL_FALSE, 0, NULL); glVertexAttribPointer(0, 3, GL_FLOAT, GL_FALSE, 0, NULL);
glBindBuffer(GL_ARRAY_BUFFER, m_element_buffers[0]);
glEnableVertexAttribArray(1);
glVertexAttribPointer(1, 4, GL_FLOAT, GL_FALSE, 0, NULL);
glVertexAttribDivisor(0, 0); // Only need to send the mesh data once
glVertexAttribDivisor(1, 1); // Send the color data for each instance drawn
}
void MyBatch::update_element_buffers()
{
// TODO: There are probably better ways to do this. Should check with the old engine to see what I did there.
glBindBuffer(GL_ARRAY_BUFFER, m_element_buffers[0]);
glBufferData(GL_ARRAY_BUFFER, m_elements.size() * sizeof(MyBatchTestShaderProgram::ColorType), NULL, GL_STREAM_DRAW);
glBufferSubData(GL_ARRAY_BUFFER, 0, m_elements.size() * sizeof(MyBatchTestShaderProgram::ColorType), m_elements.data());
} }

View File

@ -2,16 +2,21 @@
#include "Batch.h" #include "Batch.h"
#include "MyShaderProgram.h" #include "MyBatchTestShaderProgram.h"
class MyBatch : public Batch<MyShaderProgram::VertexType, MyShaderProgram::IndexType> class MyBatch : public Batch<MyBatchTestShaderProgram::VertexType, MyBatchTestShaderProgram::IndexType, 1, MyBatchTestShaderProgram::ColorType>
{ {
public: public:
MyBatch( MyBatch(
const MyShaderProgram::RenderableType* renderable, const MyBatchTestShaderProgram::RenderableType* renderable,
const SizeType& element_count, const SizeType& element_count,
const SizeType& element_render_count const SizeType& element_render_count
) : Batch(renderable, element_count, element_render_count) {} ) : Batch(renderable, element_count, element_render_count) {}
protected: protected:
void setup_element_buffers() override;
void setup_vao() override; void setup_vao() override;
void update_element_buffers() override;
}; };

View File

@ -0,0 +1,7 @@
#version 400
in vec4 vert_color;
out vec4 frag_color;
void main()
{
frag_color = vert_color;
}

View File

@ -0,0 +1,13 @@
#include "MyBatchTestShaderProgram.h"
#include "Util.h"
MyBatchTestShaderProgram::MyBatchTestShaderProgram()
// TEMP Hardcode in the path. (Should Use Relative Path to General Shader Dir)
: m_vertex_shader(Util::load_file("D:\\Development\\C++\\OpenGLEngine\\OpenGLEngine\\MyBatchTestVertexShader.glsl"), VERTEX_SHADER),
m_fragment_shader(Util::load_file("D:\\Development\\C++\\OpenGLEngine\\OpenGLEngine\\MyBatchTestFragmentShader.glsl"), FRAGMENT_SHADER)
{
attach_shader(m_vertex_shader);
attach_shader(m_fragment_shader);
link();
}

View File

@ -0,0 +1,37 @@
#pragma once
#include "ShaderProgram.h"
#include "Shader.h"
#include "Mesh.h"
#include "Renderable.h"
class MyBatchTestShaderProgram : public ShaderProgram
{
public:
struct VertexType
{
VertexType() {}
VertexType(float x, float y, float z)
: x(x), y(y), z(z)
{}
float x;
float y;
float z;
};
struct ColorType // Try changing to normalized unsigned chars (0-255) for the example
{
float r;
float g;
float b;
float a;
};
typedef unsigned int IndexType;
typedef Renderable<VertexType, IndexType> RenderableType;
typedef Mesh<VertexType, IndexType> MeshType;
MyBatchTestShaderProgram();
private:
Shader m_vertex_shader;
Shader m_fragment_shader;
};

View File

@ -0,0 +1,10 @@
#version 400
layout(location = 0) in vec3 vertex_position;
layout(location = 1) in vec4 vertex_color;
out vec4 vert_color;
void main()
{
gl_Position = vec4(vertex_position, 1.0);
vert_color = vertex_color;
}

View File

@ -4,12 +4,12 @@
#include "MeshFactory.h" #include "MeshFactory.h"
MyObjectOrientedScene::MyObjectOrientedScene() MyObjectOrientedScene::MyObjectOrientedScene()
: m_shape(MeshFactory<MyShaderProgram::VertexType, MyShaderProgram::IndexType>::gen( : m_shape(MeshFactory<MyBatchTestShaderProgram::VertexType, MyBatchTestShaderProgram::IndexType>::gen(
DrawMode::DRAW_TRIANGLES, DrawMode::DRAW_TRIANGLES,
MyShaderProgram::VertexType(-0.5f, 0.4f, 0.0f), MyBatchTestShaderProgram::VertexType(-0.5f, 0.4f, 0.0f),
MyShaderProgram::VertexType(0.5f, 0.4f, 0.0f), MyBatchTestShaderProgram::VertexType(0.5f, 0.4f, 0.0f),
MyShaderProgram::VertexType(-0.8f, -0.4f, 0.0f), MyBatchTestShaderProgram::VertexType(-0.8f, -0.4f, 0.0f),
MyShaderProgram::VertexType(0.8f, -0.4f, 0.0f) MyBatchTestShaderProgram::VertexType(0.8f, -0.4f, 0.0f)
), DrawMode::DRAW_TRIANGLES), m_batch(&m_shape, 1, 1) ), DrawMode::DRAW_TRIANGLES), m_batch(&m_shape, 1, 1)
{ {
} }
@ -36,7 +36,25 @@ void MyObjectOrientedScene::unuse()
void MyObjectOrientedScene::update(float delta_time, clock_t clock) void MyObjectOrientedScene::update(float delta_time, clock_t clock)
{ {
float n;
clock_t c = (clock / 10) % 512;
if (c < 256)
{
n = (float)c / 256;
}
else
{
n = (float)(512 - c) / 256;
}
MyBatchTestShaderProgram::ColorType& element = m_batch.get_element();
element.r = n;
element.g = n;
element.b = n;
element.a = 1.0f;
// TODO: Make a prerender function or move this to render
m_batch.prerender();
} }
void MyObjectOrientedScene::render() void MyObjectOrientedScene::render()

View File

@ -3,7 +3,7 @@
#include "Scene.h" #include "Scene.h"
#include "MyBatch.h" #include "MyBatch.h"
#include "MyShaderProgram.h" #include "MyBatchTestShaderProgram.h"
class MyObjectOrientedScene : public Scene class MyObjectOrientedScene : public Scene
{ {
@ -22,6 +22,6 @@ public:
void render() override; void render() override;
private: private:
MyBatch m_batch; MyBatch m_batch;
MyShaderProgram::RenderableType m_shape; MyBatchTestShaderProgram::RenderableType m_shape;
MyShaderProgram m_shader_program; MyBatchTestShaderProgram m_shader_program;
}; };

View File

@ -157,6 +157,7 @@
<ClCompile Include="main.cpp" /> <ClCompile Include="main.cpp" />
<ClCompile Include="MyApplication.cpp" /> <ClCompile Include="MyApplication.cpp" />
<ClCompile Include="MyBatch.cpp" /> <ClCompile Include="MyBatch.cpp" />
<ClCompile Include="MyBatchTestShaderProgram.cpp" />
<ClCompile Include="MyObjectOrientedScene.cpp" /> <ClCompile Include="MyObjectOrientedScene.cpp" />
<ClCompile Include="MyShaderProgram.cpp" /> <ClCompile Include="MyShaderProgram.cpp" />
<ClCompile Include="MySimpleScene.cpp" /> <ClCompile Include="MySimpleScene.cpp" />
@ -181,6 +182,7 @@
<ClInclude Include="MeshFactory.h" /> <ClInclude Include="MeshFactory.h" />
<ClInclude Include="MyApplication.h" /> <ClInclude Include="MyApplication.h" />
<ClInclude Include="MyBatch.h" /> <ClInclude Include="MyBatch.h" />
<ClInclude Include="MyBatchTestShaderProgram.h" />
<ClInclude Include="MyObjectOrientedScene.h" /> <ClInclude Include="MyObjectOrientedScene.h" />
<ClInclude Include="MyShaderProgram.h" /> <ClInclude Include="MyShaderProgram.h" />
<ClInclude Include="MySimpleScene.h" /> <ClInclude Include="MySimpleScene.h" />
@ -195,6 +197,8 @@
<ClInclude Include="vec4.h" /> <ClInclude Include="vec4.h" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<None Include="MyBatchTestFragmentShader.glsl" />
<None Include="MyBatchTestVertexShader.glsl" />
<None Include="MyFragmentShader.glsl" /> <None Include="MyFragmentShader.glsl" />
<None Include="MyVertexShader.glsl" /> <None Include="MyVertexShader.glsl" />
</ItemGroup> </ItemGroup>

View File

@ -78,6 +78,9 @@
<ClCompile Include="MySimpleScene.cpp"> <ClCompile Include="MySimpleScene.cpp">
<Filter>Source Files\Example\Scenes</Filter> <Filter>Source Files\Example\Scenes</Filter>
</ClCompile> </ClCompile>
<ClCompile Include="MyBatchTestShaderProgram.cpp">
<Filter>Source Files</Filter>
</ClCompile>
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<ClInclude Include="InputManager.h"> <ClInclude Include="InputManager.h">
@ -152,6 +155,9 @@
<ClInclude Include="DrawMode.h"> <ClInclude Include="DrawMode.h">
<Filter>Header Files</Filter> <Filter>Header Files</Filter>
</ClInclude> </ClInclude>
<ClInclude Include="MyBatchTestShaderProgram.h">
<Filter>Header Files</Filter>
</ClInclude>
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<None Include="MyVertexShader.glsl"> <None Include="MyVertexShader.glsl">
@ -160,5 +166,11 @@
<None Include="MyFragmentShader.glsl"> <None Include="MyFragmentShader.glsl">
<Filter>Source Files\Example\Shader Code</Filter> <Filter>Source Files\Example\Shader Code</Filter>
</None> </None>
<None Include="MyBatchTestFragmentShader.glsl">
<Filter>Source Files\Example\Shader Code</Filter>
</None>
<None Include="MyBatchTestVertexShader.glsl">
<Filter>Source Files\Example\Shader Code</Filter>
</None>
</ItemGroup> </ItemGroup>
</Project> </Project>