From 01d598220b403f4ac4da3b7aa1f0ce398be3198f Mon Sep 17 00:00:00 2001 From: omnisci3nce Date: Thu, 18 Jul 2024 23:10:11 +1000 Subject: skybox works --- src/new_render/render.c | 12 +++++++----- src/new_render/skybox.c | 49 ++++++++++++++++++++++++++++++++++++++++++------- src/new_render/skybox.h | 2 +- 3 files changed, 50 insertions(+), 13 deletions(-) (limited to 'src/new_render') diff --git a/src/new_render/render.c b/src/new_render/render.c index a757c97..58041dd 100644 --- a/src/new_render/render.c +++ b/src/new_render/render.c @@ -142,7 +142,7 @@ TextureData TextureDataLoad(const char* path, bool invert_y) { stbi_set_flip_vertically_on_load(invert_y); #pragma GCC diagnostic ignored "-Wpointer-sign" - char* data = stbi_load(path, &width, &height, &num_channels, STBI_rgb_alpha); + char* data = stbi_load(path, &width, &height, &num_channels, STBI_rgb); if (data) { DEBUG("loaded texture: %s", path); } else { @@ -182,10 +182,12 @@ Mesh Mesh_Create(Geometry* geometry, bool free_on_upload) { GPU_BufferCreate(vert_bytes, BUFFER_VERTEX, BUFFER_FLAG_GPU, geometry->vertices->data); // Create and upload index buffer - size_t index_bytes = geometry->indices->len * sizeof(u32); - INFO("Creating index buffer with size %d (len: %d)", index_bytes, geometry->indices->len); - m.index_buffer = - GPU_BufferCreate(index_bytes, BUFFER_INDEX, BUFFER_FLAG_GPU, geometry->indices->data); + if (geometry->has_indices) { + size_t index_bytes = geometry->indices->len * sizeof(u32); + INFO("Creating index buffer with size %d (len: %d)", index_bytes, geometry->indices->len); + m.index_buffer = + GPU_BufferCreate(index_bytes, BUFFER_INDEX, BUFFER_FLAG_GPU, geometry->indices->data); + } m.is_uploaded = true; m.geometry = *geometry; // clone geometry data and store on Mesh struct diff --git a/src/new_render/skybox.c b/src/new_render/skybox.c index 267ec6d..8ac8356 100644 --- a/src/new_render/skybox.c +++ b/src/new_render/skybox.c @@ -12,12 +12,42 @@ #include "render_types.h" #include "shader_layouts.h" +float skyboxVertices[] = { + // positions + -1.0f, 1.0f, -1.0f, -1.0f, -1.0f, -1.0f, 1.0f, -1.0f, -1.0f, + 1.0f, -1.0f, -1.0f, 1.0f, 1.0f, -1.0f, -1.0f, 1.0f, -1.0f, + + -1.0f, -1.0f, 1.0f, -1.0f, -1.0f, -1.0f, -1.0f, 1.0f, -1.0f, + -1.0f, 1.0f, -1.0f, -1.0f, 1.0f, 1.0f, -1.0f, -1.0f, 1.0f, + + 1.0f, -1.0f, -1.0f, 1.0f, -1.0f, 1.0f, 1.0f, 1.0f, 1.0f, + 1.0f, 1.0f, 1.0f, 1.0f, 1.0f, -1.0f, 1.0f, -1.0f, -1.0f, + + -1.0f, -1.0f, 1.0f, -1.0f, 1.0f, 1.0f, 1.0f, 1.0f, 1.0f, + 1.0f, 1.0f, 1.0f, 1.0f, -1.0f, 1.0f, -1.0f, -1.0f, 1.0f, + + -1.0f, 1.0f, -1.0f, 1.0f, 1.0f, -1.0f, 1.0f, 1.0f, 1.0f, + 1.0f, 1.0f, 1.0f, -1.0f, 1.0f, 1.0f, -1.0f, 1.0f, -1.0f, + + -1.0f, -1.0f, -1.0f, -1.0f, -1.0f, 1.0f, 1.0f, -1.0f, -1.0f, + 1.0f, -1.0f, -1.0f, -1.0f, -1.0f, 1.0f, 1.0f, -1.0f, 1.0f +}; + Skybox Skybox_Create(const char** face_paths, int n) { INFO("Creating a skybox"); assert(n == 6); // ! we're only supporting a full cubemap for now // -- cube verts - Geometry geom = Geo_CreateCuboid(f32x3(1.0, 1.0, 1.0)); + Geometry geom = { .format = VERTEX_POS_ONLY, // doesnt matter + .has_indices = false, + .indices = NULL, + .vertices = Vertex_darray_new(36) }; + for (u32 i = 0; i < (36 * 3); i += 3) { + Vertex_darray_push( + geom.vertices, + (Vertex){ .pos_only = { .position = vec3(skyboxVertices[i], skyboxVertices[i + 1], + skyboxVertices[i + 2]) } }); + } Mesh cube = Mesh_Create(&geom, false); // -- cubemap texture @@ -64,10 +94,14 @@ Skybox Skybox_Create(const char** face_paths, int n) { ShaderData camera_data = { .data = NULL, .get_layout = &Binding_Camera_GetLayout }; ShaderData shader_data = { .data = NULL, .get_layout = &Skybox_GetLayout }; + VertexDescription builder = { .debug_label = "pos only" }; + VertexDesc_AddAttr(&builder, "inPosition", ATTR_F32x3); + builder.use_full_vertex_size = true; + GraphicsPipelineDesc pipeline_desc = { .debug_name = "Skybox pipeline", - .vertex_desc = static_3d_vertex_description(), - .data_layouts = { camera_data, shader_data }, + .vertex_desc = builder, + .data_layouts = { shader_data, camera_data }, .data_layouts_count = 2, .vs = { .debug_name = "Skybox Vertex Shader", .filepath = vert_path, @@ -75,7 +109,7 @@ Skybox Skybox_Create(const char** face_paths, int n) { .fs = { .debug_name = "Skybox Fragment Shader", .filepath = frag_path, .code = fragment_shader.contents }, - .wireframe = false, + .wireframe = true, .depth_test = true, }; @@ -86,6 +120,7 @@ Skybox Skybox_Create(const char** face_paths, int n) { void Skybox_Draw(Skybox* skybox, Camera camera) { GPU_CmdEncoder* enc = GPU_GetDefaultEncoder(); + glDepthFunc(GL_LEQUAL); GPU_CmdEncoder_BeginRender(enc, skybox->pipeline->renderpass); GPU_EncodeBindPipeline(enc, skybox->pipeline); GPU_EncodeSetDefaults(enc); @@ -118,9 +153,9 @@ void Skybox_Draw(Skybox* skybox, Camera camera) { GPU_EncodeSetVertexBuffer(enc, skybox->cube.vertex_buffer); GPU_EncodeSetIndexBuffer(enc, skybox->cube.index_buffer); - glDepthFunc(GL_LEQUAL); - GPU_EncodeDrawIndexed(enc, skybox->cube.geometry.indices->len); - glDepthFunc(GL_LESS); + + GPU_EncodeDraw(enc, 36); GPU_CmdEncoder_EndRender(enc); + glDepthFunc(GL_LESS); } diff --git a/src/new_render/skybox.h b/src/new_render/skybox.h index bf70976..71262fd 100644 --- a/src/new_render/skybox.h +++ b/src/new_render/skybox.h @@ -27,7 +27,7 @@ static ShaderDataLayout Skybox_GetLayout(void* data) { bool has_data = data != NULL; ShaderBinding b1 = { - .label = "cubemap", + .label = "cubeMap", .vis = VISIBILITY_FRAGMENT, .kind = BINDING_TEXTURE, }; -- cgit v1.2.3-70-g09d2