diff options
Diffstat (limited to '')
-rw-r--r-- | src/main.cpp | 79 | ||||
-rw-r--r-- | src/yabs_core.cpp | 80 | ||||
-rw-r--r-- | src/yabs_core.h | 6 |
3 files changed, 88 insertions, 77 deletions
diff --git a/src/main.cpp b/src/main.cpp index 8033d5a..491e1c5 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -6,10 +6,6 @@ /* ()__)____________))))) :^} */ /*********************************/ -#include <stdlib.h> -#include "raylib.h" -#include "raymath.h" - #include "yabs_core.h" #include "yabs_utils.h" @@ -39,15 +35,6 @@ int main(void) { model.materials[0].maps[MATERIAL_MAP_DIFFUSE].texture = texture; // setup camera - SetCameraMode(sc3d.camera, CAMERA_FIRST_PERSON); // Set camera mode - sc3d.camera.position = (Vector3){50.0f, 1.0f, 50.0f}; - sc3d.camera.target = (Vector3){50.0f, 1.0f, 50.0f}; - sc3d.camera.up = (Vector3){0.0f, 1.0f, 0.0f}; - sc3d.camera.fovy = 90.0f; - sc3d.camera.projection = CAMERA_PERSPECTIVE; - - sc3d.rotation = (Vector3){0.0f, 0.0f, 0.0f}; - sc3d.lastMousePos = GetMousePosition(); SetTargetFPS(60); // game loop while (!WindowShouldClose()) { @@ -85,7 +72,7 @@ int main(void) { } case (yabs::GAMEPLAY): { while (game_state != yabs::NEXT) { - yabs::core::draw(game_state); + yabs::core::draw(game_state, model); } break; } @@ -96,76 +83,22 @@ int main(void) { break; } } - // mouse look - Vector2 mouseMovement = - Vector2Subtract(GetMousePosition(), sc3d.lastMousePos); - sc3d.lastMousePos = GetMousePosition(); - sc3d.rotation.x += - (mouseMovement.x * -YABS_CAMERA_MOUSE_MOVE_SENSITIVITY); - sc3d.rotation.y += - (mouseMovement.y * -YABS_CAMERA_MOUSE_MOVE_SENSITIVITY); - - // direction array - bool direction[4] = {IsKeyDown(KEY_W), IsKeyDown(KEY_S), - IsKeyDown(KEY_D), IsKeyDown(KEY_A)}; - - // compute movement - sc3d.movement = (Vector3){0, 0, 0}; - sc3d.movement.x = (sinf(sc3d.rotation.x) * direction[1] - - sinf(sc3d.rotation.x) * direction[0] - - cosf(sc3d.rotation.x) * direction[3] + - cosf(sc3d.rotation.x) * direction[2]) / - YABS_PLAYER_MOVEMENT_SENSITIVITY; - sc3d.movement.z = (cosf(sc3d.rotation.x) * direction[1] - - cosf(sc3d.rotation.x) * direction[0] + - sinf(sc3d.rotation.x) * direction[3] - - sinf(sc3d.rotation.x) * direction[2]) / - YABS_PLAYER_MOVEMENT_SENSITIVITY; - // elevation - if (IsKeyDown(KEY_SPACE)) - sc3d.movement.y += 0.12f; - if (IsKeyDown(KEY_LEFT_CONTROL)) - sc3d.movement.y -= 0.12f; - - // apply movement - sc3d.camera.position.x += - sc3d.movement.x / YABS_PLAYER_MOVEMENT_SENSITIVITY; - sc3d.camera.position.y += sc3d.movement.y; - sc3d.camera.position.z += - sc3d.movement.z / YABS_PLAYER_MOVEMENT_SENSITIVITY; - - Matrix translation = MatrixTranslate(0, 0, (10)); - Matrix rotation2 = MatrixRotateXYZ((Vector3){ - DOUBLEPI - sc3d.rotation.y, DOUBLEPI - sc3d.rotation.x, 0}); - Matrix transform = MatrixMultiply(translation, rotation2); - // apply camera rotation - sc3d.camera.target.x = sc3d.camera.position.x - transform.m12; - sc3d.camera.target.y = sc3d.camera.position.y - transform.m13; - sc3d.camera.target.z = sc3d.camera.position.z - transform.m14; + // draw BeginDrawing(); ClearBackground(GRAY); BeginMode3D(sc3d.camera); - - // draw checkerboard model - for (int x = 0; x < 50; x++) { - for (int z = 0; z < 50; z++) { - Vector3 position; - position.x = x; - position.y = 0; - position.z = z; - DrawModel(model, position, 1.0f, WHITE); - } - } - + yabs::core::tick(sc3d); + yabs::core::draw(game_state, model); EndMode3D(); DrawFPS(0, 0); DrawText("Controls: Mouse / WASD / SPACE/CTRL.", YABS_SCREENWIDTH - 400, 0, 20, DARKGRAY); + EndDrawing(); } UnloadTexture(texture); UnloadModel(model); CloseWindow(); - return 0; + return (0); } diff --git a/src/yabs_core.cpp b/src/yabs_core.cpp index 6252b14..8920f96 100644 --- a/src/yabs_core.cpp +++ b/src/yabs_core.cpp @@ -6,16 +6,92 @@ /* ()__)____________))))) :^} */ /*********************************/ +#include <stdlib.h> + #include "yabs_core.h" +#include "raymath.h" namespace yabs { namespace core { -int reset_camera(Scene3D const& scene_3d) { +int reset_camera(Scene3D & scene_3d) { + SetCameraMode(scene_3d.camera, CAMERA_FIRST_PERSON); + scene_3d.camera.position = (Vector3){50.0f, 1.0f, 50.0f}; + scene_3d.camera.target = (Vector3){50.0f, 1.0f, 50.0f}; + scene_3d.camera.up = (Vector3){0.0f, 1.0f, 0.0f}; + scene_3d.camera.fovy = 90.0f; + scene_3d.camera.projection = CAMERA_PERSPECTIVE; + + scene_3d.rotation = (Vector3){0.0f, 0.0f, 0.0f}; + scene_3d.lastMousePos = GetMousePosition(); + return (0); +} + +int draw(gameState const& game_state, Model & model) { + // draw checkerboard model + for (int x = 0; x < 50; x++) { + for (int z = 0; z < 50; z++) { + Vector3 position; + position.x = x; + position.y = 0; + position.z = z; + DrawModel(model, position, 1.0f, WHITE); + } + } + + // end draw return (0); } -int draw(gameState const& game_state) { +int tick(Scene3D & scene_3d) { + // mouse look + Vector2 mouseMovement = + Vector2Subtract(GetMousePosition(), scene_3d.lastMousePos); + scene_3d.lastMousePos = GetMousePosition(); + scene_3d.rotation.x += + (mouseMovement.x * -YABS_CAMERA_MOUSE_MOVE_SENSITIVITY); + scene_3d.rotation.y += + (mouseMovement.y * -YABS_CAMERA_MOUSE_MOVE_SENSITIVITY); + + // direction array + bool direction[4] = {IsKeyDown(KEY_W), IsKeyDown(KEY_S), + IsKeyDown(KEY_D), IsKeyDown(KEY_A)}; + + // compute movement + scene_3d.movement = (Vector3){0, 0, 0}; + scene_3d.movement.x = (sinf(scene_3d.rotation.x) * direction[1] - + sinf(scene_3d.rotation.x) * direction[0] - + cosf(scene_3d.rotation.x) * direction[3] + + cosf(scene_3d.rotation.x) * direction[2]) / + YABS_PLAYER_MOVEMENT_SENSITIVITY; + scene_3d.movement.z = (cosf(scene_3d.rotation.x) * direction[1] - + cosf(scene_3d.rotation.x) * direction[0] + + sinf(scene_3d.rotation.x) * direction[3] - + sinf(scene_3d.rotation.x) * direction[2]) / + YABS_PLAYER_MOVEMENT_SENSITIVITY; + // elevation + if (IsKeyDown(KEY_SPACE)) + scene_3d.movement.y += 0.12f; + if (IsKeyDown(KEY_LEFT_CONTROL)) + scene_3d.movement.y -= 0.12f; + + // apply movement + scene_3d.camera.position.x += + scene_3d.movement.x / YABS_PLAYER_MOVEMENT_SENSITIVITY; + scene_3d.camera.position.y += scene_3d.movement.y; + scene_3d.camera.position.z += + scene_3d.movement.z / YABS_PLAYER_MOVEMENT_SENSITIVITY; + + Matrix translation = MatrixTranslate(0, 0, (10)); + Matrix rotation2 = MatrixRotateXYZ((Vector3){ + YABS_DOUBLEPI - scene_3d.rotation.y, YABS_DOUBLEPI - scene_3d.rotation.x, 0}); + Matrix transform = MatrixMultiply(translation, rotation2); + + // apply camera rotation + scene_3d.camera.target.x = scene_3d.camera.position.x - transform.m12; + scene_3d.camera.target.y = scene_3d.camera.position.y - transform.m13; + scene_3d.camera.target.z = scene_3d.camera.position.z - transform.m14; + return (0); } diff --git a/src/yabs_core.h b/src/yabs_core.h index 15a6d4c..73c7543 100644 --- a/src/yabs_core.h +++ b/src/yabs_core.h @@ -43,9 +43,11 @@ namespace core { // draw takes a reference to the game_state, which is checked on each frame // for next level or death -int reset_camera(Scene3D const& scene_3d); +int reset_camera(Scene3D & scene_3d); -int draw(gameState const& game_state); +int draw(gameState const& game_state, Model & model); + +int tick(Scene3D & scene_3d); } // namespace core |