diff options
Diffstat (limited to 'src/core')
-rw-r--r-- | src/core/README.md | 3 | ||||
-rw-r--r-- | src/core/camera.c | 22 | ||||
-rw-r--r-- | src/core/camera.h | 37 | ||||
-rw-r--r-- | src/core/core.c | 89 | ||||
-rw-r--r-- | src/core/core.h | 40 |
5 files changed, 191 insertions, 0 deletions
diff --git a/src/core/README.md b/src/core/README.md new file mode 100644 index 0000000..19cc1d0 --- /dev/null +++ b/src/core/README.md @@ -0,0 +1,3 @@ +# Core + +Core engine facilities diff --git a/src/core/camera.c b/src/core/camera.c new file mode 100644 index 0000000..50c4054 --- /dev/null +++ b/src/core/camera.c @@ -0,0 +1,22 @@ +#include "camera.h" + +#include "maths.h" + +Camera Camera_Create(vec3 pos, vec3 front, vec3 up, f32 fov) { + Camera c = { .position = pos, .front = front, .up = up, .fov = fov }; + return c; +} + +mat4 Camera_ViewProj(Camera *c, f32 lens_height, f32 lens_width, mat4 *out_view, + mat4 *out_proj) { + mat4 proj = mat4_perspective(c->fov, lens_width / lens_height, 0.1, 100.0); + vec3 camera_direction = vec3_add(c->position, c->front); + mat4 view = mat4_look_at(c->position, camera_direction, c->up); + if (out_view) { + *out_view = view; + } + if (out_proj) { + *out_proj = proj; + } + return mat4_mult(view, proj); +} diff --git a/src/core/camera.h b/src/core/camera.h new file mode 100644 index 0000000..233f5f3 --- /dev/null +++ b/src/core/camera.h @@ -0,0 +1,37 @@ +/** + * @file camera.h + * @brief + */ +#pragma once + +#include "defines.h" +#include "maths_types.h" + +typedef struct Camera { + vec3 position; + vec3 front; + vec3 up; + f32 fov; +} Camera; + +/** @brief create a camera */ +Camera Camera_Create(vec3 pos, vec3 front, vec3 up, f32 fov); + +/** + * @brief Get 3D camera transform matrix + * @param out_view optionally stores just the view matrix + * @param out_proj optionally stores just the projection matrix + * @returns the camera's view projection matrix pre-multiplied +*/ +PUB mat4 Camera_ViewProj(Camera* c, f32 lens_height, f32 lens_width, mat4* out_view, mat4* out_proj); + +/** @brief Get 2D camera transform matrix */ +PUB mat4 Camera_View2D(Camera* c); // TODO: 2D cameras + + +// TODO: Basic reusable camera controls +/* +Right click + move = pan +Left click = orbit camera +WASD = forward/backward/left/right +*/ diff --git a/src/core/core.c b/src/core/core.c new file mode 100644 index 0000000..1d8fe91 --- /dev/null +++ b/src/core/core.c @@ -0,0 +1,89 @@ +#include "core.h" + +#include <stdlib.h> + +#include "glfw3.h" +#include "input.h" +#include "keys.h" +#include "log.h" +#include "mem.h" +#include "render.h" +#include "render_types.h" +#include "scene.h" +// #include "threadpool.h" + +#define SCR_WIDTH 1000 +#define SCR_HEIGHT 1000 + +core g_core; /** @brief global `core` that other files can use */ + +inline core* get_global_core() { return &g_core; } + +void core_bringup() { + INFO("Initiate Core bringup"); + renderer_config conf = { .window_name = { "Celeritas Engine Core" }, + .scr_width = SCR_WIDTH, + .scr_height = SCR_HEIGHT, + .clear_colour = (vec3){ .08, .08, .1 } }; + g_core.renderer.config = conf; + g_core.renderer.backend_context = NULL; + + // threadpool_create(&c->threadpool, 6, 256); + // threadpool_set_ctx(&c->threadpool, c); // Gives the threadpool access to the core + + // initialise all subsystems + if (!renderer_init(&g_core.renderer)) { + // FATAL("Failed to start renderer"); + ERROR_EXIT("Failed to start renderer\n"); + } + if (!input_system_init(&g_core.input, g_core.renderer.window)) { + // the input system needs the glfw window which is created by the renderer + // hence the order here is important + FATAL("Failed to start input system"); + ERROR_EXIT("Failed to start input system\n"); + } + /* + if (!text_system_init(&c->text)) { + // FATAL("Failed to start text system"); + ERROR_EXIT("Failed to start text system\n"); + } + if (!screenspace_2d_init(&c->screenspace)) { + // FATAL("Failed to start screenspace 2d plugin"); + ERROR_EXIT("Failed to start screenspace 2d plugin\n"); + } + */ + + size_t model_data_max = 1024 * 1024 * 1024; + arena model_arena = arena_create(malloc(model_data_max), model_data_max); + + model_pool model_pool = model_pool_create(&model_arena, 256, sizeof(model)); + g_core.models = model_pool; + INFO("Created model pool allocator"); + + INFO("Creating default scene"); + scene_init(&g_core.default_scene); +} + +#include <glfw3.h> + +/* bool should_window_close(core* core) { glfwWindowShouldClose(core->renderer.window); } */ +void core_input_update() { input_update(&g_core.input); } +void core_frame_begin(core* core) { render_frame_begin(&core->renderer); } +void core_frame_end(core* core) { render_frame_end(&core->renderer); } + +void core_shutdown() { + // threadpool_destroy(&core->threadpool); + input_system_shutdown(&g_core.input); + renderer_shutdown(&g_core.renderer); +} + +bool should_exit() { + return key_just_released(KEYCODE_ESCAPE) || glfwWindowShouldClose(g_core.renderer.window); +} + +void frame_begin() { + glfwPollEvents(); + render_frame_begin(&g_core.renderer); +} +void frame_draw() {} +void frame_end() { render_frame_end(&g_core.renderer); } diff --git a/src/core/core.h b/src/core/core.h new file mode 100644 index 0000000..89702fd --- /dev/null +++ b/src/core/core.h @@ -0,0 +1,40 @@ +#pragma once + +#include "input.h" +#include "render_types.h" +#include "scene.h" +#include "screenspace.h" +#include "terrain.h" +#include "text.h" +// #include "threadpool.h" + +typedef struct core { + const char* app_name; + // foundations + renderer renderer; + // threadpool threadpool; + // systems + input_state input; + text_system_state text; + terrain_state terrain; + screenspace_state screenspace; + // data storage + scene default_scene; + model_pool models; + // model_darray* models; +} core; + +core* get_global_core(); + +// --- Lifecycle + +/** @brief Throws error if the core cannot be instantiated */ +void core_bringup(); +void core_shutdown(); +bool should_exit(); + +void frame_begin(); +void frame_draw(); +void frame_end(); + +void core_input_update(); |