summaryrefslogtreecommitdiff
path: root/examples/shadow_maps/ex_shadow_maps.c
diff options
context:
space:
mode:
Diffstat (limited to 'examples/shadow_maps/ex_shadow_maps.c')
-rw-r--r--examples/shadow_maps/ex_shadow_maps.c129
1 files changed, 121 insertions, 8 deletions
diff --git a/examples/shadow_maps/ex_shadow_maps.c b/examples/shadow_maps/ex_shadow_maps.c
index 30df618..28cab86 100644
--- a/examples/shadow_maps/ex_shadow_maps.c
+++ b/examples/shadow_maps/ex_shadow_maps.c
@@ -2,6 +2,7 @@
#include "maths.h"
#include "maths_types.h"
#include "primitives.h"
+#include "log.h"
#include "ral.h"
#include "ral_types.h"
#include "render.h"
@@ -21,14 +22,96 @@ transform s_transforms[5];
*/
void draw_scene();
+void switch_view();
+
+enum active_view {
+ SceneView,
+ LightView,
+ DebugQuad,
+};
+
+// Define the shader data
+typedef struct mvp_uniforms {
+ mat4 model;
+ mat4 view;
+ mat4 projection;
+} mvp_uniforms;
+typedef struct my_shader_bind_group {
+ mvp_uniforms mvp;
+ texture_handle tex;
+} my_shader_bind_group;
+
+// We also must create a function that knows how to return a `shader_data_layout`
+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 = "Matrices",
+ .type = SHADER_BINDING_BYTES,
+ .stores_data = has_data,
+ .data = { .bytes = { .size = sizeof(mvp_uniforms) } } };
+
+ shader_binding b2 = { .label = "texSampler",
+ .type = SHADER_BINDING_TEXTURE,
+ .stores_data = has_data };
+ if (has_data) {
+ b1.data.bytes.data = &d->mvp;
+ b2.data.texture.handle = d->tex;
+ }
+ return (shader_data_layout){ .name = "global_ubo", .bindings = { b1, b2 }, .bindings_count = 2 };
+}
int main() {
core_bringup();
arena scratch = arena_create(malloc(1024 * 1024), 1024 * 1024);
- vec3 camera_pos = vec3(2., 2., 2.);
+ vec3 camera_pos = vec3(5,5,5);
vec3 camera_front = vec3_normalise(vec3_negate(camera_pos));
camera cam = camera_create(camera_pos, camera_front, VEC3_Y, deg_to_rad(45.0));
+ // TEMP
+ shader_data mvp_uniforms_data = { .data = NULL, .shader_data_get_layout = &mvp_uniforms_layout };
+
+ gpu_renderpass_desc pass_description = { .default_framebuffer = true };
+ gpu_renderpass* renderpass = gpu_renderpass_create(&pass_description);
+
+ 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")
+ }
+
+ struct graphics_pipeline_desc pipeline_description = {
+ .debug_name = "Basic Pipeline",
+ .vertex_desc = static_3d_vertex_description(),
+ .data_layouts = { mvp_uniforms_data },
+ .data_layouts_count = 1,
+ .vs = { .debug_name = "Cube Vertex Shader",
+ .filepath = vert_path,
+ .code = vertex_shader.contents,
+ .is_spirv = true },
+ .fs = { .debug_name = "Cube 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);
+
+ // Texture
+ texture_data tex_data = texture_data_load("assets/textures/texture.jpg", false);
+ texture_handle texture = texture_data_upload(tex_data, true);
+
+ // END TEMP
ren_shadowmaps shadows = { .width = 1000, .height = 1000 };
ren_shadowmaps_init(&shadows);
@@ -39,14 +122,14 @@ int main() {
// 2. lights
// 3. some boxes
for (int i = 0; i < 4; i++) {
- geometry_data geo = geo_create_cuboid(f32x3(2, 2, 2));
+ geometry_data geo = geo_create_cuboid(f32x3(1,1,1));
s_scene[i] = mesh_create(&geo, true);
- s_transforms[i] = transform_create(vec3(4 * i, 0, 0), quat_ident(), 1.0);
+ s_transforms[i] = transform_create(vec3(-2 + (i * 1.2), 0, 0), quat_ident(), 1.0);
}
geometry_data plane = geo_create_plane(f32x2(20, 20));
s_scene[4] = mesh_create(&plane, true);
- geometry_data quad_geo = geo_create_plane(f32x2(2,2));
+ geometry_data quad_geo = geo_create_plane(f32x2(2, 2));
mesh quad = mesh_create(&quad_geo, true);
shader_data model_data = { .data = NULL, .shader_data_get_layout = &model_uniform_layout };
@@ -61,7 +144,9 @@ int main() {
continue;
}
gpu_cmd_encoder* enc = gpu_get_default_cmd_encoder();
+ gpu_cmd_encoder_begin(*enc);
+ // Shadow draw
gpu_cmd_encoder_begin_render(enc, shadows.rpass);
// calculations
@@ -79,22 +164,49 @@ int main() {
draw_scene();
gpu_cmd_encoder_end_render(enc);
+ // End
+ // Debug quad
gpu_cmd_encoder_begin_render(enc, shadows.debug_quad->renderpass);
+
encode_bind_pipeline(enc, PIPELINE_GRAPHICS, shadows.debug_quad);
- debug_quad_uniform dqu = {.depthMap = shadows.depth_tex};
- shader_data debug_quad_data = { .data = &dqu, .shader_data_get_layout = debug_quad_layout};
+ debug_quad_uniform dqu = { .depthMap = shadows.depth_tex };
+ shader_data debug_quad_data = { .data = &dqu, .shader_data_get_layout = debug_quad_layout };
encode_bind_shader_data(enc, 0, &debug_quad_data);
encode_set_vertex_buffer(enc, quad.vertex_buffer);
encode_set_index_buffer(enc, quad.index_buffer);
encode_draw_indexed(enc, quad.geometry->indices->len);
gpu_cmd_encoder_end_render(enc);
+ // End
// gpu_cmd_encoder_begin_render(enc, static_opaque_rpass);
// gpu_cmd_encoder_end_render(enc);
+
+ /* gpu_cmd_encoder_begin_render(enc, renderpass); */
+ /* encode_bind_pipeline(enc, PIPELINE_GRAPHICS, gfx_pipeline); */
+
+ /* mat4 view, proj; */
+ /* camera_view_projection(&cam, 1000, 1000, */
+ /* &view, &proj); */
+ /* for (int i = 0; i < 4; i++) { */
+ /* mat4 model = transform_to_mat(&s_transforms[i]); */
+ /* mvp_uniforms mvp_data = { .model = model, .view = view, .projection = proj }; */
+ /* my_shader_bind_group shader_bind_data = { .mvp = mvp_data, .tex = texture }; */
+ /* mvp_uniforms_data.data = &shader_bind_data; */
+ /* encode_bind_shader_data(enc, 0, &mvp_uniforms_data); */
+ /* encode_set_vertex_buffer(enc, s_scene[i].vertex_buffer); */
+ /* encode_set_index_buffer(enc, s_scene[i].index_buffer); */
+ /* encode_draw_indexed(enc, s_scene[i].geometry->indices->len); */
+ /* } */
+
+ /* gpu_cmd_encoder_end_render(enc); */
+
+ // END drawing
+ gpu_cmd_buffer buf = gpu_cmd_encoder_finish(enc);
+ gpu_queue_submit(&buf);
gpu_backend_end_frame();
}
@@ -105,8 +217,9 @@ int main() {
void draw_scene() {
gpu_cmd_encoder* enc = gpu_get_default_cmd_encoder();
- for (int i = 0; i < 5; i++) {
- model_uniform mu = { .model = transform_to_mat(&s_transforms[i]) };
+ for (int i = 0; i < 4; i++) { //FIXME: draw plane as well
+ mat4 model = transform_to_mat(&s_transforms[i]) ;
+ model_uniform mu = { .model = model};
shader_data model_data = { .data = &mu, .shader_data_get_layout = model_uniform_layout };
encode_bind_shader_data(enc, 0, &model_data);
encode_set_vertex_buffer(enc, s_scene[i].vertex_buffer);