From f1cb5bece520dba63fa77e4721909ab8f0a6c26f Mon Sep 17 00:00:00 2001 From: omniscient <17525998+omnisci3nce@users.noreply.github.com> Date: Mon, 17 Jun 2024 22:08:13 +1000 Subject: add plane primitive --- src/maths/primitives.c | 61 +++++++++++++++++++++++++++--------------- src/renderer/render.c | 2 +- src/renderer/static_pipeline.h | 2 +- 3 files changed, 42 insertions(+), 23 deletions(-) (limited to 'src') diff --git a/src/maths/primitives.c b/src/maths/primitives.c index 46175fd..2fbe71a 100644 --- a/src/maths/primitives.c +++ b/src/maths/primitives.c @@ -5,6 +5,18 @@ #include "ral_types.h" #include "render_types.h" +#define VERT_3D(arr, pos, norm, uv) \ + { \ + vertex v = { .static_3d = { .position = pos, .normal = norm, .tex_coords = uv } }; \ + vertex_darray_push(arr, v); \ + } + +void push_triangle(u32_darray* arr, u32 i0, u32 i1, u32 i2) { + u32_darray_push(arr, i0); + u32_darray_push(arr, i1); + u32_darray_push(arr, i2); +} + // TODO: move to another file void geo_free_data(geometry_data* geo) { vertex_darray_free(geo->vertices); @@ -16,21 +28,40 @@ void geo_free_data(geometry_data* geo) { } // vertices -f32 plane_vertex_positions[] = { - // triangle 1 - -0.5, 0, -0.5, -0.5, 0, 0.5, 0.5, 0, -0.5, - // triangle 2 - 0.5, 0, -0.5, -0.5, 0, 0.5, 0.5, 0, 0.5 +vec3 plane_vertex_positions[] = { + (vec3){ -0.5, 0, -0.5}, + (vec3){ 0.5, 0, -0.5}, + (vec3){ -0.5, 0, 0.5}, + (vec3){ 0.5, 0, 0.5}, }; geometry_data geo_create_plane(f32x2 extents) { - f32x2 half_extents = vec2_div(extents, 2.0); - vertex_format format = VERTEX_STATIC_3D; vertex_darray* vertices = vertex_darray_new(4); + u32_darray* indices = u32_darray_new(vertices->len); - // vertex_darray_push(vertices, (vertex){ .static_3d = { .position = } }); + vec3 vert_pos[4]; + memcpy(&vert_pos, plane_vertex_positions, sizeof(plane_vertex_positions)); + for (int i = 0; i < 4; i++) { + vert_pos[i].x *= extents.x; + vert_pos[i].z *= extents.y; + } + VERT_3D(vertices, vert_pos[0], VEC3_Y, vec2(0, 0)); + VERT_3D(vertices, vert_pos[1], VEC3_Y, vec2(1, 0)); + VERT_3D(vertices, vert_pos[2], VEC3_Y, vec2(0, 1)); + VERT_3D(vertices, vert_pos[3], VEC3_Y, vec2(1, 1)); + + push_triangle(indices, 2,1,0); + push_triangle(indices, 1,2,3); - // return (geometry_data) { .format = format, .vertices =.has_indices = true, } + geometry_data geo = { + .format = VERTEX_STATIC_3D, + .vertices = vertices, + .has_indices = true, + .indices = indices, + .colour = (rgba){ 0, 0, 0, 1 } + }; + + return geo; } // OLD @@ -44,18 +75,6 @@ static const vec3 FRONT_BOT_RIGHT = (vec3){ 1, 0, 1 }; static const vec3 FRONT_TOP_LEFT = (vec3){ 0, 1, 1 }; static const vec3 FRONT_TOP_RIGHT = (vec3){ 1, 1, 1 }; -#define VERT_3D(arr, pos, norm, uv) \ - { \ - vertex v = { .static_3d = { .position = pos, .normal = norm, .tex_coords = uv } }; \ - vertex_darray_push(arr, v); \ - } - -void push_triangle(u32_darray* arr, u32 i0, u32 i1, u32 i2) { - u32_darray_push(arr, i0); - u32_darray_push(arr, i1); - u32_darray_push(arr, i2); -} - geometry_data geo_create_cuboid(f32x3 extents) { /* static mesh prim_cube_mesh_create() { */ vertex_darray* vertices = vertex_darray_new(36); diff --git a/src/renderer/render.c b/src/renderer/render.c index 1c98b0b..f52e2be 100644 --- a/src/renderer/render.c +++ b/src/renderer/render.c @@ -62,7 +62,7 @@ bool renderer_init(renderer* ren) { resource_pools_init(&pool_arena, ren->resource_pools); // Create default rendering pipeline - /* default_pipelines_init(ren); */ + default_pipelines_init(ren); return true; } diff --git a/src/renderer/static_pipeline.h b/src/renderer/static_pipeline.h index 15e8842..bf5bc42 100644 --- a/src/renderer/static_pipeline.h +++ b/src/renderer/static_pipeline.h @@ -18,7 +18,7 @@ static shader_data_layout mvp_uniforms_layout(void* data) { my_shader_bind_group* d = (my_shader_bind_group*)data; bool has_data = data != NULL; - shader_binding b1 = { .label = "mvp_uniforms", + shader_binding b1 = { .label = "Matrices", .type = SHADER_BINDING_BYTES, .stores_data = has_data, .data = { .bytes = { .size = sizeof(mvp_uniforms) } } }; -- cgit v1.2.3-70-g09d2