summaryrefslogtreecommitdiff
path: root/examples/primitives
diff options
context:
space:
mode:
authoromniscient <17525998+omnisci3nce@users.noreply.github.com>2024-06-12 00:16:51 +1000
committeromniscient <17525998+omnisci3nce@users.noreply.github.com>2024-06-12 00:16:51 +1000
commit26fb1fcafa552c600a70b2680c868f7355b138e4 (patch)
tree2fb77c8b14a5610584a316e57fd8db2795847a0f /examples/primitives
parent76216f91aee936bc57d7e1a1b2c2b63a03ce976a (diff)
wip: uvsphere mesh gen and pbr shader first pass
Diffstat (limited to 'examples/primitives')
-rw-r--r--examples/primitives/ex_primitives.c53
1 files changed, 53 insertions, 0 deletions
diff --git a/examples/primitives/ex_primitives.c b/examples/primitives/ex_primitives.c
new file mode 100644
index 0000000..c208734
--- /dev/null
+++ b/examples/primitives/ex_primitives.c
@@ -0,0 +1,53 @@
+#include <glfw3.h>
+
+#include "buf.h"
+#include "camera.h"
+#include "core.h"
+#include "file.h"
+#include "log.h"
+#include "maths.h"
+#include "maths_types.h"
+#include "mem.h"
+#include "primitives.h"
+#include "ral.h"
+#include "ral_types.h"
+#include "render.h"
+#include "render_types.h"
+
+extern core g_core;
+
+int main() {
+ core_bringup();
+ arena scratch = arena_create(malloc(1024 * 1024), 1024 * 1024);
+
+ vec3 camera_pos = vec3(2., 2., 2.);
+ vec3 camera_front = vec3_normalise(vec3_negate(camera_pos));
+ camera cam = camera_create(camera_pos, camera_front, VEC3_Y, deg_to_rad(45.0));
+
+ // Geometry
+ // geo_create_cuboid(f32x3(1, 1, 1));
+ geometry_data sphere_data = geo_create_uvsphere(2.0, 8, 8);
+ mesh sphere = mesh_create(&sphere_data, false);
+
+ // Texture
+ texture_data tex_data = texture_data_load("assets/textures/texture.jpg", false);
+ texture_handle texture = texture_data_upload(tex_data, true);
+
+ static f32 theta = 0.0;
+
+ // Main loop
+ while (!should_exit(&g_core)) {
+ input_update(&g_core.input);
+
+ render_frame_begin(&g_core.renderer);
+
+ mat4 model = mat4_ident();
+ draw_mesh(&sphere, &model, &cam);
+
+ render_frame_end(&g_core.renderer);
+ }
+
+ renderer_shutdown(&g_core.renderer);
+
+ return 0;
+}