mirror of
				https://github.com/MichaelFisher1997/opengl-cpp.git
				synced 2025-10-18 12:17:45 +00:00 
			
		
		
		
	Segment faults fixed!!
This commit is contained in:
		| @@ -6,7 +6,7 @@ IndexBuffer::IndexBuffer(const unsigned int* data, unsigned int count) | |||||||
| { | { | ||||||
|   ASSERT(sizeof(unsigned int) == sizeof(GLuint)); |   ASSERT(sizeof(unsigned int) == sizeof(GLuint)); | ||||||
|   // |   // | ||||||
|   std::cout << "m_RendererID: " << &m_RendererID << " " << m_RendererID << std::endl;  |   //std::cout << "m_RendererID: " << &m_RendererID << " " << m_RendererID << std::endl;  | ||||||
|   GLCall(glGenBuffers(1, &m_RendererID)); |   GLCall(glGenBuffers(1, &m_RendererID)); | ||||||
|   GLCall(glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, m_RendererID)); //select buffer called 'buffer' |   GLCall(glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, m_RendererID)); //select buffer called 'buffer' | ||||||
|   GLCall(glBufferData(GL_ELEMENT_ARRAY_BUFFER, count * sizeof(unsigned int), data, GL_STATIC_DRAW)); // assigne buffer size, static as we use many times, but does not change |   GLCall(glBufferData(GL_ELEMENT_ARRAY_BUFFER, count * sizeof(unsigned int), data, GL_STATIC_DRAW)); // assigne buffer size, static as we use many times, but does not change | ||||||
|   | |||||||
| @@ -4,10 +4,10 @@ | |||||||
| VertexArray::VertexArray() | VertexArray::VertexArray() | ||||||
| { | { | ||||||
|   std::cout << "VertexArray::VertexArray()" << std::endl; |   std::cout << "VertexArray::VertexArray()" << std::endl; | ||||||
|   std::cout << "m_RendererID: " << &m_RendererID << " " << m_RendererID << std::endl; |   std::cout << "m_RendererID: " << &m_RendererID  << std::endl; | ||||||
|   //GLCall(glGenVertexArrays(1, &m_RendererID)); |   GLCall(glGenVertexArrays(1, &m_RendererID)); | ||||||
|   glGenVertexArrays(1, &m_RendererID); |   //glGenVertexArrays(1, &m_RendererID); | ||||||
|   std::cout << "m_RendererID: " << &m_RendererID << " " << m_RendererID << std::endl; |   std::cout << "m_RendererID: " << &m_RendererID << std::endl; | ||||||
|   if (!m_RendererID) { |   if (!m_RendererID) { | ||||||
|     std::cerr << "Failed to generate VAO" << std::endl; |     std::cerr << "Failed to generate VAO" << std::endl; | ||||||
|   } |   } | ||||||
|   | |||||||
| @@ -40,18 +40,18 @@ private: | |||||||
| template<> | template<> | ||||||
| inline void VertexBufferLayout::Push<float>(int count) { | inline void VertexBufferLayout::Push<float>(int count) { | ||||||
|     m_Elements.push_back({ GL_FLOAT, static_cast<unsigned int>(count), GL_FALSE }); |     m_Elements.push_back({ GL_FLOAT, static_cast<unsigned int>(count), GL_FALSE }); | ||||||
|     m_Stride += VertexBufferElement::GetSizeOfType(GL_FLOAT); |     m_Stride += count * VertexBufferElement::GetSizeOfType(GL_FLOAT); | ||||||
| } | } | ||||||
|  |  | ||||||
| template<> | template<> | ||||||
| inline void VertexBufferLayout::Push<unsigned int>(int count) { | inline void VertexBufferLayout::Push<unsigned int>(int count) { | ||||||
|     m_Elements.push_back({ GL_UNSIGNED_INT,static_cast<unsigned int>(count), GL_FALSE }); |     m_Elements.push_back({ GL_UNSIGNED_INT,static_cast<unsigned int>(count), GL_FALSE }); | ||||||
|     m_Stride += VertexBufferElement::GetSizeOfType(GL_UNSIGNED_INT); |     m_Stride += count * VertexBufferElement::GetSizeOfType(GL_UNSIGNED_INT); | ||||||
| } | } | ||||||
|  |  | ||||||
| template<> | template<> | ||||||
| inline void VertexBufferLayout::Push<unsigned char>(int count) { | inline void VertexBufferLayout::Push<unsigned char>(int count) { | ||||||
|     m_Elements.push_back({ GL_UNSIGNED_BYTE, static_cast<unsigned int>(count), GL_TRUE }); |     m_Elements.push_back({ GL_UNSIGNED_BYTE, static_cast<unsigned int>(count), GL_TRUE }); | ||||||
|     m_Stride += VertexBufferElement::GetSizeOfType(GL_UNSIGNED_BYTE); |     m_Stride += count * VertexBufferElement::GetSizeOfType(GL_UNSIGNED_BYTE); | ||||||
| } | } | ||||||
| #endif // VERTEXBUFFERLAYOUT_H | #endif // VERTEXBUFFERLAYOUT_H | ||||||
							
								
								
									
										57
									
								
								src/sdl.cpp
									
									
									
									
									
								
							
							
						
						
									
										57
									
								
								src/sdl.cpp
									
									
									
									
									
								
							| @@ -62,10 +62,11 @@ SdlWindow::SdlWindow(const char* title, int width, int height) | |||||||
|       r(0.5f), |       r(0.5f), | ||||||
|       m_glContext(nullptr), |       m_glContext(nullptr), | ||||||
|       increment(0.05f), |       increment(0.05f), | ||||||
|       vao(0), |       m_shader(0), | ||||||
|       layout(nullptr), |       m_Location(-1), | ||||||
|       va(nullptr), |       m_IB(nullptr), | ||||||
|       m_ib(nullptr) |       m_VB(nullptr), | ||||||
|  |       m_VA(nullptr) | ||||||
| { | { | ||||||
|  |  | ||||||
|   std::cout << "Step 0: hellow world" << std::endl; |   std::cout << "Step 0: hellow world" << std::endl; | ||||||
| @@ -136,17 +137,14 @@ SdlWindow::SdlWindow(const char* title, int width, int height) | |||||||
|       0, 1, 2, |       0, 1, 2, | ||||||
|       2, 3, 0 |       2, 3, 0 | ||||||
|   }; |   }; | ||||||
|  |   m_VA = new VertexArray(); | ||||||
|   VertexArray va; |   m_VB = new VertexBuffer(positions, 4 * 2 * sizeof(float)); | ||||||
|   VertexBuffer vb(positions, 4 * 2 * sizeof(float)); |   m_IB = new IndexBuffer(indices, 6); | ||||||
|   m_ib = new IndexBuffer(indices, 6); |  | ||||||
|    |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   VertexBufferLayout layout; |   VertexBufferLayout layout; | ||||||
|   layout.Push<float>(2); |   layout.Push<float>(2); | ||||||
|  |  | ||||||
|   va.AddBuffer(vb, layout); |   m_VA->AddBuffer(*m_VB, layout); | ||||||
|    |    | ||||||
|   ShaderProgramSource source = parseShader("res/shaders/Basic.shader"); |   ShaderProgramSource source = parseShader("res/shaders/Basic.shader"); | ||||||
|  |  | ||||||
| @@ -154,13 +152,15 @@ SdlWindow::SdlWindow(const char* title, int width, int height) | |||||||
|   std::cout << "FRAGMENT" << std::endl << source.FragmentSource << std::endl; |   std::cout << "FRAGMENT" << std::endl << source.FragmentSource << std::endl; | ||||||
|  |  | ||||||
|   unsigned int shader = createShader(source.VertexSource, source.FragmentSource); |   unsigned int shader = createShader(source.VertexSource, source.FragmentSource); | ||||||
|   std::cout << "shader: " << shader << std::endl; |   m_shader = shader; | ||||||
|   GLCall(glUseProgram(shader)); |   std::cout << "shader: " << m_shader << std::endl; | ||||||
|  |   std::cout << "shader: " << m_shader << std::endl; | ||||||
|  |   GLCall(glUseProgram(m_shader)); | ||||||
|    |    | ||||||
|   GLCall(unsigned int location = glGetUniformLocation(shader, "u_Color")); |   GLCall(m_Location = glGetUniformLocation(m_shader, "u_Color")); | ||||||
|   ASSERT(location != -1); // -1 is an error |   ASSERT(m_Location != -1); // -1 is an error | ||||||
|  |  | ||||||
|   GLCall(glUniform4f(location, 0.8f, 0.3f, 0.8f, 1.0f)); |   GLCall(glUniform4f(m_Location, 0.8f, 0.3f, 0.8f, 1.0f)); | ||||||
|  |  | ||||||
|   GLCall(glBindVertexArray(0)); |   GLCall(glBindVertexArray(0)); | ||||||
|   GLCall(glUseProgram(0)); |   GLCall(glUseProgram(0)); | ||||||
| @@ -186,13 +186,9 @@ SdlWindow::~SdlWindow() { | |||||||
|       SDL_DestroyWindow(m_window); |       SDL_DestroyWindow(m_window); | ||||||
|       m_window = nullptr; |       m_window = nullptr; | ||||||
|   } |   } | ||||||
|   if (shader) { |   if (m_shader) { | ||||||
|         glDeleteProgram(shader); |         glDeleteProgram(m_shader); | ||||||
|         shader = 0; |         m_shader = 0; | ||||||
|     } |  | ||||||
|   if (m_ib) { |  | ||||||
|         delete m_ib; |  | ||||||
|         m_ib = nullptr; |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   SDL_Quit(); |   SDL_Quit(); | ||||||
| @@ -205,7 +201,7 @@ void SdlWindow::run() { | |||||||
|     update(); |     update(); | ||||||
|     render(); |     render(); | ||||||
|   } |   } | ||||||
|   GLCall(glDeleteProgram(shader)); |   GLCall(glDeleteProgram(m_shader)); | ||||||
| } | } | ||||||
| // | // | ||||||
| void SdlWindow::processEvents() { | void SdlWindow::processEvents() { | ||||||
| @@ -270,13 +266,14 @@ void SdlWindow::render() { | |||||||
|   // |   // | ||||||
|   GLCall(glClear(GL_COLOR_BUFFER_BIT)); |   GLCall(glClear(GL_COLOR_BUFFER_BIT)); | ||||||
|    |    | ||||||
|   GLCall(glUseProgram(shader)); |   GLCall(glUseProgram(m_shader)); | ||||||
|   std::cout << "shader: " << shader << std::endl; |   std::cout << "m_shader: " << m_shader << std::endl; | ||||||
|   std::cout << "location: " << location << std::endl; |   std::cout << "location: " << m_Location << std::endl; | ||||||
|   GLCall(glUniform4f(location, r, 0.3f, 0.8f, 1.0f)); |   std::cout << "R: " << r << std::endl; | ||||||
|  |   GLCall(glUniform4f(m_Location, r, 0.3f, 0.8f, 1.0f)); | ||||||
|  |  | ||||||
|   va->Bind(); |   m_VA->Bind(); | ||||||
|   m_ib->Bind(); |   m_IB->Bind(); | ||||||
|   // TODO: Draw with OpenGL here (shaders, triangles, etc.) |   // TODO: Draw with OpenGL here (shaders, triangles, etc.) | ||||||
|   //glDrawElements(GL_TRIANGLES, 6, GL_UNSIGNED_INT, nullptr); |   //glDrawElements(GL_TRIANGLES, 6, GL_UNSIGNED_INT, nullptr); | ||||||
|   GLCall(glDrawElements(GL_TRIANGLES, 6, GL_UNSIGNED_INT, nullptr)); //macro assert for debugging |   GLCall(glDrawElements(GL_TRIANGLES, 6, GL_UNSIGNED_INT, nullptr)); //macro assert for debugging | ||||||
|   | |||||||
							
								
								
									
										15
									
								
								src/sdl.hpp
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								src/sdl.hpp
									
									
									
									
									
								
							| @@ -57,16 +57,11 @@ private: | |||||||
|   SDL_GLContext m_glContext; |   SDL_GLContext m_glContext; | ||||||
|   float         increment;  |   float         increment;  | ||||||
| //  // temp shader stuff | //  // temp shader stuff | ||||||
|   std::string vetexShader; |   unsigned int  m_shader; | ||||||
|   std::string fragmentShader; |   GLint   m_Location; | ||||||
|   unsigned int buffer; |   VertexArray* m_VA; | ||||||
|   unsigned int ibo; |   IndexBuffer* m_IB; | ||||||
|   unsigned int vao; |   VertexBuffer* m_VB; | ||||||
|   unsigned int  shader; |  | ||||||
|   unsigned int   location; |  | ||||||
|   VertexBufferLayout* layout; |  | ||||||
|   VertexArray* va; |  | ||||||
|   IndexBuffer* m_ib; |  | ||||||
|  |  | ||||||
|   // Private methods |   // Private methods | ||||||
|   void processEvents(); |   void processEvents(); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 MichaelFisher1997
					MichaelFisher1997