summaryrefslogtreecommitdiff
path: root/examples/pbr_params/ex_pbr_params.c
diff options
context:
space:
mode:
Diffstat (limited to 'examples/pbr_params/ex_pbr_params.c')
-rw-r--r--examples/pbr_params/ex_pbr_params.c46
1 files changed, 18 insertions, 28 deletions
diff --git a/examples/pbr_params/ex_pbr_params.c b/examples/pbr_params/ex_pbr_params.c
index 0d8ade4..1d2d756 100644
--- a/examples/pbr_params/ex_pbr_params.c
+++ b/examples/pbr_params/ex_pbr_params.c
@@ -24,19 +24,12 @@ const vec3 pointlight_positions[4] = {
};
pbr_point_light point_lights[4];
-// Lets define some constant PBR parameters here to test on one sphere with first
-const rgba ALBEDO = RED_700;
-const f32 metallic = 1.0;
-const f32 roughness = 0.3;
-const f32 ao = 1.0;
-
-const int num_rows = 7;
-const int num_cols = 7;
+void encode_draw_mesh(mesh* m);
+
+const int num_rows = 7, num_cols = 7;
const float spacing = 2.5;
-pbr_params_material_uniforms pbr_params = {
- .albedo = (vec3){ 0.5, 0.0, 0.0 }, .metallic = metallic, .roughness = roughness, .ao = ao
-};
+pbr_params_material_uniforms pbr_params;
int main() {
core_bringup();
@@ -45,15 +38,15 @@ int main() {
for (int i = 0; i < 4; i++) {
point_lights[i].pos = pointlight_positions[i];
- // point_lights[i].color = vec3(0.25 * (i + 1), 0., 0.0);
point_lights[i].color = vec3(300.0, 300.0, 300.0);
}
- vec3 camera_pos = vec3(1., 1., -25.);
- vec3 camera_front = vec3_normalise(vec3_negate(camera_pos));
- camera cam = camera_create(camera_pos, camera_front, VEC3_Y, deg_to_rad(45.0));
+ vec3 camera_pos = vec3(-1., -1., 26.);
+ camera cam = camera_create(camera_pos, VEC3_NEG_Z, VEC3_Y, deg_to_rad(45.0));
// PBR Material data
+ pbr_params.albedo = (vec3){ 0.5, 0.0, 0.0 };
+ pbr_params.ao = 1.0;
shader_data pbr_uniforms = { .data = NULL, .shader_data_get_layout = &pbr_params_shader_layout };
// Make the pipeline
@@ -119,20 +112,11 @@ int main() {
pbr_bind_data.material = pbr_params;
pbr_bind_data.lights = (pbr_params_light_uniforms){
.viewPos = vec4(cam.position.x, cam.position.y, cam.position.z, 1.0),
- // .viewPos = cam.position,
.pointLights = { point_lights[0], point_lights[1], point_lights[2], point_lights[3] }
};
pbr_uniforms.data = &pbr_bind_data;
-// encode_bind_shader_data(enc, 0, &pbr_uniforms);
-
-// Record draw call
-/* draw_mesh(&sphere, &model_affine, &cam); */
-#if 0
- encode_set_vertex_buffer(enc, cube.vertex_buffer);
- encode_set_index_buffer(enc, cube.index_buffer);
- encode_draw_indexed(enc, cube.geometry->indices->len);
-#endif
+ // Record draw calls
for (u32 row = 0; row < num_rows; row++) {
f32 metallic = (float)row / (float)num_rows;
for (u32 col = 0; col < num_cols; col++) {
@@ -152,9 +136,8 @@ int main() {
mat4 model = mat4_translation(vec3(x, y, 0.0f));
pbr_bind_data.mvp_matrices.model = model;
encode_bind_shader_data(enc, 0, &pbr_uniforms);
- encode_set_vertex_buffer(enc, sphere.vertex_buffer);
- encode_set_index_buffer(enc, sphere.index_buffer);
- encode_draw_indexed(enc, sphere.geometry->indices->len);
+ mesh object = sphere;
+ encode_draw_mesh(&object);
}
}
@@ -171,3 +154,10 @@ int main() {
return 0;
}
+
+void encode_draw_mesh(mesh* m) {
+ gpu_cmd_encoder* enc = gpu_get_default_cmd_encoder();
+ encode_set_vertex_buffer(enc, m->vertex_buffer);
+ encode_set_index_buffer(enc, m->index_buffer);
+ encode_draw_indexed(enc, m->geometry->indices->len);
+} \ No newline at end of file