Added framebuffer to render screen to

This commit is contained in:
Dane Johnson
2021-01-19 16:01:37 -06:00
parent 22016f9d98
commit 2d4e162cd6
10 changed files with 186 additions and 7 deletions

80
core/Screen.cpp Normal file
View 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
View 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 */

View File

@@ -0,0 +1,5 @@
#include "ScreenShader.h"
#include "screen.vert.h"
#include "screen.frag.h"
ScreenShader::ScreenShader() : Shader(screen_vert, screen_frag) {}

View File

@@ -0,0 +1,6 @@
#include "Shader.h"
class ScreenShader : public Shader {
public:
ScreenShader();
};

View File

@@ -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();