XFBSource::Draw in vbo
Signed-off-by: Ryan Houdek <Sonicadvance1@gmail.com>
This commit is contained in:
parent
d44228f1b7
commit
8ea2ddbc50
|
@ -28,6 +28,8 @@ namespace OGL
|
||||||
|
|
||||||
extern bool s_bHaveFramebufferBlit; // comes from Render.cpp. ugly.
|
extern bool s_bHaveFramebufferBlit; // comes from Render.cpp. ugly.
|
||||||
|
|
||||||
|
static GLuint s_VBO = 0;
|
||||||
|
|
||||||
int FramebufferManager::m_targetWidth;
|
int FramebufferManager::m_targetWidth;
|
||||||
int FramebufferManager::m_targetHeight;
|
int FramebufferManager::m_targetHeight;
|
||||||
int FramebufferManager::m_msaaSamples;
|
int FramebufferManager::m_msaaSamples;
|
||||||
|
@ -171,6 +173,8 @@ FramebufferManager::FramebufferManager(int targetWidth, int targetHeight, int ms
|
||||||
|
|
||||||
glGenFramebuffersEXT(1, &m_xfbFramebuffer);
|
glGenFramebuffersEXT(1, &m_xfbFramebuffer);
|
||||||
|
|
||||||
|
glGenBuffers(1, &s_VBO);
|
||||||
|
|
||||||
// EFB framebuffer is currently bound, make sure to clear its alpha value to 1.f
|
// EFB framebuffer is currently bound, make sure to clear its alpha value to 1.f
|
||||||
glViewport(0, 0, m_targetWidth, m_targetHeight);
|
glViewport(0, 0, m_targetWidth, m_targetHeight);
|
||||||
glScissor(0, 0, m_targetWidth, m_targetHeight);
|
glScissor(0, 0, m_targetWidth, m_targetHeight);
|
||||||
|
@ -182,6 +186,7 @@ FramebufferManager::FramebufferManager(int targetWidth, int targetHeight, int ms
|
||||||
FramebufferManager::~FramebufferManager()
|
FramebufferManager::~FramebufferManager()
|
||||||
{
|
{
|
||||||
glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, 0);
|
glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, 0);
|
||||||
|
glDeleteBuffers(1, &s_VBO);
|
||||||
|
|
||||||
GLuint glObj[3];
|
GLuint glObj[3];
|
||||||
|
|
||||||
|
@ -306,25 +311,24 @@ void XFBSource::Draw(const MathUtil::Rectangle<float> &sourcerc,
|
||||||
|
|
||||||
glBindTexture(GL_TEXTURE_RECTANGLE_ARB, texture);
|
glBindTexture(GL_TEXTURE_RECTANGLE_ARB, texture);
|
||||||
|
|
||||||
GLfloat vtx1[] = {
|
GLfloat vertices[] = {
|
||||||
drawrc.left, drawrc.bottom,
|
drawrc.left, drawrc.bottom,
|
||||||
drawrc.left, drawrc.top,
|
|
||||||
drawrc.right, drawrc.top,
|
|
||||||
drawrc.right, drawrc.bottom,
|
|
||||||
};
|
|
||||||
GLfloat tex1[] = { // For TEXTURE0
|
|
||||||
sourcerc.left, sourcerc.bottom,
|
sourcerc.left, sourcerc.bottom,
|
||||||
sourcerc.left, sourcerc.top,
|
|
||||||
sourcerc.right, sourcerc.top,
|
|
||||||
sourcerc.right, sourcerc.bottom
|
|
||||||
};
|
|
||||||
GLfloat tex2[] = { // For TEXTURE1
|
|
||||||
0.0f, 0.0f,
|
0.0f, 0.0f,
|
||||||
|
drawrc.left, drawrc.top,
|
||||||
|
sourcerc.left, sourcerc.top,
|
||||||
0.0f, 1.0f,
|
0.0f, 1.0f,
|
||||||
|
drawrc.right, drawrc.top,
|
||||||
|
sourcerc.right, sourcerc.top,
|
||||||
1.0f, 1.0f,
|
1.0f, 1.0f,
|
||||||
|
drawrc.right, drawrc.bottom,
|
||||||
|
sourcerc.right, sourcerc.bottom,
|
||||||
1.0f, 0.0f
|
1.0f, 0.0f
|
||||||
};
|
};
|
||||||
|
|
||||||
|
glBindBuffer(GL_ARRAY_BUFFER, s_VBO);
|
||||||
|
glBufferData(GL_ARRAY_BUFFER, 2*4*3*sizeof(GLfloat), vertices, GL_STREAM_DRAW);
|
||||||
|
|
||||||
// disable all pointer, TODO: use VAO
|
// disable all pointer, TODO: use VAO
|
||||||
glEnableClientState(GL_VERTEX_ARRAY);
|
glEnableClientState(GL_VERTEX_ARRAY);
|
||||||
glDisableVertexAttribArray(SHADER_POSMTX_ATTRIB);
|
glDisableVertexAttribArray(SHADER_POSMTX_ATTRIB);
|
||||||
|
@ -342,13 +346,15 @@ void XFBSource::Draw(const MathUtil::Rectangle<float> &sourcerc,
|
||||||
glDisableClientState(GL_TEXTURE_COORD_ARRAY);
|
glDisableClientState(GL_TEXTURE_COORD_ARRAY);
|
||||||
}
|
}
|
||||||
|
|
||||||
glVertexPointer(2, GL_FLOAT, 0, vtx1);
|
glVertexPointer(2, GL_FLOAT, 6*sizeof(GLfloat), NULL);
|
||||||
glClientActiveTexture(GL_TEXTURE0);
|
glClientActiveTexture(GL_TEXTURE0);
|
||||||
glTexCoordPointer(2, GL_FLOAT, 0, tex1);
|
glTexCoordPointer(2, GL_FLOAT, 6*sizeof(GLfloat), (GLfloat*)NULL+2);
|
||||||
glClientActiveTexture(GL_TEXTURE1);
|
glClientActiveTexture(GL_TEXTURE1);
|
||||||
glTexCoordPointer(2, GL_FLOAT, 0, tex2);
|
glTexCoordPointer(2, GL_FLOAT, 6*sizeof(GLfloat), (GLfloat*)NULL+4);
|
||||||
glDrawArrays(GL_TRIANGLE_FAN, 0, 4);
|
glDrawArrays(GL_TRIANGLE_FAN, 0, 4);
|
||||||
|
|
||||||
|
// TODO: this need to be removed in future
|
||||||
|
glBindBuffer(GL_ARRAY_BUFFER, 0);
|
||||||
|
|
||||||
GL_REPORT_ERRORD();
|
GL_REPORT_ERRORD();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue