Fix shader errs

This commit is contained in:
2026-01-14 14:00:09 +01:00
parent 85df7154a7
commit 81096a9b5f
5 changed files with 84 additions and 86 deletions

4
.gitignore vendored
View File

@@ -1,3 +1,3 @@
!build/shader.v
!build/shader.f
!build/vertex.glsl
!build/fragment.glsl
build/

9
build/fragment.glsl Normal file
View File

@@ -0,0 +1,9 @@
#version 460 core
out vec4 fragcolor;
void main(){
fragcolor = vec4(1.0, 0.5, 0.2, 1.0);
}

View File

@@ -1,6 +0,0 @@
#version 460 core
out vec4 FragColor;
void main(){
FragColor = vec4(1.0f, 0.5f, 0.2f, 1.0f);
}

View File

@@ -1,7 +1,7 @@
#version 460 core
layout (location = 0) in vec3 aPos;
void main(){
gl_Position = vec4(aPos.x, aPos.y, aPos.z, 1.0);
}
gl_Position = vec4(aPos, 1.0);
};

View File

@@ -5,7 +5,8 @@
#include <glad/glad.h>
#include <stdio.h>
void keyfunc (RGFW_window* win, RGFW_key key, u8 keychar, RGFW_keymod keymod, RGFW_bool repeat, RGFW_bool pressed){
void keyfunc(RGFW_window *win, RGFW_key key, u8 keychar, RGFW_keymod keymod,
RGFW_bool repeat, RGFW_bool pressed) {
RGFW_UNUSED(repeat);
if (key == RGFW_escape && pressed) {
RGFW_window_setShouldClose(win, 1);
@@ -16,7 +17,9 @@ RGFW_window* SetupWindow(){
hints->major = 4;
hints->minor = 6;
RGFW_setGlobalHints_OpenGL(hints);
RGFW_window* win = RGFW_createWindow("PACMAN CLONE", 0,0, 800, 600, RGFW_windowCenter | RGFW_windowNoResize | RGFW_windowOpenGL | RGFW_windowHide);
RGFW_window *win = RGFW_createWindow("PACMAN CLONE", 0, 0, 800, 600,
RGFW_windowCenter | RGFW_windowNoResize |
RGFW_windowOpenGL | RGFW_windowHide);
RGFW_window_createContext_OpenGL(win, hints);
RGFW_window_show(win);
@@ -37,8 +40,7 @@ long stat_GetSize(FILE* file ) {
fseek(file, 0, SEEK_SET); // Reset to the beginning
return size;
}
char* LoadFile(const char* Path)
{
char *LoadFile(const char *Path) {
FILE *fptr;
fptr = fopen(Path, "r");
if (!fptr) {
@@ -46,15 +48,16 @@ char* LoadFile(const char* Path)
return NULL;
}
long size = stat_GetSize(fptr);
char* text = malloc(sizeof(char) * size);
fread(text , size , 1, fptr);
char *text = malloc(sizeof(char) * (size + 1));
memset(text, 0x00, sizeof(char)*(size + 1));
fread(text, size + 1, 1, fptr);
fclose(fptr);
return text;
}
uint CompileShader(const char *FilePath, GLenum ShaderType) {
char *shdr_text = LoadFile(FilePath);
printf("%s\n" , shdr_text);
uint shader = glCreateShader(ShaderType);
glShaderSource(shader, 1, (const char **)&shdr_text, NULL);
glCompileShader(shader);
@@ -63,25 +66,19 @@ uint CompileShader (const char* FilePath , GLenum ShaderType ) {
glGetShaderiv(shader, GL_COMPILE_STATUS, &status);
if (!status) {
glGetShaderInfoLog(shader, 512, NULL, info);
const char* typename = ShaderType == GL_VERTEX_SHADER ? "VERTEX" : "FRAGMENT";
const char *typename =
ShaderType == GL_VERTEX_SHADER ? "VERTEX" : "FRAGMENT";
printf("ERROR::SHADER::%s::COMPILATION %s\n", typename, info);
}
free(shdr_text);
return shader;
}
float vertices[] = {
0.5f, 0.5f, 0.0f,
0.5f, -0.5f, 0.0f,
-0.5f, -0.5f, 0.0f,
-0.5f, 0.5f, 0.0f,
0.5f, 0.5f, 0.0f, 0.5f, -0.5f, 0.0f, -0.5f, -0.5f, 0.0f, -0.5f, 0.5f, 0.0f,
};
uint indices[] = {
0,1,3,
1,2,3
};
uint indices[] = {0, 1, 3, 1, 2, 3};
struct {
unsigned int shaderProgram;
@@ -92,9 +89,9 @@ struct {
void Setup() {
// Load Vertex Shader
uint vert_shader = CompileShader("shader.v", GL_VERTEX_SHADER);
uint vert_shader = CompileShader("vertex.glsl", GL_VERTEX_SHADER);
// Load Fragment Shader
uint frag_shader = CompileShader("shader.f", GL_FRAGMENT_SHADER);
uint frag_shader = CompileShader("fragment.glsl", GL_FRAGMENT_SHADER);
RenderVariables.shaderProgram = glCreateProgram();
glAttachShader(RenderVariables.shaderProgram, vert_shader);
@@ -117,11 +114,12 @@ void Setup(){
glBindVertexArray(RenderVariables.VAO);
glBindBuffer(GL_ARRAY_BUFFER, RenderVariables.EBO);
glBindBuffer(GL_ARRAY_BUFFER, RenderVariables.VBO);
glBufferData(GL_ARRAY_BUFFER, sizeof(vertices), vertices, GL_STATIC_DRAW);
glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, RenderVariables.EBO);
glBufferData(GL_ELEMENT_ARRAY_BUFFER, sizeof(indices), indices, GL_STATIC_DRAW);
glBufferData(GL_ELEMENT_ARRAY_BUFFER, sizeof(indices), indices,
GL_STATIC_DRAW);
glVertexAttribPointer(0, 3, GL_FLOAT, GL_FALSE, 3 * sizeof(float), (void *)0);
glEnableVertexAttribArray(0);
@@ -144,11 +142,8 @@ int main (int argc, char **argv){
glBindVertexArray(RenderVariables.VAO);
glDrawElements(GL_TRIANGLES, 6, GL_UNSIGNED_INT, 0);
RGFW_window_swapBuffers_OpenGL(win);
}
RGFW_window_close(win);
return 0;
}