Quick fixed Poseable vtable issue with glVertexAttribPointer
Poseable is not a struct because it has a vtable. This means that it cannot be used easily with glVertexAttribPointer. This quick fix should be overwritten by a full fix that stores the matrix data in a seperate vector and modifies the matrices with poseable interfaces. (Will go into more detail in that commit.)
This commit is contained in:
parent
f57c972be0
commit
2bdc165572
@ -19,14 +19,23 @@ void MyBatch::setup_vao()
|
|||||||
glVertexAttribPointer(1, 4, GL_FLOAT, GL_FALSE, 0, NULL);
|
glVertexAttribPointer(1, 4, GL_FLOAT, GL_FALSE, 0, NULL);
|
||||||
glBindBuffer(GL_ARRAY_BUFFER, m_element_buffers[POSEABLE_VBO_INDEX]);
|
glBindBuffer(GL_ARRAY_BUFFER, m_element_buffers[POSEABLE_VBO_INDEX]);
|
||||||
glEnableVertexAttribArray(2);
|
glEnableVertexAttribArray(2);
|
||||||
glVertexAttribPointer(2, 4, GL_FLOAT, GL_FALSE, 0, NULL);
|
glEnableVertexAttribArray(3);
|
||||||
glVertexAttribPointer(3, 4, GL_FLOAT, GL_FALSE, 0, NULL);
|
glEnableVertexAttribArray(4);
|
||||||
glVertexAttribPointer(4, 4, GL_FLOAT, GL_FALSE, 0, NULL);
|
glEnableVertexAttribArray(5);
|
||||||
glVertexAttribPointer(5, 4, GL_FLOAT, GL_FALSE, 0, NULL);
|
|
||||||
|
int orientation_location = offsetof(Poseable, m_orientation_matrix);
|
||||||
|
|
||||||
|
glVertexAttribPointer(2, 4, GL_FLOAT, GL_FALSE, sizeof(Poseable), (void*)(orientation_location + 0 * sizeof(vec4)));
|
||||||
|
glVertexAttribPointer(3, 4, GL_FLOAT, GL_FALSE, sizeof(Poseable), (void*)(orientation_location + 1 * sizeof(vec4)));
|
||||||
|
glVertexAttribPointer(4, 4, GL_FLOAT, GL_FALSE, sizeof(Poseable), (void*)(orientation_location + 2 * sizeof(vec4)));
|
||||||
|
glVertexAttribPointer(5, 4, GL_FLOAT, GL_FALSE, sizeof(Poseable), (void*)(orientation_location + 3 * sizeof(vec4)));
|
||||||
|
|
||||||
glVertexAttribDivisor(0, 0); // Only need to send the mesh data once (This should probably be done every time)
|
glVertexAttribDivisor(0, 0); // Only need to send the mesh data once (This should probably be done every time)
|
||||||
glVertexAttribDivisor(1, 1); // Send the color data for each instance drawn
|
glVertexAttribDivisor(1, 1); // Send the color data for each instance drawn
|
||||||
glVertexAttribDivisor(2, 1); // Send the offset data for each instance drawn
|
glVertexAttribDivisor(2, 1); // Send the offset data for each instance drawn
|
||||||
|
glVertexAttribDivisor(3, 1); // Send the offset data for each instance drawn
|
||||||
|
glVertexAttribDivisor(4, 1); // Send the offset data for each instance drawn
|
||||||
|
glVertexAttribDivisor(5, 1); // Send the offset data for each instance drawn
|
||||||
}
|
}
|
||||||
|
|
||||||
void MyBatch::update_element_buffers()
|
void MyBatch::update_element_buffers()
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#version 400
|
#version 430
|
||||||
in vec4 fragment_color;
|
in vec4 fragment_color;
|
||||||
|
|
||||||
out vec4 frag_color;
|
out vec4 frag_color;
|
||||||
|
@ -10,5 +10,5 @@ out vec4 fragment_color;
|
|||||||
void main()
|
void main()
|
||||||
{
|
{
|
||||||
fragment_color = vertex_color;
|
fragment_color = vertex_color;
|
||||||
gl_Position = pv * vec4(vertex_position, 1.0);
|
gl_Position = pv * m * vec4(vertex_position, 1.0);
|
||||||
}
|
}
|
@ -11,18 +11,21 @@
|
|||||||
#include "MeshFactory.h"
|
#include "MeshFactory.h"
|
||||||
|
|
||||||
#define FIRST_VERT -50.0f, 50.0f, 0.0f
|
#define FIRST_VERT -50.0f, 50.0f, 0.0f
|
||||||
|
#define SECOND_VERT 50.0f, 150.0f, 0.0f
|
||||||
|
#define THIRD_VERT -100.0f, -50.0f, 0.0f
|
||||||
|
#define FOURTH_VERT 100.0f, -50.0f, 0.0f
|
||||||
|
|
||||||
MyObjectOrientedScene::MyObjectOrientedScene(Application& application)
|
MyObjectOrientedScene::MyObjectOrientedScene(Application& application)
|
||||||
: Scene(application),
|
: Scene(application),
|
||||||
m_shape(MeshFactory<MyBatchTestShaderProgram::Vertex, MyBatchTestShaderProgram::Index>::gen(
|
m_shape(MeshFactory<MyBatchTestShaderProgram::Vertex, MyBatchTestShaderProgram::Index>::gen(
|
||||||
DrawMode::DRAW_TRIANGLES,
|
DrawMode::DRAW_TRIANGLES,
|
||||||
MyBatchTestShaderProgram::Vertex(FIRST_VERT),
|
MyBatchTestShaderProgram::Vertex(FIRST_VERT),
|
||||||
MyBatchTestShaderProgram::Vertex(50.0f, 150.0f, 0.0f),
|
MyBatchTestShaderProgram::Vertex(SECOND_VERT),
|
||||||
MyBatchTestShaderProgram::Vertex(-100.0f, -50.0f, 0.0f),
|
MyBatchTestShaderProgram::Vertex(THIRD_VERT),
|
||||||
MyBatchTestShaderProgram::Vertex(100.0f, -50.0f, 0.0f)
|
MyBatchTestShaderProgram::Vertex(FOURTH_VERT)
|
||||||
), DrawMode::DRAW_TRIANGLES),
|
), DrawMode::DRAW_TRIANGLES),
|
||||||
m_batch(&m_shape, 2),
|
m_batch(&m_shape, 2),
|
||||||
m_camera(vec3(m_screen_size, 4.0f))// TODO: change this back to just m_screen_size
|
m_camera(vec3(m_screen_size, 2.0f))// TODO: change this back to just m_screen_size
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -70,7 +73,7 @@ void MyObjectOrientedScene::update(float delta_time, clock_t clock)
|
|||||||
color.a = 1.0f;
|
color.a = 1.0f;
|
||||||
|
|
||||||
Poseable& pose = m_batch.get_pose(0);
|
Poseable& pose = m_batch.get_pose(0);
|
||||||
pose.update_position(vec3(3 * (float)cos(radians), 0.0f, 0.0f));
|
pose.update_position(vec3(cos(radians) * 50, 2.0f, 0.0f));
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
@ -81,7 +84,7 @@ void MyObjectOrientedScene::update(float delta_time, clock_t clock)
|
|||||||
color.a = 1.0f;
|
color.a = 1.0f;
|
||||||
|
|
||||||
Poseable& pose = m_batch.get_pose(1);
|
Poseable& pose = m_batch.get_pose(1);
|
||||||
pose.update_position(vec3(0.0f, 3 * (float)sin(radians), 0.0f));
|
pose.update_position(vec3(-3.0f, -2.0f, 0.0f));
|
||||||
}
|
}
|
||||||
|
|
||||||
vec2 camera_translation(0.0f, 0.0f);
|
vec2 camera_translation(0.0f, 0.0f);
|
||||||
@ -93,19 +96,29 @@ void MyObjectOrientedScene::update(float delta_time, clock_t clock)
|
|||||||
|
|
||||||
m_camera.translate(camera_translation * delta_time * 100.0f);
|
m_camera.translate(camera_translation * delta_time * 100.0f);
|
||||||
|
|
||||||
|
const mat4& projection = m_camera.get_projection_matrix();
|
||||||
|
const mat4& camera_orientation = m_camera.get_orientation_matrix();
|
||||||
const mat4& world_to_view = m_camera.get_world_to_view_matrix();
|
const mat4& world_to_view = m_camera.get_world_to_view_matrix();
|
||||||
const mat4& orientation = m_batch.get_pose(0).get_orientation_matrix();
|
const mat4& orientation = m_batch.get_pose(0).get_orientation_matrix();
|
||||||
|
|
||||||
|
const mat4 mvp = world_to_view * orientation;
|
||||||
|
|
||||||
vec4 first_vert(FIRST_VERT, 1.0f);
|
vec4 first_vert(FIRST_VERT, 1.0f);
|
||||||
|
vec4 second_vert(SECOND_VERT, 1.0f);
|
||||||
|
vec4 third_vert(THIRD_VERT, 1.0f);
|
||||||
|
vec4 fourth_vert(FOURTH_VERT, 1.0f);
|
||||||
|
|
||||||
Util::set_console_position(0, 0);
|
Util::set_console_position(0, 0);
|
||||||
|
std::cout << "Projection" << std::endl;
|
||||||
|
Util::print_matrix(projection);
|
||||||
std::cout << "World to View" << std::endl;
|
std::cout << "World to View" << std::endl;
|
||||||
Util::print_matrix(m_camera.get_world_to_view_matrix());
|
Util::print_matrix(world_to_view);
|
||||||
std::cout << "Pose 0 Orientation" << std::endl;
|
std::cout << "Pose 0 Orientation" << std::endl;
|
||||||
Util::print_matrix(m_batch.get_pose(0).get_orientation_matrix());
|
Util::print_matrix(orientation);
|
||||||
std::cout << "First Vert" << std::endl;
|
std::cout << "Full Projection Matrix" << std::endl;
|
||||||
Util::print_vec(first_vert);
|
Util::print_matrix(world_to_view * orientation);
|
||||||
std::cout << "Projected Position" << std::endl;
|
std::cout << " First Second Third Fourth " << std::endl;
|
||||||
Util::print_vec(world_to_view * orientation * first_vert);
|
Util::print_matrix(mat4(mvp * first_vert, mvp * second_vert, mvp * third_vert, mvp * fourth_vert));
|
||||||
|
|
||||||
// TODO: Make a prerender function or move this to render
|
// TODO: Make a prerender function or move this to render
|
||||||
m_batch.prerender();
|
m_batch.prerender();
|
||||||
@ -120,3 +133,6 @@ void MyObjectOrientedScene::render()
|
|||||||
}
|
}
|
||||||
|
|
||||||
#undef FIRST_VERT
|
#undef FIRST_VERT
|
||||||
|
#undef SECOND_VERT
|
||||||
|
#undef THIRD_VERT
|
||||||
|
#undef FOURTH_VERT
|
@ -24,6 +24,6 @@ public:
|
|||||||
|
|
||||||
const mat4& get_orientation_matrix() const { return m_orientation_matrix; }
|
const mat4& get_orientation_matrix() const { return m_orientation_matrix; }
|
||||||
|
|
||||||
protected:
|
// Please dont use this. If you see it, tell michael that he is bad
|
||||||
mat4 m_orientation_matrix;
|
mat4 m_orientation_matrix;
|
||||||
};
|
};
|
Loading…
Reference in New Issue
Block a user