Added framebuffer to render screen to
This commit is contained in:
80
core/Screen.cpp
Normal file
80
core/Screen.cpp
Normal file
@@ -0,0 +1,80 @@
|
||||
#include "Screen.h"
|
||||
|
||||
const Vertex vertices[] = {
|
||||
Vertex(-1.0f, -1.0f, 0.0f, 0.0f, 0.0f),
|
||||
Vertex(-1.0f, 1.0f, 0.0f, 0.0f, 1.0f),
|
||||
Vertex(1.0f, -1.0f, 0.0f, 1.0f, 0.0f),
|
||||
|
||||
Vertex(-1.0f, 1.0f, 0.0f, 0.0f, 1.0f),
|
||||
Vertex(1.0f, -1.0f, 0.0f, 1.0f, 0.0f),
|
||||
Vertex(1.0f, 1.0f, 0.0f, 1.0f, 1.0f)
|
||||
};
|
||||
|
||||
Screen::Screen() {
|
||||
// Setup quad
|
||||
glGenVertexArrays(1, &quad);
|
||||
glBindVertexArray(quad);
|
||||
|
||||
Id vbo;
|
||||
glGenBuffers(1, &vbo);
|
||||
glBindBuffer(GL_ARRAY_BUFFER, vbo);
|
||||
glBufferData(GL_ARRAY_BUFFER, sizeof(vertices), vertices, GL_STATIC_DRAW);
|
||||
|
||||
// Vertex positions
|
||||
glEnableVertexAttribArray(0);
|
||||
glVertexAttribPointer(0, 3, GL_FLOAT, GL_FALSE, sizeof(Vertex), (void*) 0);
|
||||
//Vertex UV
|
||||
glEnableVertexAttribArray(1);
|
||||
glVertexAttribPointer(1, 2, GL_FLOAT, GL_FALSE, sizeof(Vertex), (void*) (3 * sizeof(float)));
|
||||
|
||||
glBindVertexArray(0);
|
||||
|
||||
// Setup frame buffers
|
||||
glGenFramebuffers(1, &framebuffer);
|
||||
glBindFramebuffer(GL_FRAMEBUFFER, framebuffer);
|
||||
|
||||
tex.width = width;
|
||||
tex.height = height;
|
||||
glGenTextures(1, &tex.id);
|
||||
glBindTexture(GL_TEXTURE_2D, tex.id);
|
||||
glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, width, height, 0, GL_RGB, GL_UNSIGNED_BYTE, NULL);
|
||||
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
|
||||
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
|
||||
glBindTexture(GL_TEXTURE_2D, 0);
|
||||
|
||||
glFramebufferTexture2D(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, GL_TEXTURE_2D, tex.id, 0);
|
||||
|
||||
// Setup render buffer
|
||||
glGenRenderbuffers(1, &renderbuffer);
|
||||
glBindRenderbuffer(GL_RENDERBUFFER, renderbuffer);
|
||||
glRenderbufferStorage(GL_RENDERBUFFER, GL_DEPTH24_STENCIL8, width, height);
|
||||
glBindRenderbuffer(GL_RENDERBUFFER, 0);
|
||||
|
||||
glFramebufferRenderbuffer(GL_FRAMEBUFFER, GL_DEPTH_STENCIL_ATTACHMENT, GL_RENDERBUFFER, renderbuffer);
|
||||
|
||||
if(glCheckFramebufferStatus(GL_FRAMEBUFFER) != GL_FRAMEBUFFER_COMPLETE) {
|
||||
std::cerr << "Error setting up screen framebuffer." << std::endl;
|
||||
exit(1);
|
||||
}
|
||||
glBindFramebuffer(GL_FRAMEBUFFER, 0);
|
||||
}
|
||||
|
||||
void Screen::Enable() {
|
||||
glBindFramebuffer(GL_FRAMEBUFFER, framebuffer);
|
||||
glClearColor(0.5f, 0.5f, 0.5f, 1.0f);
|
||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
||||
glEnable(GL_DEPTH_TEST);
|
||||
}
|
||||
|
||||
void Screen::Disable() {
|
||||
glBindFramebuffer(GL_FRAMEBUFFER, 0);
|
||||
glClearColor(1.0f, 1.0f, 1.0f, 1.0f);
|
||||
glClear(GL_COLOR_BUFFER_BIT);
|
||||
glDisable(GL_DEPTH_TEST);
|
||||
}
|
||||
|
||||
void Screen::Draw() {
|
||||
glBindVertexArray(quad);
|
||||
glDrawArrays(GL_TRIANGLES, 0, 6);
|
||||
glBindVertexArray(0);
|
||||
}
|
||||
28
core/Screen.h
Normal file
28
core/Screen.h
Normal file
@@ -0,0 +1,28 @@
|
||||
#ifndef SCREEN_H
|
||||
#define SCREEN_H
|
||||
|
||||
#include <iostream>
|
||||
#include <stdlib.h>
|
||||
|
||||
#include <GL/glew.h>
|
||||
|
||||
#include "types.h"
|
||||
#include "Vertex.h"
|
||||
#include "Material.h"
|
||||
|
||||
class Screen {
|
||||
public:
|
||||
Screen();
|
||||
void Enable();
|
||||
void Disable();
|
||||
void Draw();
|
||||
const int width = 640;
|
||||
const int height = 480;
|
||||
Texture tex;
|
||||
private:
|
||||
Id quad;
|
||||
Id framebuffer;
|
||||
Id renderbuffer;
|
||||
};
|
||||
|
||||
#endif /* SCREEN_H */
|
||||
5
core/Shaders/ScreenShader.cpp
Normal file
5
core/Shaders/ScreenShader.cpp
Normal file
@@ -0,0 +1,5 @@
|
||||
#include "ScreenShader.h"
|
||||
#include "screen.vert.h"
|
||||
#include "screen.frag.h"
|
||||
|
||||
ScreenShader::ScreenShader() : Shader(screen_vert, screen_frag) {}
|
||||
6
core/Shaders/ScreenShader.h
Normal file
6
core/Shaders/ScreenShader.h
Normal file
@@ -0,0 +1,6 @@
|
||||
#include "Shader.h"
|
||||
|
||||
class ScreenShader : public Shader {
|
||||
public:
|
||||
ScreenShader();
|
||||
};
|
||||
@@ -9,6 +9,10 @@
|
||||
#include "types.h"
|
||||
|
||||
#include "Shaders/FlatShader.h"
|
||||
#include "Shaders/ScreenShader.h"
|
||||
|
||||
#include "Screen.h"
|
||||
|
||||
#include "Ball.h"
|
||||
#include "Camera.h"
|
||||
#include "Input.h"
|
||||
@@ -80,7 +84,6 @@ int main() {
|
||||
}
|
||||
|
||||
glViewport(0, 0, width, height);
|
||||
glEnable(GL_DEPTH_TEST);
|
||||
|
||||
root = Node::GetRoot();
|
||||
|
||||
@@ -88,12 +91,13 @@ int main() {
|
||||
input->Use(window);
|
||||
|
||||
Camera defaultCamera;
|
||||
|
||||
Screen screen;
|
||||
ScreenShader *screenShader = new ScreenShader();
|
||||
|
||||
FlatShader *shader = new FlatShader();
|
||||
shader->Use();
|
||||
|
||||
Matrix projection = glm::perspective(glm::radians(45.0f), 800.0f/600.0f, 0.1f, 100.0f);
|
||||
shader->UpdateProjection(projection);
|
||||
|
||||
// TODO Allow multiple scripting languages
|
||||
Lua *lua = new Lua();
|
||||
@@ -103,11 +107,13 @@ int main() {
|
||||
double delta = 0.0;
|
||||
|
||||
while(!glfwWindowShouldClose(window)) {
|
||||
glClearColor(0.5f, 0.5f, 0.5f, 1.0f);
|
||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
||||
// Start rendering to texture;
|
||||
screen.Enable();
|
||||
|
||||
lua->Update(delta);
|
||||
|
||||
shader->Use();
|
||||
shader->UpdateProjection(projection);
|
||||
Matrix view(1.0f);
|
||||
Camera *camera = Camera::GetCurrentCamera();
|
||||
view = glm::rotate(view, -camera->transform.rotation.x, Vector3(1.0f, 0.0f, 0.0f));
|
||||
@@ -118,6 +124,14 @@ int main() {
|
||||
|
||||
// Render the scene tree
|
||||
render(root, shader, Matrix(1.0f));
|
||||
|
||||
// Stop rendering to texture
|
||||
screen.Disable();
|
||||
// // Render the screen
|
||||
screenShader->Use();
|
||||
screenShader->UpdateTex(true, screen.tex);
|
||||
glViewport(0, 0, width, height);
|
||||
screen.Draw();
|
||||
|
||||
glfwSwapBuffers(window);
|
||||
glfwPollEvents();
|
||||
|
||||
Reference in New Issue
Block a user