Added framebuffer to render screen to
This commit is contained in:
		
							parent
							
								
									78370a2ffd
								
							
						
					
					
						commit
						de3a51f47f
					
				
							
								
								
									
										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(); | ||||
|  | ||||
							
								
								
									
										16
									
								
								roadmap.md
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								roadmap.md
									
									
									
									
									
								
							| @ -36,3 +36,19 @@ For now, what we've got is good | ||||
| ### Better error messages | ||||
| Okay, now I want a message other than "main.lua not found!" if the lua file fucks up. | ||||
| Also, I want Lua errors to kill the program with an error message and a stack trace. | ||||
| 
 | ||||
| ### Added model importing | ||||
| I did this without writing about it in the roadmap. I still want to add a way to get multiple meshes on the same model, but  | ||||
| I'll save skeletal animation until we have a working physics system | ||||
| 
 | ||||
| ### Refactoring pass | ||||
| I want to clean things up and see if some of the code can be combined into multiple files. | ||||
| Also, I want a better user experience, so I might wind up removeing the %includes from the  | ||||
| swig files and customizing the interface by hand. I also want to add a whole mess of constants | ||||
| so that I don't have to test for keypresses. Lastly, I want to test if a function exists before | ||||
| calling it from the lua file, so stubs aren't necessary to prevent a crash | ||||
| 
 | ||||
| - [ ] Combine files | ||||
| - [ ] Better interface | ||||
| - [ ] Constants for keys and the like | ||||
| - [ ] No crash on calling non-existant scripting hooks | ||||
|  | ||||
| @ -10,7 +10,9 @@ endmacro() | ||||
| 
 | ||||
| add_shader(flat.vert) | ||||
| add_shader(flat.frag) | ||||
| add_shader(screen.vert) | ||||
| add_shader(screen.frag) | ||||
| 
 | ||||
| add_custom_target(shader_headers | ||||
|   DEPENDS flat.vert.h flat.frag.h | ||||
|   DEPENDS flat.vert.h flat.frag.h screen.vert.h screen.frag.h | ||||
|   COMMENT "Generated shaders headers.") | ||||
|  | ||||
							
								
								
									
										18
									
								
								shaders/screen.frag
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								shaders/screen.frag
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,18 @@ | ||||
| #version 330 core | ||||
| 
 | ||||
| in vec2 UV; | ||||
| 
 | ||||
| out vec4 FragColor; | ||||
| 
 | ||||
| struct Material { | ||||
|   vec3 color; | ||||
|   bool usesColor; | ||||
|   sampler2D tex; | ||||
|   bool usesTex; | ||||
| }; | ||||
| 
 | ||||
| uniform Material material; | ||||
| 
 | ||||
| void main() { | ||||
|   FragColor = texture(material.tex, UV); | ||||
| } | ||||
							
								
								
									
										11
									
								
								shaders/screen.vert
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								shaders/screen.vert
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | ||||
| #version 330 core | ||||
| 
 | ||||
| layout (location = 0) in vec3 pos; | ||||
| layout (location = 1) in vec2 uv; | ||||
| 
 | ||||
| out vec2 UV; | ||||
| 
 | ||||
| void main() { | ||||
|   gl_Position = vec4(pos, 1.0); | ||||
|   UV = uv; | ||||
| } | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Dane Johnson
						Dane Johnson