From 66b1e02847e08b8e66e9969f0a3d138c15cc70f4 Mon Sep 17 00:00:00 2001 From: omniscient <17525998+omnisci3nce@users.noreply.github.com> Date: Sun, 21 Jul 2024 17:48:00 +1000 Subject: terrain/hmap skeleton --- src/new_render/render.c | 16 ++++++++++++++-- src/new_render/render.h | 6 ++++-- src/new_render/shadows.c | 4 +--- 3 files changed, 19 insertions(+), 7 deletions(-) (limited to 'src/new_render') diff --git a/src/new_render/render.c b/src/new_render/render.c index eea9ad1..08ef2c0 100644 --- a/src/new_render/render.c +++ b/src/new_render/render.c @@ -16,6 +16,7 @@ #include "render_scene.h" #include "render_types.h" #include "shadows.h" +#include "terrain.h" #define STB_IMAGE_IMPLEMENTATION #include @@ -34,7 +35,7 @@ struct Renderer { RenderScene scene; PBR_Storage* pbr; Shadow_Storage* shadows; - // Terrain_Storage terrain; + Terrain_Storage* terrain; // Text_Storage text; ResourcePools* resource_pools; arena frame_arena; @@ -104,6 +105,9 @@ bool Renderer_Init(RendererConfig config, Renderer* ren, GLFWwindow** out_window ren->pbr = malloc(sizeof(PBR_Storage)); PBR_Init(ren->pbr); + ren->terrain = malloc(sizeof(Terrain_Storage)); + Terrain_Init(ren->terrain); + return true; } @@ -112,6 +116,8 @@ void Renderer_Shutdown(Renderer* ren) { DEBUG("Freed Shadows storage"); free(ren->pbr); DEBUG("Freed PBR storage"); + free(ren->terrain); + DEBUG("Freed Terrain storage"); arena_free_storage(&ren->frame_arena); DEBUG("Freed frame allocator buffer"); } @@ -147,7 +153,8 @@ void Render_RenderEntities(RenderEnt* entities, size_t entity_count) { RenderScene scene = ren->scene; Shadow_Storage* shadow_storage = Render_GetShadowStorage(); - TextureHandle depthmap = shadow_storage->enabled ? Shadow_GetShadowMapTexture(shadow_storage) : INVALID_TEX_HANDLE; + TextureHandle depthmap = + shadow_storage->enabled ? Shadow_GetShadowMapTexture(shadow_storage) : INVALID_TEX_HANDLE; PBR_Execute(ren->pbr, scene.camera, depthmap, entities, entity_count); } @@ -239,4 +246,9 @@ RenderScene* Render_GetScene() { Shadow_Storage* Render_GetShadowStorage() { Renderer* ren = Core_GetRenderer(&g_core); return ren->shadows; +} + +Terrain_Storage* Render_GetTerrainStorage() { + Renderer* ren = Core_GetRenderer(&g_core); + return ren->terrain; } \ No newline at end of file diff --git a/src/new_render/render.h b/src/new_render/render.h index 0231975..233c934 100644 --- a/src/new_render/render.h +++ b/src/new_render/render.h @@ -70,8 +70,10 @@ PUB void Render_DrawTerrain(); // --- Getters (not in love with this but I'm finding keeping Renderer internals private to be okay) arena* GetRenderFrameArena(Renderer* r); -typedef struct Shadow_Storage Shadow_Storage; typedef struct RenderScene RenderScene; +typedef struct Shadow_Storage Shadow_Storage; +typedef struct Terrain_Storage Terrain_Storage; RenderScene* Render_GetScene(); -Shadow_Storage* Render_GetShadowStorage(); \ No newline at end of file +Shadow_Storage* Render_GetShadowStorage(); +Terrain_Storage* Render_GetTerrainStorage(); \ No newline at end of file diff --git a/src/new_render/shadows.c b/src/new_render/shadows.c index df25e05..f62950b 100644 --- a/src/new_render/shadows.c +++ b/src/new_render/shadows.c @@ -209,6 +209,4 @@ void Shadow_ShadowmapExecute(Shadow_Storage* storage, Mat4 light_space_transform GPU_CmdEncoder_EndRender(&shadow_encoder); // end renderpass } -TextureHandle Shadow_GetShadowMapTexture(Shadow_Storage* storage) { - return storage->depth_texture; -} +TextureHandle Shadow_GetShadowMapTexture(Shadow_Storage* storage) { return storage->depth_texture; } -- cgit v1.2.3-70-g09d2