diff --git a/asset-src/gfx/background.piskel b/asset-src/gfx/background.piskel deleted file mode 100644 index 6977dd8..0000000 --- a/asset-src/gfx/background.piskel +++ /dev/null @@ -1 +0,0 @@ -{"modelVersion":2,"piskel":{"name":"background","description":"","fps":12,"height":450,"width":800,"layers":["{\"name\":\"Layer 1\",\"opacity\":1,\"frameCount\":1,\"chunks\":[{\"layout\":[[0]],\"base64PNG\":\"\"}]}"],"hiddenFrames":[""]}} \ No newline at end of file diff --git a/asset-src/gfx/background_pal.json b/asset-src/gfx/background_pal.json deleted file mode 100644 index 5e3149d..0000000 --- a/asset-src/gfx/background_pal.json +++ /dev/null @@ -1,9 +0,0 @@ -GIMP Palette -Name: Avoid_bg -Columns: 0 -# -248 248 248 Untitled -166 166 166 Untitled - 30 142 20 Untitled - 22 85 93 Untitled - diff --git a/assets/gfx/background.png b/assets/gfx/background.png deleted file mode 100644 index f9b0747..0000000 Binary files a/assets/gfx/background.png and /dev/null differ diff --git a/doc-assets/preview.gif b/doc-assets/preview.gif index 2f852cb..f3fadc0 100644 Binary files a/doc-assets/preview.gif and b/doc-assets/preview.gif differ diff --git a/src/Credits.c b/src/Credits.c index 3720a59..7e37931 100644 --- a/src/Credits.c +++ b/src/Credits.c @@ -10,7 +10,6 @@ #include "Screens.h" #include "Controls.h" -#include "Textures.h" void UpdateCreditsScreen(void) { @@ -19,11 +18,15 @@ void UpdateCreditsScreen(void) void DrawCreditsScreen(void) { - DrawTexture(background, 0, 0, DARKGRAY); - DrawText("CREDITS", 290, 20, 50, BLUE); + DrawRectangle(0, 0, GetScreenWidth(), GetScreenHeight(), GREEN); + + DrawText("Avoid", 330, 20, 50, MAGENTA); + DrawText("Programming and Art by Return0ne", 10, 210, 20, BLUE); + DrawText("Powered by raylib 4.0", 10, 240, 20, BLUE); - DrawText("A Canneddonuts project 2022", 10, 270, 40, BLUE); - DrawText(TextFormat("Build compiled on %s", __DATE__), 10, 310, 30, YELLOW); + + DrawText("A Canneddonuts project 2022", 10, 270, 40, RED); + DrawText("Press 'ENTER' ", 10, 350, 20, WHITE); } diff --git a/src/Gameover.c b/src/Gameover.c index 646a3ec..402404b 100644 --- a/src/Gameover.c +++ b/src/Gameover.c @@ -34,7 +34,7 @@ void UpdateGameoverScreen(void) void DrawGameoverScreen(void) { - DrawRectangle(0, 0, GetScreenWidth(), GetScreenHeight(), BLACK); + DrawRectangle(0, 0, GetScreenWidth(), GetScreenHeight(), BLUE); DrawText("GAMEOVER", 250, 20, 50, RED); if (gameoverSelected == 0) DrawText("RETRY", 350, 200, 20, WHITE); else DrawText("RETRY", 350, 200, 20, RED); diff --git a/src/Gameplay.c b/src/Gameplay.c index 25ca5f7..784c79b 100644 --- a/src/Gameplay.c +++ b/src/Gameplay.c @@ -12,7 +12,6 @@ #include "Controls.h" #include "Gameplay.h" #include "Score.h" -#include "Textures.h" int score = 0, bestscore = 0; @@ -39,14 +38,14 @@ void InitGameplayScreen(void) (float) player.sprite.height }; - heart.sprite = LoadTexture("assets/gfx/health.png"); - heart.hitbox = (Rectangle) { - GetRandomValue(0, GetScreenWidth() - heart.sprite.width), - GetRandomValue(0, GetScreenHeight() - heart.sprite.height), - (float) heart.sprite.width, - (float) heart.sprite.height + heart.sprite = LoadTexture("assets/gfx/health.png"); + heart.hitbox = (Rectangle) { + GetRandomValue(0, GetScreenWidth() - heart.sprite.width), + GetRandomValue(0, GetScreenHeight() - heart.sprite.height), + (float) heart.sprite.width, + (float) heart.sprite.height }; - heart.active = true; + heart.active = false; ball.position = (Vector2){ 50, 50 }; ball.speed = (Vector2){ 400.0f, 300.0f }; @@ -56,7 +55,7 @@ void InitGameplayScreen(void) ball.active = true; pause = 0; - mute = true; + mute = 0; DebugMode = 0; pauseTimer = 0; } @@ -79,8 +78,8 @@ void ResetGameplayScreen(void) GetRandomValue(0, GetScreenHeight() - heart.sprite.height), (float) heart.sprite.width, (float) heart.sprite.height - }; - heart.active = true; + }; + heart.active = false; ball.position = (Vector2){ 50, 50 }; ball.radius = 20; @@ -94,20 +93,20 @@ void ResetGameplayScreen(void) void UpdateGameplayScreen(void) { - if (IsKeyPressed(KEY_M)) mute = !mute; + if (IsKeyPressed(KEY_M)) mute = !mute; - if (INPUT_OPTION_PRESSED) pause = !pause; + if (INPUT_OPTION_PRESSED) pause = !pause; - if (!pause) { + if (!pause) { // Controls - if (INPUT_LEFT_DOWN) player.hitbox.x -= GetFrameTime() * player.speed; - if (INPUT_RIGHT_DOWN) player.hitbox.x += GetFrameTime() * player.speed; - if (INPUT_UP_DOWN) player.hitbox.y -= GetFrameTime() * player.speed; - if (INPUT_DOWN_DOWN) player.hitbox.y += GetFrameTime() * player.speed; - if (INPUT_DASH_DOWN) { - player.speed = 600.0f; - if (player.currentframe != 1) player.currentframe = 2; - } else player.speed = 300.0f; + if (INPUT_LEFT_DOWN) player.hitbox.x -= GetFrameTime() * player.speed; + if (INPUT_RIGHT_DOWN) player.hitbox.x += GetFrameTime() * player.speed; + if (INPUT_UP_DOWN) player.hitbox.y -= GetFrameTime() * player.speed; + if (INPUT_DOWN_DOWN) player.hitbox.y += GetFrameTime() * player.speed; + if (INPUT_DASH_DOWN) { + player.speed = 600.0f; + if (player.currentframe != 1) player.currentframe = 2; + } else player.speed = 300.0f; player.sprite_pos = (Vector2){ player.hitbox.x, player.hitbox.y }; @@ -115,7 +114,16 @@ void UpdateGameplayScreen(void) heart.sprite_pos = (Vector2){ heart.hitbox.x, heart.hitbox.y }; - if (score % 1000 == 0) heart.active = true; + if (score == 1000) heart.active = true; + if (score == 2000) heart.active = true; + if (score == 3000) heart.active = true; + if (score == 4000) heart.active = true; + if (score == 5000) heart.active = true; + if (score == 6000) heart.active = true; + if (score == 7000) heart.active = true; + if (score == 8000) heart.active = true; + if (score == 9000) heart.active = true; + if (score == 10000) heart.active = true; // Player to da wallz collies if ((player.hitbox.x + player.hitbox.width) >= GetScreenWidth()) player.hitbox.x = GetScreenWidth() - player.hitbox.width; @@ -149,13 +157,12 @@ void UpdateGameplayScreen(void) if (ball.active) { score++; - - if (score >= bestscore) bestscore = score; - // movement of the ball ball.position.x += GetFrameTime() * ball.speed.x; ball.position.y += GetFrameTime() * ball.speed.y; + if (score >= bestscore) bestscore = score; + // Ballz to da wallz collies if ((ball.position.x >= (GetScreenWidth() - ball.radius)) || (ball.position.x <= ball.radius)) { ball.speed.x *= -1.0f; @@ -181,7 +188,7 @@ void UpdateGameplayScreen(void) void DrawGameplayScreen(void) { - DrawTexture(background, 0, 0, RAYWHITE); + DrawRectangle(0, 0, GetScreenWidth(), GetScreenHeight(), BLACK); DrawFPS(10, 430); DrawText(TextFormat("HP: %i", player.hp), 10, 10, 20, RED); DrawText(TextFormat("SCORE: %i", score), 10, 30, 20, BLUE); @@ -194,7 +201,7 @@ void DrawGameplayScreen(void) } if (ball.active) DrawCircleV(ball.position, (float)ball.radius, ball.color); if (heart.active) DrawTexture(heart.sprite, heart.sprite_pos.x, heart.sprite_pos.y, RAYWHITE); - DrawTextureRec(player.sprite, player.frameRec, player.sprite_pos, RAYWHITE); + DrawTextureRec(player.sprite, player.frameRec, player.sprite_pos, WHITE); if (pause && ((pauseTimer/30)%2)) DrawText("PAUSED", 330, 190, 30, PURPLE); } diff --git a/src/Gameplay.h b/src/Gameplay.h index 67a4d05..f4b9041 100644 --- a/src/Gameplay.h +++ b/src/Gameplay.h @@ -9,16 +9,16 @@ #ifndef GAMEPLAY_HEADER #define GAMEPLAY_HEADER -struct Ball { +typedef struct Ball { Vector2 position; Vector2 speed; float radius; float growth; Color color; bool active; -}; +} Ball; -struct Player { +typedef struct Player { Texture2D sprite; float speed; int hp; @@ -26,20 +26,20 @@ struct Player { Vector2 sprite_pos; Rectangle frameRec; Rectangle hitbox; -}; +} Player; -struct Item { +typedef struct Item { Texture2D sprite; Vector2 sprite_pos; Rectangle hitbox; bool active; -}; +} Item; -struct Player player = { 0 }; -struct Ball ball = { 0 }; -struct Item heart = { 0 }; int pauseTimer; Sound fxbounce = { 0 }; +Player player = { 0 }; +Ball ball = { 0 }; +Item heart = { 0 }; bool pause; bool mute; bool DebugMode; diff --git a/src/Main.c b/src/Main.c index dc40c74..a1e9610 100644 --- a/src/Main.c +++ b/src/Main.c @@ -9,6 +9,8 @@ #include "../include/raylib.h" #include "Screens.h" +#include "Controls.h" + #if defined(PLATFORM_WEB) #include @@ -19,7 +21,7 @@ static const int screenWidth = 800; static const int screenHeight = 450; GameScreen currentScreen = 0; -Texture2D background = { 0 }; + // Game functions static void gameSetup(void); @@ -59,7 +61,6 @@ void gameSetup(void) currentScreen = TITLE; InitGameplayScreen(); - InitTitleScreen(); } void updateGame(void) @@ -67,7 +68,7 @@ void updateGame(void) // code that runs as long as the program is running if ((IsKeyDown(KEY_LEFT_ALT)) && (IsKeyPressed(KEY_F))) ToggleFullscreen(); - switch (currentScreen) { + switch(currentScreen) { case TITLE: UpdateTitleScreen(); break; case GAMEPLAY: UpdateGameplayScreen(); break; case GAMEOVER: UpdateGameoverScreen(); break; @@ -83,7 +84,7 @@ void drawGame(void) ClearBackground(RAYWHITE); - switch (currentScreen) { + switch(currentScreen) { case TITLE: DrawTitleScreen(); break; case GAMEPLAY: DrawGameplayScreen(); break; case GAMEOVER: DrawGameoverScreen(); break; @@ -103,5 +104,4 @@ void gameLoop(void) void unloadGame(void) { UnloadGameplayScreen(); - UnloadTitleScreen(); } diff --git a/src/Screens.h b/src/Screens.h index 86fa370..a8570eb 100644 --- a/src/Screens.h +++ b/src/Screens.h @@ -15,10 +15,8 @@ extern GameScreen currentScreen; void gameReset(void); -void InitTitleScreen(void); void UpdateTitleScreen(void); void DrawTitleScreen(void); -void UnloadTitleScreen(void); void InitGameplayScreen(void); diff --git a/src/Textures.h b/src/Textures.h deleted file mode 100644 index 3fdf1f4..0000000 --- a/src/Textures.h +++ /dev/null @@ -1,14 +0,0 @@ -/* -- Avoid ~ a game by Canneddonuts -- Filename ~ Textures.h -- Author ~ Return0ne -- 2022 -- *no license* -*/ - -#ifndef TEXTURES_HEADER -#define TEXTURES_HEADER - -extern Texture2D background; - -#endif diff --git a/src/Title.c b/src/Title.c index 1d55ae9..abbcbe3 100644 --- a/src/Title.c +++ b/src/Title.c @@ -11,15 +11,9 @@ #include "Screens.h" #include "Controls.h" #include "Score.h" -#include "Textures.h" int titleSelected = 0; -void InitTitleScreen(void) -{ - background = LoadTexture("assets/gfx/background.png"); -} - void UpdateTitleScreen(void) { if (INPUT_UP_PRESSED) titleSelected++; @@ -34,15 +28,15 @@ void UpdateTitleScreen(void) void DrawTitleScreen(void) { - DrawTexture(background, 0, 0, GRAY); - DrawText("Controls", 10, 10, 30, BLUE); + DrawRectangle(0, 0, GetScreenWidth(), GetScreenHeight(), ORANGE); + DrawText("Controls", 10, 10, 30, PURPLE); DrawText(TextFormat("BEST: %i", bestscore), 600, 0, 30, WHITE); - DrawText("Press the arrow keys or 'DPAD' to move and 'X' to dash", 10, 40, 10, WHITE); - DrawText("Press 'ENTER' or 'START' to pause", 10, 60, 10, WHITE); - DrawText("Press 'M' to mute", 10, 80, 10, WHITE); - DrawText("Press 'Left-ALT' + 'F' for full screen", 10, 100, 10, WHITE); - DrawText("Press 'R' to restart", 10, 120, 10, WHITE); - DrawText("Press 'ENTER' or 'START' to select an option", 10, 140, 10, WHITE); + DrawText("Press the arrow keys or 'DPAD' to move and 'X' to dash", 10, 40, 10, RED); + DrawText("Press 'ENTER' or 'START' to pause", 10, 60, 10, RED); + DrawText("Press 'M' to mute", 10, 80, 10, RED); + DrawText("Press 'Left-ALT' + 'F' for full screen", 10, 100, 10, RED); + DrawText("Press 'R' to restart", 10, 120, 10, RED); + DrawText("Press 'ENTER' or 'START' to select an option", 10, 140, 10, RED); DrawText("Avoid", 330, 20, 50, BLUE); if (titleSelected == 0) DrawText("PLAY", 360, 220, 20, WHITE); else DrawText("PLAY", 360, 220, 20, BLUE); @@ -53,8 +47,3 @@ void DrawTitleScreen(void) if (titleSelected == -2) DrawText("MORE GAMES", 320, 260, 20, WHITE); else DrawText("MORE GAMES", 320, 260, 20, BLUE); } - -void UnloadTitleScreen(void) -{ - UnloadTexture(background); -}