src/mesh.c

Mon, 12 May 2025 21:13:24 +0200

author
Mike Becker <universe@uap-core.de>
date
Mon, 12 May 2025 21:13:24 +0200
changeset 118
830608f7e7d9
parent 117
d1267f656a97
permissions
-rw-r--r--

apply texture scaling

81
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1 /*
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
2 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
3 * Copyright 2025 Mike Becker. All rights reserved.
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
4 *
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
5 * Redistribution and use in source and binary forms, with or without
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
6 * modification, are permitted provided that the following conditions are met:
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
7 *
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
8 * 1. Redistributions of source code must retain the above copyright
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
9 * notice, this list of conditions and the following disclaimer.
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
10 *
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
11 * 2. Redistributions in binary form must reproduce the above copyright
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
12 * notice, this list of conditions and the following disclaimer in the
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
13 * documentation and/or other materials provided with the distribution.
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
14 *
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
16 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
17 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
18 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
19 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
20 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
21 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
22 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
23 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
24 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
25 * POSSIBILITY OF SUCH DAMAGE.
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
26 */
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
27
106
895f92cff6b8 bring back error.h to reduce compile dependencies
Mike Becker <universe@uap-core.de>
parents: 95
diff changeset
28 #include "ascension/error.h"
81
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
29 #include "ascension/mesh.h"
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
30
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
31 #include <GL/glew.h>
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
32
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
33 void asc_mesh_allocate_buffers(AscMesh *mesh, unsigned count) {
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
34 asc_dprintf("Allocate mesh buffers for %u meshes.", count);
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
35 GLuint buffers[count];
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
36 GLuint arrays[count];
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
37 glGenBuffers(count, buffers);
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
38 glGenVertexArrays(count, arrays);
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
39 for (unsigned i = 0; i < count; i++) {
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
40 mesh[i].vbo = buffers[i];
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
41 mesh[i].vao = arrays[i];
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
42 }
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
43 asc_error_catch_all_gl();
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
44 }
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
45
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
46 void asc_mesh_free_buffers(AscMesh *mesh, unsigned count) {
115
e5f8c99b0987 refactor rendering 1/3 - create new mesh structs
Mike Becker <universe@uap-core.de>
parents: 106
diff changeset
47 if (count == 1 && mesh->vbo == 0) return; // hack to skip this function until we remove it
81
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
48 asc_dprintf("Free mesh buffers for %u meshes.", count);
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
49 GLuint buffers[count];
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
50 GLuint arrays[count];
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
51
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
52 for (unsigned i = 0; i < count; i++) {
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
53 buffers[i] = mesh[i].vbo;
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
54 arrays[i] = mesh[i].vao;
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
55 mesh[i].vbo = 0;
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
56 mesh[i].vao = 0;
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
57 }
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
58
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
59 glDeleteBuffers(count, buffers);
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
60 glDeleteVertexArrays(count, arrays);
84a546e282b7 create catch-all util for GL errors + refactors mesh creation
Mike Becker <universe@uap-core.de>
parents:
diff changeset
61 asc_error_catch_all_gl();
82
4e1e698f4b0d add generic mesh draw function and move sprite draw function to separate unit
Mike Becker <universe@uap-core.de>
parents: 81
diff changeset
62 }
4e1e698f4b0d add generic mesh draw function and move sprite draw function to separate unit
Mike Becker <universe@uap-core.de>
parents: 81
diff changeset
63
115
e5f8c99b0987 refactor rendering 1/3 - create new mesh structs
Mike Becker <universe@uap-core.de>
parents: 106
diff changeset
64 void asc_mesh_draw_triangle_strip(const AscMesh *mesh) {
82
4e1e698f4b0d add generic mesh draw function and move sprite draw function to separate unit
Mike Becker <universe@uap-core.de>
parents: 81
diff changeset
65 glBindVertexArray(mesh->vao);
115
e5f8c99b0987 refactor rendering 1/3 - create new mesh structs
Mike Becker <universe@uap-core.de>
parents: 106
diff changeset
66 glDrawArrays(GL_TRIANGLE_STRIP, 0, mesh->vtx_count);
82
4e1e698f4b0d add generic mesh draw function and move sprite draw function to separate unit
Mike Becker <universe@uap-core.de>
parents: 81
diff changeset
67 #ifndef NDEBUG
4e1e698f4b0d add generic mesh draw function and move sprite draw function to separate unit
Mike Becker <universe@uap-core.de>
parents: 81
diff changeset
68 // only unbind in debug mode to detect accidental re-use of the wrong VAO
4e1e698f4b0d add generic mesh draw function and move sprite draw function to separate unit
Mike Becker <universe@uap-core.de>
parents: 81
diff changeset
69 glBindVertexArray(0);
4e1e698f4b0d add generic mesh draw function and move sprite draw function to separate unit
Mike Becker <universe@uap-core.de>
parents: 81
diff changeset
70 #endif
4e1e698f4b0d add generic mesh draw function and move sprite draw function to separate unit
Mike Becker <universe@uap-core.de>
parents: 81
diff changeset
71 }
115
e5f8c99b0987 refactor rendering 1/3 - create new mesh structs
Mike Becker <universe@uap-core.de>
parents: 106
diff changeset
72
e5f8c99b0987 refactor rendering 1/3 - create new mesh structs
Mike Becker <universe@uap-core.de>
parents: 106
diff changeset
73 void asc_mesh_destroy(AscMesh *mesh) {
e5f8c99b0987 refactor rendering 1/3 - create new mesh structs
Mike Becker <universe@uap-core.de>
parents: 106
diff changeset
74 asc_mesh_free_buffers(mesh, 1);
e5f8c99b0987 refactor rendering 1/3 - create new mesh structs
Mike Becker <universe@uap-core.de>
parents: 106
diff changeset
75 free(mesh->vtx_data);
e5f8c99b0987 refactor rendering 1/3 - create new mesh structs
Mike Becker <universe@uap-core.de>
parents: 106
diff changeset
76 }
e5f8c99b0987 refactor rendering 1/3 - create new mesh structs
Mike Becker <universe@uap-core.de>
parents: 106
diff changeset
77
116
bfb2a7d62047 replace scaling with correct mesh sizes
Mike Becker <universe@uap-core.de>
parents: 115
diff changeset
78 void asc_mesh_init_plane_2d(AscMesh *mesh, struct asc_mesh_init_plane_2d_args args) {
115
e5f8c99b0987 refactor rendering 1/3 - create new mesh structs
Mike Becker <universe@uap-core.de>
parents: 106
diff changeset
79 if (mesh->vbo == 0) {
e5f8c99b0987 refactor rendering 1/3 - create new mesh structs
Mike Becker <universe@uap-core.de>
parents: 106
diff changeset
80 asc_mesh_allocate_buffers(mesh, 1);
e5f8c99b0987 refactor rendering 1/3 - create new mesh structs
Mike Becker <universe@uap-core.de>
parents: 106
diff changeset
81 }
116
bfb2a7d62047 replace scaling with correct mesh sizes
Mike Becker <universe@uap-core.de>
parents: 115
diff changeset
82
118
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
83 unsigned required_memory = 4 * sizeof(AscMeshVertex2d);
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
84
116
bfb2a7d62047 replace scaling with correct mesh sizes
Mike Becker <universe@uap-core.de>
parents: 115
diff changeset
85 // free any previous data
118
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
86 if (mesh->vtx_data && mesh->vtx_data_size < required_memory) {
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
87 free(mesh->vtx_data);
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
88 mesh->vtx_data = NULL;
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
89 }
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
90
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
91 // allocate memory
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
92 AscMeshVertex2d *data;
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
93 if (mesh->vtx_data == NULL) {
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
94 asc_dprintf("Create plane in VBO %u and VAO %u", mesh->vbo, mesh->vao);
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
95 mesh->vtx_data_size = required_memory;
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
96 data = malloc(mesh->vtx_data_size);
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
97 mesh->vtx_data = (float*) data;
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
98 } else {
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
99 data = (AscMeshVertex2d*) mesh->vtx_data;
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
100 }
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
101 mesh->vtx_count = 4;
116
bfb2a7d62047 replace scaling with correct mesh sizes
Mike Becker <universe@uap-core.de>
parents: 115
diff changeset
102
bfb2a7d62047 replace scaling with correct mesh sizes
Mike Becker <universe@uap-core.de>
parents: 115
diff changeset
103 // default values
117
d1267f656a97 implement texture scaling
Mike Becker <universe@uap-core.de>
parents: 116
diff changeset
104 args.size.x = ASC_NONZERO_OR(1.f, args.size.x);
d1267f656a97 implement texture scaling
Mike Becker <universe@uap-core.de>
parents: 116
diff changeset
105 args.size.y = ASC_NONZERO_OR(1.f, args.size.y);
d1267f656a97 implement texture scaling
Mike Becker <universe@uap-core.de>
parents: 116
diff changeset
106 args.uv_scale.x = ASC_NONZERO_OR(1.f, args.uv_scale.x);
d1267f656a97 implement texture scaling
Mike Becker <universe@uap-core.de>
parents: 116
diff changeset
107 args.uv_scale.y = ASC_NONZERO_OR(1.f, args.uv_scale.y);
116
bfb2a7d62047 replace scaling with correct mesh sizes
Mike Becker <universe@uap-core.de>
parents: 115
diff changeset
108
118
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
109 // bottom left
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
110 data[0].pos = asc_vec2f_new(0.0f, 0.0f);
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
111 data[0].uv = asc_vec2f_new(args.uv_offset.x, args.uv_offset.y);
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
112 // top left
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
113 data[1].pos = asc_vec2f_new(0.0f, args.size.y);
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
114 data[1].uv = asc_vec2f_new(args.uv_offset.x, args.uv_offset.y + args.uv_scale.y);
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
115 // bottom right
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
116 data[2].pos = asc_vec2f_new(args.size.x, 0.0f);
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
117 data[2].uv = asc_vec2f_new(args.uv_offset.x + args.uv_scale.x, args.uv_offset.y);
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
118 // top right
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
119 data[3].pos = asc_vec2f_new(args.size.x, args.size.y);
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
120 data[3].uv = asc_vec2f_new(args.uv_offset.x + args.uv_scale.x, args.uv_offset.y + args.uv_scale.y);
115
e5f8c99b0987 refactor rendering 1/3 - create new mesh structs
Mike Becker <universe@uap-core.de>
parents: 106
diff changeset
121 glBindBuffer(GL_ARRAY_BUFFER, mesh->vbo);
118
830608f7e7d9 apply texture scaling
Mike Becker <universe@uap-core.de>
parents: 117
diff changeset
122 glBufferData(GL_ARRAY_BUFFER, mesh->vtx_data_size, mesh->vtx_data, GL_STATIC_DRAW);
116
bfb2a7d62047 replace scaling with correct mesh sizes
Mike Becker <universe@uap-core.de>
parents: 115
diff changeset
123 // TODO: this should not be repeated for every adjustment - but it will be moved to the batch renderer anyway
115
e5f8c99b0987 refactor rendering 1/3 - create new mesh structs
Mike Becker <universe@uap-core.de>
parents: 106
diff changeset
124 glBindVertexArray(mesh->vao);
e5f8c99b0987 refactor rendering 1/3 - create new mesh structs
Mike Becker <universe@uap-core.de>
parents: 106
diff changeset
125 glVertexAttribPointer(0, 2, GL_FLOAT, GL_FALSE, sizeof(AscMeshVertex2d), (void*)offsetof(AscMeshVertex2d, pos));
e5f8c99b0987 refactor rendering 1/3 - create new mesh structs
Mike Becker <universe@uap-core.de>
parents: 106
diff changeset
126 glEnableVertexAttribArray(0);
e5f8c99b0987 refactor rendering 1/3 - create new mesh structs
Mike Becker <universe@uap-core.de>
parents: 106
diff changeset
127 glVertexAttribPointer(1, 2, GL_FLOAT, GL_FALSE, sizeof(AscMeshVertex2d), (void*)offsetof(AscMeshVertex2d, uv));
e5f8c99b0987 refactor rendering 1/3 - create new mesh structs
Mike Becker <universe@uap-core.de>
parents: 106
diff changeset
128 glEnableVertexAttribArray(1);
e5f8c99b0987 refactor rendering 1/3 - create new mesh structs
Mike Becker <universe@uap-core.de>
parents: 106
diff changeset
129 }

mercurial