summaryrefslogtreecommitdiff
path: root/examples/gltf_loading
diff options
context:
space:
mode:
Diffstat (limited to 'examples/gltf_loading')
-rw-r--r--examples/gltf_loading/ex_gltf_loading.c30
1 files changed, 19 insertions, 11 deletions
diff --git a/examples/gltf_loading/ex_gltf_loading.c b/examples/gltf_loading/ex_gltf_loading.c
index fa74ada..e7f84ff 100644
--- a/examples/gltf_loading/ex_gltf_loading.c
+++ b/examples/gltf_loading/ex_gltf_loading.c
@@ -10,6 +10,10 @@
#include "render.h"
#include "render_types.h"
+extern core g_core;
+
+#define MODEL_GET(h) (model_pool_get(&g_core.models, h))
+
const vec3 pointlight_positions[4] = {
{ 0.7, 0.2, 2.0 },
{ 2.3, -3.3, -4.0 },
@@ -23,12 +27,12 @@ int main() {
double lastFrame = currentFrame;
double deltaTime;
- core* core = core_bringup();
+ core_bringup();
model_handle helmet_handle =
- model_load_gltf(core, "assets/models/gltf/DamagedHelmet/glTF/DamagedHelmet.gltf", false);
- model* helmet = &core->models->data[helmet_handle.raw];
- model_upload_meshes(&core->renderer, helmet);
+ model_load_gltf("assets/models/gltf/DamagedHelmet/glTF/DamagedHelmet.gltf", false);
+ INFO("GLTF loaded successfully!");
+ model* helmet = MODEL_GET(helmet_handle);
vec3 camera_pos = vec3(5., 0., 0.);
vec3 camera_front = vec3_normalise(vec3_negate(camera_pos));
@@ -51,16 +55,17 @@ int main() {
point_lights[i].quadratic = 0.032;
}
- scene our_scene = { .dir_light = dir_light, .n_point_lights = 4 };
- memcpy(&our_scene.point_lights, &point_lights, sizeof(point_light[4]));
+ // scene our_scene = { .dir_light = dir_light, .n_point_lights = 4 };
+ // memcpy(&our_scene.point_lights, &point_lights, sizeof(point_light[4]));
+
+ while (!should_exit(&g_core)) {
+ input_update(&g_core.input);
- while (!should_exit(core)) {
currentFrame = glfwGetTime();
deltaTime = currentFrame - lastFrame;
lastFrame = currentFrame;
- input_update(&core->input);
- render_frame_begin(&core->renderer);
+ render_frame_begin(&g_core.renderer);
// Draw the model
static f32 angle = 0.0;
@@ -69,10 +74,13 @@ int main() {
angle += (rot_speed * deltaTime);
transform model_tf = transform_create(vec3(0.0, 0.1, -0.1), rot, 1.8);
mat4 model = transform_to_mat(&model_tf);
- draw_model(&core->renderer, &cam, helmet, &model, &our_scene);
- render_frame_end(&core->renderer);
+ draw_mesh(&helmet->meshes->data[0], &model);
+
+ render_frame_end(&g_core.renderer);
}
+ renderer_shutdown(&g_core.renderer);
+
return 0;
}