From f40e9f02ef3ca0a86282a927c9bb7887900100b2 Mon Sep 17 00:00:00 2001 From: pommicket Date: Sat, 31 Dec 2022 11:29:22 -0500 Subject: move NDC conversion to GPU --- gl.c | 20 ++++++-------------- text.c | 15 ++++++--------- 2 files changed, 12 insertions(+), 23 deletions(-) diff --git a/gl.c b/gl.c index 2cf6a43..322c0ed 100644 --- a/gl.c +++ b/gl.c @@ -243,14 +243,17 @@ static GLSimpleTriangle *gl_geometry_triangles; static GLuint gl_geometry_program; static GLuint gl_geometry_v_pos; static GLuint gl_geometry_v_color; +static GLint gl_geometry_u_window_size; static GLuint gl_geometry_vbo, gl_geometry_vao; static void gl_geometry_init(void) { char const *vshader_code = "attribute vec2 v_pos;\n\ attribute vec4 v_color;\n\ + uniform vec2 u_window_size;\n\ OUT vec4 color;\n\ void main() {\n\ - gl_Position = vec4(v_pos, 0.0, 1.0);\n\ + vec2 p = v_pos * (2.0 / u_window_size);\n\ + gl_Position = vec4(p.x - 1.0, 1.0 - p.y, 0.0, 1.0);\n\ color = v_color;\n\ }\n\ "; @@ -263,6 +266,7 @@ static void gl_geometry_init(void) { gl_geometry_program = gl_compile_and_link_shaders(NULL, vshader_code, fshader_code); gl_geometry_v_pos = gl_attrib_loc(gl_geometry_program, "v_pos"); gl_geometry_v_color = gl_attrib_loc(gl_geometry_program, "v_color"); + gl_geometry_u_window_size = gl_uniform_loc(gl_geometry_program, "u_window_size"); glGenBuffers(1, &gl_geometry_vbo); if (gl_version_major >= 3) @@ -271,11 +275,6 @@ static void gl_geometry_init(void) { static float gl_window_width, gl_window_height; -static void gl_convert_to_ndc(v2 *pos) { - pos->x = pos->x / gl_window_width * 2.0f - 1.0f; - pos->y = 1.0f - pos->y / gl_window_height * 2.0f; -} - static void gl_geometry_rect(Rect r, u32 color_rgba) { v4 color = rgba_u32_to_v4(color_rgba); @@ -313,14 +312,6 @@ static void gl_geometry_draw(void) { size_t ntriangles = arr_len(gl_geometry_triangles); if (ntriangles == 0) return; - - // convert coordinates to NDC - for (size_t i = 0; i < ntriangles; ++i) { - GLSimpleTriangle *triangle = &gl_geometry_triangles[i]; - gl_convert_to_ndc(&triangle->v1.pos); - gl_convert_to_ndc(&triangle->v2.pos); - gl_convert_to_ndc(&triangle->v3.pos); - } if (gl_version_major >= 3) glBindVertexArray(gl_geometry_vao); @@ -333,6 +324,7 @@ static void gl_geometry_draw(void) { glEnableVertexAttribArray(gl_geometry_v_color); glUseProgram(gl_geometry_program); + glUniform2f(gl_geometry_u_window_size, gl_window_width, gl_window_height); glDrawArrays(GL_TRIANGLES, 0, (GLsizei)(3 * ntriangles)); arr_clear(gl_geometry_triangles); diff --git a/text.c b/text.c index d439b32..8c31c2c 100644 --- a/text.c +++ b/text.c @@ -88,17 +88,20 @@ static GLuint text_program; static GLuint text_vbo, text_vao; static GLuint text_v_pos, text_v_color, text_v_tex_coord; static GLint text_u_sampler; +static GLint text_u_window_size; static bool text_init(void) { char const *vshader_code = "attribute vec4 v_color;\n\ attribute vec2 v_pos;\n\ attribute vec2 v_tex_coord;\n\ +uniform vec2 u_window_size;\n\ OUT vec4 color;\n\ OUT vec2 tex_coord;\n\ void main() {\n\ color = v_color;\n\ tex_coord = v_tex_coord;\n\ - gl_Position = vec4(v_pos, 0.0, 1.0);\n\ + vec2 p = v_pos * (2.0 / u_window_size);\n\ + gl_Position = vec4(p.x - 1.0, 1.0 - p.y, 0.0, 1.0);\n\ }\n\ "; char const *fshader_code = "IN vec4 color;\n\ @@ -115,6 +118,7 @@ void main() {\n\ text_v_color = gl_attrib_loc(text_program, "v_color"); text_v_tex_coord = gl_attrib_loc(text_program, "v_tex_coord"); text_u_sampler = gl_uniform_loc(text_program, "sampler"); + text_u_window_size = gl_uniform_loc(text_program, "u_window_size"); glGenBuffers(1, &text_vbo); glGenVertexArrays(1, &text_vao); @@ -239,14 +243,6 @@ void text_render(Font *font) { if (font->triangles[i]) { // render these triangles size_t ntriangles = arr_len(font->triangles[i]); - - // convert coordinates to NDC - for (size_t t = 0; t < ntriangles; ++t) { - TextTriangle *triangle = &font->triangles[i][t]; - gl_convert_to_ndc(&triangle->v1.pos); - gl_convert_to_ndc(&triangle->v2.pos); - gl_convert_to_ndc(&triangle->v3.pos); - } if (gl_version_major >= 3) glBindVertexArray(text_vao); @@ -262,6 +258,7 @@ void text_render(Font *font) { glActiveTexture(GL_TEXTURE0); glBindTexture(GL_TEXTURE_2D, font->textures[i]); glUniform1i(text_u_sampler, 0); + glUniform2f(text_u_window_size, gl_window_width, gl_window_height); glDrawArrays(GL_TRIANGLES, 0, (GLsizei)(3 * ntriangles)); arr_clear(font->triangles[i]); } -- cgit v1.2.3