diff options
author | omniscient <17525998+omnisci3nce@users.noreply.github.com> | 2024-07-31 10:33:32 +1000 |
---|---|---|
committer | omniscient <17525998+omnisci3nce@users.noreply.github.com> | 2024-07-31 10:33:32 +1000 |
commit | 0f703b8a5129acfa13c92ce79699d86833dcc561 (patch) | |
tree | bf18dc3263e8958d2a8cc7864f822ad21ed738b7 | |
parent | 0a60692230841cbcbbf67acba55d2dbb4730b6cb (diff) |
grid draw/execute
-rw-r--r-- | src/new_render/render.c | 5 | ||||
-rw-r--r-- | src/new_render/render.h | 2 | ||||
-rw-r--r-- | src/render/backends/opengl/README.md | 1 | ||||
-rw-r--r-- | src/render/render.c | 289 | ||||
-rw-r--r-- | src/render/render.h | 85 | ||||
-rw-r--r-- | src/systems/grid.c | 7 | ||||
-rw-r--r-- | src/systems/grid.h | 5 |
7 files changed, 16 insertions, 378 deletions
diff --git a/src/new_render/render.c b/src/new_render/render.c index 54ea32a..f83e573 100644 --- a/src/new_render/render.c +++ b/src/new_render/render.c @@ -314,6 +314,11 @@ Terrain_Storage* Render_GetTerrainStorage() { return ren->terrain; } +Grid_Storage* Render_GetGridStorage() { + Renderer* ren = Core_GetRenderer(&g_core); + return ren->grid; +} + TextureHandle Render_GetWhiteTexture() { Renderer* ren = Core_GetRenderer(&g_core); return ren->white_1x1; diff --git a/src/new_render/render.h b/src/new_render/render.h index dad3026..8f3ac2a 100644 --- a/src/new_render/render.h +++ b/src/new_render/render.h @@ -4,6 +4,7 @@ #pragma once #include "defines.h" +#include "grid.h" #include "maths_types.h" #include "ral_types.h" #include "render_types.h" @@ -84,6 +85,7 @@ typedef struct Terrain_Storage Terrain_Storage; RenderScene* Render_GetScene(); Shadow_Storage* Render_GetShadowStorage(); Terrain_Storage* Render_GetTerrainStorage(); +Grid_Storage* Render_GetGridStorage(); TextureHandle Render_GetWhiteTexture(); arena* Render_GetFrameArena(); Mesh_pool* Render_GetMeshPool(); diff --git a/src/render/backends/opengl/README.md b/src/render/backends/opengl/README.md deleted file mode 100644 index f87f5c1..0000000 --- a/src/render/backends/opengl/README.md +++ /dev/null @@ -1 +0,0 @@ -# TODO
\ No newline at end of file diff --git a/src/render/render.c b/src/render/render.c deleted file mode 100644 index f326fdd..0000000 --- a/src/render/render.c +++ /dev/null @@ -1,289 +0,0 @@ -#include <glfw3.h> -#include "maths_types.h" -#include "render_types.h" -#define STB_IMAGE_IMPLEMENTATION -#include <stb_image.h> - -#include "camera.h" -#include "file.h" -#include "log.h" -#include "mem.h" -#include "ral.h" -#include "ral_types.h" -#include "render.h" - -//---NEW -#include "static_pipeline.h" -//---END - -/** @brief Creates the pipelines built into Celeritas such as rendering static opaque geometry, - debug visualisations, immediate mode UI, etc */ -void default_pipelines_init(renderer* ren); - -bool renderer_init(renderer* ren) { - // INFO("Renderer init"); - - // NOTE: all platforms use GLFW at the moment but thats subject to change - glfwInit(); - -#if defined(CEL_REND_BACKEND_OPENGL) - glfwWindowHint(GLFW_CONTEXT_VERSION_MAJOR, 4); - glfwWindowHint(GLFW_CONTEXT_VERSION_MINOR, 1); - glfwWindowHint(GLFW_OPENGL_PROFILE, GLFW_OPENGL_CORE_PROFILE); - glfwWindowHint(GLFW_OPENGL_FORWARD_COMPAT, GL_TRUE); -#elif defined(CEL_REND_BACKEND_VULKAN) - glfwWindowHint(GLFW_CLIENT_API, GLFW_NO_API); -#endif - - // glfw window creation - GLFWwindow* window = glfwCreateWindow(ren->config.scr_width, ren->config.scr_height, - ren->config.window_name, NULL, NULL); - if (window == NULL) { - // ERROR("Failed to create GLFW window\n"); - glfwTerminate(); - return false; - } - ren->window = window; - - glfwMakeContextCurrent(ren->window); - - DEBUG("Set up GLFW window callbacks"); - - DEBUG("Start gpu backend init"); - - if (!gpu_backend_init("Celeritas Engine - Vulkan", window)) { - FATAL("Couldnt load graphics api backend"); - return false; - } - gpu_device_create(&ren->device); // TODO: handle errors - gpu_swapchain_create(&ren->swapchain); - - DEBUG("Initialise GPU resource pools"); - arena pool_arena = arena_create(malloc(1024 * 1024), 1024 * 1024); - ren->resource_pools = arena_alloc(&pool_arena, sizeof(struct resource_pools)); - resource_pools_init(&pool_arena, ren->resource_pools); - - // Create default rendering pipeline - default_pipelines_init(ren); - - return true; -} -void renderer_shutdown(renderer* ren) { - gpu_swapchain_destroy(&ren->swapchain); - gpu_pipeline_destroy(&ren->static_opaque_pipeline); - gpu_backend_shutdown(); -} - -void default_pipelines_init(renderer* ren) { - // Static opaque geometry - arena scratch = arena_create(malloc(1024 * 1024), 1024 * 1024); - - gpu_renderpass_desc pass_description = {}; - gpu_renderpass* renderpass = gpu_renderpass_create(&pass_description); - - ren->default_renderpass = *renderpass; - - printf("Load shaders\n"); - str8 vert_path, frag_path; -#ifdef CEL_REND_BACKEND_OPENGL - vert_path = str8lit("assets/shaders/cube.vert"); - frag_path = str8lit("assets/shaders/cube.frag"); -#else - vert_path = str8lit("build/linux/x86_64/debug/cube.vert.spv"); - frag_path = str8lit("build/linux/x86_64/debug/cube.frag.spv"); -#endif - str8_opt vertex_shader = str8_from_file(&scratch, vert_path); - str8_opt fragment_shader = str8_from_file(&scratch, frag_path); - if (!vertex_shader.has_value || !fragment_shader.has_value) { - ERROR_EXIT("Failed to load shaders from disk") - } - if (!vertex_shader.has_value || !fragment_shader.has_value) { - ERROR_EXIT("Failed to load shaders from disk") - } - - // Vertex attributes - vertex_description vertex_input = { 0 }; - vertex_input.debug_label = "Standard Static 3D Vertex Format"; - vertex_desc_add(&vertex_input, "inPosition", ATTR_F32x3); - vertex_desc_add(&vertex_input, "inNormal", ATTR_F32x3); - vertex_desc_add(&vertex_input, "inTexCoords", ATTR_F32x2); - vertex_input.use_full_vertex_size = true; - - // Shader data bindings - shader_data mvp_uniforms_data = { .data = NULL, .shader_data_get_layout = &mvp_uniforms_layout }; - - struct graphics_pipeline_desc pipeline_description = { - .debug_name = "Basic Pipeline", - .vertex_desc = vertex_input, - .data_layouts = { mvp_uniforms_data }, - .data_layouts_count = 1, - .vs = { .debug_name = "Basic Vertex Shader", - .filepath = vert_path, - .code = vertex_shader.contents, - .is_spirv = true }, - .fs = { .debug_name = "Basic Fragment Shader", - .filepath = frag_path, - .code = fragment_shader.contents, - .is_spirv = true }, - .renderpass = renderpass, - .wireframe = false, - .depth_test = false - }; - gpu_pipeline* gfx_pipeline = gpu_graphics_pipeline_create(pipeline_description); - ren->static_opaque_pipeline = *gfx_pipeline; -} - -void render_frame_begin(renderer* ren) { - ren->frame_aborted = false; - if (!gpu_backend_begin_frame()) { - ren->frame_aborted = true; - WARN("Frame aborted"); - return; - } - gpu_cmd_encoder* enc = gpu_get_default_cmd_encoder(); - // begin recording - gpu_cmd_encoder_begin(*enc); - gpu_cmd_encoder_begin_render(enc, &ren->default_renderpass); - encode_bind_pipeline(enc, PIPELINE_GRAPHICS, &ren->static_opaque_pipeline); - encode_set_default_settings(enc); -} -void render_frame_end(renderer* ren) { - if (ren->frame_aborted) { - return; - } - gpu_cmd_encoder* enc = gpu_get_default_cmd_encoder(); - gpu_cmd_encoder_end_render(enc); - gpu_cmd_buffer buf = gpu_cmd_encoder_finish(enc); - gpu_queue_submit(&buf); - gpu_backend_end_frame(); -} -void render_frame_draw(renderer* ren) {} - -bool mesh_has_indices(mesh* m) { return m->geometry->has_indices; } - -/** - * - * @param Camera used for getting the view projection matric to draw the mesh with. - * If NULL use the last used camera */ -void draw_mesh(mesh* mesh, mat4* model, camera* cam) { // , mat4* view, mat4* proj) { - gpu_cmd_encoder* enc = gpu_get_default_cmd_encoder(); - - encode_set_vertex_buffer(enc, mesh->vertex_buffer); - if (mesh_has_indices(mesh)) { - encode_set_index_buffer(enc, mesh->index_buffer); - } - - mat4 view, proj; - if (cam) { - camera_view_projection(cam, // FIXME: proper swapchain dimensions - 1000, 1000, &view, &proj); - - } else { - WARN("No camera set"); - } - mvp_uniforms mvp_data = { .model = *model, .view = view, .projection = proj }; - my_shader_bind_group shader_bind_data = { .mvp = mvp_data }; - shader_data mvp_uniforms_data = { .data = &shader_bind_data, - .shader_data_get_layout = &mvp_uniforms_layout }; - encode_bind_shader_data(enc, 0, &mvp_uniforms_data); - - encode_draw_indexed(enc, mesh->geometry->indices->len); -} - -void gfx_backend_draw_frame(renderer* ren, camera* camera, mat4 model, texture* tex) {} - -void geo_set_vertex_colours(geometry_data* geo, vec4 colour) {} - -// --- NEW - -mesh mesh_create(geometry_data* geometry, bool free_on_upload) { - mesh m = { 0 }; - - // Create and upload vertex buffer - size_t vert_bytes = geometry->vertices->len * sizeof(vertex); - INFO("Creating vertex buffer with size %d (%d x %d)", vert_bytes, geometry->vertices->len, - sizeof(vertex)); - m.vertex_buffer = gpu_buffer_create(vert_bytes, CEL_BUFFER_VERTEX, CEL_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_buffer_create(index_bytes, CEL_BUFFER_INDEX, CEL_BUFFER_FLAG_GPU, - geometry->indices->data); - - m.is_uploaded = true; - // m.has_indices = geometry->has_indices; - // m.index_count = geometry->indices.len; - m.geometry = geometry; - if (free_on_upload) { - geo_free_data(geometry); - } - - // TODO: materials? - - return m; -} - -// --- Textures - -texture_data texture_data_load(const char* path, bool invert_y) { - TRACE("Load texture %s", path); - - // load the file data - int width, height, num_channels; - 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); - if (data) { - DEBUG("loaded texture: %s", path); - } else { - WARN("failed to load texture"); - } - - unsigned int channel_type; - if (num_channels == 4) { - channel_type = GL_RGBA; - } else { - channel_type = GL_RGB; - } - texture_desc desc = { .extents = { width, height }, - .format = CEL_TEXTURE_FORMAT_8_8_8_8_RGBA_UNORM, - .tex_type = CEL_TEXTURE_TYPE_2D }; - - return (texture_data){ .description = desc, .image_data = data }; -} - -texture_handle texture_data_upload(texture_data data, bool free_on_upload) { - texture_handle handle = gpu_texture_create(data.description, true, data.image_data); - if (free_on_upload) { - TRACE("Freed stb_image data"); - stbi_image_free(data.image_data); - } - return handle; -} - -/** @brief load all of the texture for a PBR material and returns an unnamed material */ -material pbr_material_load(char* albedo_path, char* normal_path, bool metal_roughness_combined, - char* metallic_path, char* roughness_map, char* ao_map) { - material m = { 0 }; - m.kind = MAT_PBR; - - // For now we must have the required textures - assert(albedo_path); - assert(normal_path); - assert(metallic_path); - assert(metal_roughness_combined); - - m.mat_data.pbr.metal_roughness_combined = metal_roughness_combined; - texture_data tex_data; - tex_data = texture_data_load(albedo_path, false); - m.mat_data.pbr.albedo_map = texture_data_upload(tex_data, true); - tex_data = texture_data_load(normal_path, false); - m.mat_data.pbr.normal_map = texture_data_upload(tex_data, true); - tex_data = texture_data_load(metallic_path, false); - m.mat_data.pbr.metallic_map = texture_data_upload(tex_data, true); - - return m; -} diff --git a/src/render/render.h b/src/render/render.h deleted file mode 100644 index 313b14c..0000000 --- a/src/render/render.h +++ /dev/null @@ -1,85 +0,0 @@ -/** - * @file render.h - * @author your name (you@domain.com) - * @brief Renderer frontend - * @version 0.1 - * @date 2024-03-21 - * - * @copyright Copyright (c) 2024 - * - */ -#pragma once - -#include "file.h" -#include "ral_types.h" -#include "render_types.h" - -/** @brief configuration passed to the renderer at init time */ -typedef struct renderer_config { - char window_name[256]; - u32 scr_width, scr_height; - vec3 clear_colour; /** colour that the screen gets cleared to every frame */ -} renderer_config; - -typedef struct renderer { - struct GLFWwindow* window; - void* backend_context; - renderer_config config; - gpu_device device; - gpu_swapchain swapchain; - gpu_renderpass default_renderpass; - gpu_pipeline static_opaque_pipeline; - bool frame_aborted; - struct resource_pools* resource_pools; -} renderer; - -bool renderer_init(renderer* ren); -void renderer_shutdown(renderer* ren); - -void render_frame_begin(renderer* ren); -void render_frame_update_globals(renderer* ren); -void render_frame_end(renderer* ren); -void render_frame_draw(renderer* ren); - -// ! TEMP -typedef struct camera camera; -void gfx_backend_draw_frame(renderer* ren, camera* camera, mat4 model, texture* tex); - -typedef struct render_ctx { - mat4 view; - mat4 projection; -} render_ctx; - -// frontend -- these can be called from say a loop in an example, or via FFI -texture_handle texture_create(const char* debug_name, texture_desc description, const u8* data); - -// Frontend Resources -texture_data texture_data_load(const char* path, bool invert_y); - -/** - * @brief - * - * @param data - * @param free_on_upload frees the CPU-side pixel data stored in `data` - * @return texture_handle - */ -texture_handle texture_data_upload(texture_data data, bool free_on_upload); - -/** @brief load all of the texture for a PBR material and returns an unnamed material */ -material pbr_material_load(char* albedo_path, char* normal_path, bool metal_roughness_combined, - char* metallic_path, char* roughness_map, char* ao_map); - -/** - * @brief Creates buffers and returns a struct that holds handles to our resources - * - * @param geometry - * @param free_on_upload frees the CPU-side vertex/index data stored in `geometry` when we - successfully upload that data to the GPU-side buffer - * @return mesh - */ -mesh mesh_create(geometry_data* geometry, bool free_on_upload); -void mesh_delete(mesh* mesh); // TODO - -void draw_mesh(mesh* mesh, mat4* model, camera* cam); - -model_handle model_load(const char* debug_name, const char* filepath); diff --git a/src/systems/grid.c b/src/systems/grid.c index 20e3657..256fab4 100644 --- a/src/systems/grid.c +++ b/src/systems/grid.c @@ -54,6 +54,11 @@ void Grid_Init(Grid_Storage* storage) { storage->pipeline = GPU_GraphicsPipeline_Create(pipeline_desc, storage->renderpass); } -void Grid_Draw(Grid_Storage* storage) { +void Grid_Draw() { + Grid_Storage* grid = Render_GetGridStorage(); + Grid_Execute(grid); +} +void Grid_Execute(Grid_Storage *storage) { + // TODO: draw calls }
\ No newline at end of file diff --git a/src/systems/grid.h b/src/systems/grid.h index 7d983dc..d8bc567 100644 --- a/src/systems/grid.h +++ b/src/systems/grid.h @@ -11,10 +11,11 @@ typedef struct Grid_Storage { } Grid_Storage; // --- Public API -void Grid_Init(Grid_Storage* storage); +PUB void Grid_Init(Grid_Storage* storage); // void Grid_Shutdown(Grid_Storage* storage); -void Grid_Draw(Grid_Storage* storage); +PUB void Grid_Draw(); // --- Internal +void Grid_Execute(Grid_Storage* storage); // typedef struct GridUniforms {} GridUniforms; // ShaderDataLayout GridUniforms_GetLayout(void* data);
\ No newline at end of file |