summaryrefslogtreecommitdiff
path: root/src/new_render
diff options
context:
space:
mode:
authoromniscient <17525998+omnisci3nce@users.noreply.github.com>2024-07-21 17:48:00 +1000
committeromniscient <17525998+omnisci3nce@users.noreply.github.com>2024-07-21 17:48:00 +1000
commit66b1e02847e08b8e66e9969f0a3d138c15cc70f4 (patch)
treea598a4a1716fa985ab4359a60f6a2c93d2ee390b /src/new_render
parent9f1bfa75490bbdf22dd57ff17352d2736a0891fa (diff)
terrain/hmap skeleton
Diffstat (limited to 'src/new_render')
-rw-r--r--src/new_render/render.c16
-rw-r--r--src/new_render/render.h6
-rw-r--r--src/new_render/shadows.c4
3 files changed, 19 insertions, 7 deletions
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 <stb_image.h>
@@ -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; }