enemy hurt sprite and shorter feather wait times

This commit is contained in:
Return0ne 2022-07-15 12:59:37 -04:00
parent 21915fc0df
commit 851a13ce0d
8 changed files with 63 additions and 89 deletions

View file

@ -1 +1 @@
{"modelVersion":2,"piskel":{"name":"cat","description":"","fps":12,"height":50,"width":50,"layers":["{\"name\":\"Layer 1\",\"opacity\":1,\"frameCount\":1,\"chunks\":[{\"layout\":[[0]],\"base64PNG\":\"\"}]}"],"hiddenFrames":[""]}} {"modelVersion":2,"piskel":{"name":"cat","description":"","fps":12,"height":50,"width":50,"layers":["{\"name\":\"Layer 1\",\"opacity\":1,\"frameCount\":2,\"chunks\":[{\"layout\":[[0],[1]],\"base64PNG\":\"\"}]}"],"hiddenFrames":[""]}}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 228 B

After

Width:  |  Height:  |  Size: 453 B

View file

@ -17,21 +17,33 @@
int score = 0, bestscore = 0; int score = 0, bestscore = 0;
void LoadGamplayScreen(void)
{
fxhit = LoadSound("assets/sfx/hit.wav");
player_sprite = LoadTexture("assets/gfx/player.png");
enemy_sprite = LoadTexture("assets/gfx/enemy.png");
fxfeather = LoadSound("assets/sfx/feather.wav");
feather_sprite = LoadTexture("assets/gfx/feather.png");
attack_sprite = LoadTexture("assets/gfx/attack.png");
firework_sprite = LoadTexture("assets/gfx/firework.png");
fxboom = LoadSound("assets/sfx/boom.wav");
}
void InitGameplayScreen(void) void InitGameplayScreen(void)
{ {
SetMasterVolume(0.5); SetMasterVolume(0.5);
fxhit = LoadSound("assets/sfx/hit.wav");
player_sprite = LoadTexture("assets/gfx/player.png");
player.currentframe = 0; player.currentframe = 0;
player.speed = 300.0f; player.speed = 300.0f;
player.hp = PLAYER_HP; player.hp = PLAYER_HP;
if (GI_callcount < 1) {
player.frameRec = (Rectangle) { player.frameRec = (Rectangle) {
player.hitbox.x, player.hitbox.x,
player.hitbox.y, player.hitbox.y,
(float) player_sprite.width/3, (float) player_sprite.width/3,
(float) player_sprite.height (float) player_sprite.height
}; };
}
player.hitbox = (Rectangle) { player.hitbox = (Rectangle) {
0, 0,
100, 100,
@ -43,20 +55,27 @@ void InitGameplayScreen(void)
player.color = RAYWHITE; player.color = RAYWHITE;
player_flashtimer = 0; player_flashtimer = 0;
enemy_sprite = LoadTexture("assets/gfx/enemy.png");
enemy.currentframe = 0; enemy.currentframe = 0;
enemy.speed = 2.0f; enemy.speed = 2.0f;
enemy.hp = 30; enemy.hp = 30;
if (GI_callcount < 1) {
enemy.frameRec = (Rectangle) {
enemy.hitbox.x,
enemy.hitbox.y,
(float) enemy_sprite.width/2,
(float) enemy_sprite.height
};
}
enemy.hitbox = (Rectangle) { enemy.hitbox = (Rectangle) {
690, 690,
10, 10,
(float) enemy_sprite.width, (float) enemy_sprite.width/2,
(float) enemy_sprite.height (float) enemy_sprite.height
}; };
enemy.color = RAYWHITE; enemy.color = RAYWHITE;
enemy_hurt = false;
fxfeather = LoadSound("assets/sfx/feather.wav");
feather_sprite = LoadTexture("assets/gfx/feather.png");
feather.hitbox = (Rectangle) { feather.hitbox = (Rectangle) {
GetRandomValue(0, GetScreenWidth() - feather_sprite.width), GetRandomValue(0, GetScreenWidth() - feather_sprite.width),
GetRandomValue(0, GetScreenHeight() - feather_sprite.height), GetRandomValue(0, GetScreenHeight() - feather_sprite.height),
@ -67,7 +86,6 @@ void InitGameplayScreen(void)
feather.power = 0; feather.power = 0;
firework_sprite = LoadTexture("assets/gfx/firework.png");
for (int i = 0; i < MAX_FIREWORKS; i++) { for (int i = 0; i < MAX_FIREWORKS; i++) {
fireworks[i].speed.x = 300.0f; fireworks[i].speed.x = 300.0f;
fireworks[i].active = 0; fireworks[i].active = 0;
@ -80,8 +98,6 @@ void InitGameplayScreen(void)
fireworks[i].color = RAYWHITE; fireworks[i].color = RAYWHITE;
} }
attack_sprite = LoadTexture("assets/gfx/attack.png");
fxboom = LoadSound("assets/sfx/boom.wav");
for (int i = 0; i < MAX_SHOOTS; i++) { for (int i = 0; i < MAX_SHOOTS; i++) {
shoot[i].hitbox = (Rectangle) { shoot[i].hitbox = (Rectangle) {
player.hitbox.x, player.hitbox.x,
@ -97,75 +113,11 @@ void InitGameplayScreen(void)
ammo = 0; ammo = 0;
pause = 0; pause = 0;
mute = false;
DebugMode = 0;
pauseTimer = 0;
}
void ResetGameplayScreen(void)
{
// code to reset all variables without reloading assets
player.currentframe = 0;
player.speed = 300.0f;
player.hp = PLAYER_HP;
player.hitbox = (Rectangle) {
0,
100,
(float) player_sprite.width/3,
(float) player_sprite.height/2 + 5
};
player_iframeTimer = 0;
player_in = false;
player.color = RAYWHITE;
player_flashtimer = 0;
enemy.currentframe = 0;
enemy.speed = 2.0f;
enemy.hp = 30;
enemy.hitbox = (Rectangle) {
690,
10,
(float) enemy_sprite.width,
(float) enemy_sprite.height
};
feather.hitbox = (Rectangle) {
GetRandomValue(0, GetScreenWidth() - feather_sprite.width),
GetRandomValue(0, GetScreenHeight() - feather_sprite.height),
(float) feather_sprite.width,
(float) feather_sprite.height
};
feather.active = true;
feather.power = 0;
for (int i = 0; i < MAX_FIREWORKS; i++) {
fireworks[i].speed.x = 300.0f;
fireworks[i].active = 0;
fireworks[i].hitbox = (Rectangle) {
630,
GetRandomValue(0, GetScreenHeight()),
(float) firework_sprite.width/2 + 10,
(float) firework_sprite.height
};
}
for (int i = 0; i < MAX_SHOOTS; i++) {
shoot[i].hitbox = (Rectangle) {
player.hitbox.x,
player.hitbox.y,
(float) attack_sprite.width,
(float) attack_sprite.height
};
shoot[i].speed.x = 7;
shoot[i].speed.y = 0;
shoot[i].active = false;
shoot[i].color = RED;
}
ammo = 0;
DebugMode = 0; DebugMode = 0;
pauseTimer = 0; pauseTimer = 0;
score = 0; score = 0;
GI_callcount++;
} }
void DamagePlayer(void) void DamagePlayer(void)
@ -190,6 +142,15 @@ void UpdateiFrameTimer(void)
player_iframeTimer = 0; player_iframeTimer = 0;
} }
} else player.color = RAYWHITE; } else player.color = RAYWHITE;
if (enemy_hurt) {
enemy_frametimer++;
enemy.currentframe = 1;
if (enemy_frametimer >= 60) {
enemy_hurt = false;
enemy_frametimer = 0;
}
} else enemy.currentframe = 0;
} }
void UpdateGameplayScreen(void) void UpdateGameplayScreen(void)
@ -227,6 +188,8 @@ void UpdateGameplayScreen(void)
feather.sprite_pos = (Vector2){ feather.hitbox.x, feather.hitbox.y }; feather.sprite_pos = (Vector2){ feather.hitbox.x, feather.hitbox.y };
enemy.sprite_pos = (Vector2){ enemy.hitbox.x, enemy.hitbox.y }; enemy.sprite_pos = (Vector2){ enemy.hitbox.x, enemy.hitbox.y };
enemy.frameRec.x = (float)enemy.currentframe*(float)enemy_sprite.width/2;
player_flashtimer++; player_flashtimer++;
@ -239,7 +202,7 @@ void UpdateGameplayScreen(void)
} }
if (score % 1000 == 0) feather.active = true; if (score % 500 == 0) feather.active = true;
// Player to da wallz collies // Player to da wallz collies
if ((player.hitbox.x + player.hitbox.width) >= GetScreenWidth()) player.hitbox.x = GetScreenWidth() - player.hitbox.width; if ((player.hitbox.x + player.hitbox.width) >= GetScreenWidth()) player.hitbox.x = GetScreenWidth() - player.hitbox.width;
@ -254,6 +217,8 @@ void UpdateGameplayScreen(void)
if (IsKeyPressed(KEY_NINE)) ammo = 99; if (IsKeyPressed(KEY_NINE)) ammo = 99;
if (IsKeyPressed(KEY_ZERO)) ammo = 0; if (IsKeyPressed(KEY_ZERO)) ammo = 0;
if (IsKeyPressed(KEY_R)) { if (IsKeyPressed(KEY_R)) {
gameReset(); gameReset();
currentScreen = TITLE; currentScreen = TITLE;
@ -271,6 +236,7 @@ void UpdateGameplayScreen(void)
if (CheckCollisionRecs(shoot[i].hitbox, enemy.hitbox) && shoot[i].active) { if (CheckCollisionRecs(shoot[i].hitbox, enemy.hitbox) && shoot[i].active) {
// enemy.hp--; // enemy.hp--;
enemy_hurt = true;
score += 300; score += 300;
if (!mute) PlaySoundMulti(fxboom); if (!mute) PlaySoundMulti(fxboom);
shoot[i].active = false; shoot[i].active = false;
@ -361,7 +327,7 @@ void DrawGameplayScreen(void)
DrawText(TextFormat("player_in: %d", player_in), 10, 320, 20, GREEN); DrawText(TextFormat("player_in: %d", player_in), 10, 320, 20, GREEN);
} }
if (feather.active) DrawTexture(feather_sprite, feather.sprite_pos.x, feather.sprite_pos.y, feather.color); if (feather.active) DrawTexture(feather_sprite, feather.sprite_pos.x, feather.sprite_pos.y, feather.color);
DrawTexture(enemy_sprite, enemy.sprite_pos.x, enemy.sprite_pos.y, enemy.color); DrawTextureRec(enemy_sprite, enemy.frameRec, enemy.sprite_pos, enemy.color);
for (int i = 0; i < MAX_FIREWORKS; i++) { for (int i = 0; i < MAX_FIREWORKS; i++) {
DrawTexture(firework_sprite, fireworks[i].sprite_pos.x, fireworks[i].sprite_pos.y, fireworks[i].color); DrawTexture(firework_sprite, fireworks[i].sprite_pos.x, fireworks[i].sprite_pos.y, fireworks[i].color);
} }
@ -374,7 +340,8 @@ void DrawGameplayScreen(void)
DrawTexture(feather_sprite, 70, 0, RED); DrawTexture(feather_sprite, 70, 0, RED);
DrawText(TextFormat("= %i", ammo), 100, 30, 20, RED); DrawText(TextFormat("= %i", ammo), 100, 30, 20, RED);
// DrawText(TextFormat("ENEMY HP: %i", enemy.hp), GetScreenWidth() - 150, 10, 20, RED); // DrawText(TextFormat("ENEMY HP: %i", enemy.hp), GetScreenWidth() - 150, 10, 20, RED);
DrawText(TextFormat("SCORE: %i", score), 10, 65, 20, BLUE); if (score >= 10000) DrawText(TextFormat("SCORE: %i", score), 10, 65, 20, (Color){ 222, 181, 0, 255 });
else DrawText(TextFormat("SCORE: %i", score), 10, 65, 20, BLUE);
if (pause && ((pauseTimer/30)%2)) DrawText("PAUSED", 330, 190, 30, WHITE); if (pause && ((pauseTimer/30)%2)) DrawText("PAUSED", 330, 190, 30, WHITE);
} }
@ -392,6 +359,6 @@ void UnloadGameplayScreen()
void gameReset(void) void gameReset(void)
{ {
ResetGameplayScreen(); InitGameplayScreen();
InitGameoverScreen(); InitGameoverScreen();
} }

View file

@ -48,9 +48,12 @@ Sound fxhit = { 0 };
Sound fxfeather = { 0 }; Sound fxfeather = { 0 };
Sound fxboom = { 0 }; Sound fxboom = { 0 };
bool pause; bool pause;
bool mute; bool mute = false;
bool player_in; bool player_in;
bool enemy_hurt;
int ammo = 0; int ammo = 0;
int GI_callcount = 0;
bool DebugMode; bool DebugMode;

View file

@ -64,6 +64,7 @@ void gameSetup(void)
// asset loading & setting of variable values // asset loading & setting of variable values
currentScreen = TITLE; currentScreen = TITLE;
LoadGamplayScreen();
InitGameplayScreen(); InitGameplayScreen();
InitTitleScreen(); InitTitleScreen();
} }

View file

@ -25,7 +25,8 @@ void InitGameplayScreen(void);
void UpdateGameplayScreen(void); void UpdateGameplayScreen(void);
void DrawGameplayScreen(void); void DrawGameplayScreen(void);
void UnloadGameplayScreen(void); void UnloadGameplayScreen(void);
void ResetGameplayScreen(void); void LoadGamplayScreen(void);
void UpdateCreditsScreen(void); void UpdateCreditsScreen(void);
void DrawCreditsScreen(void); void DrawCreditsScreen(void);

View file

@ -12,5 +12,6 @@
int pauseTimer; int pauseTimer;
int player_iframeTimer; int player_iframeTimer;
int player_flashtimer; int player_flashtimer;
int enemy_frametimer;
#endif #endif

View file

@ -57,6 +57,7 @@ void DrawTitleScreen(void)
DrawText("Press 'ENTER' or 'START' to select an option", 10, 140, 10, WHITE); DrawText("Press 'ENTER' or 'START' to select an option", 10, 140, 10, WHITE);
DrawText("Press 'X' or 'A' on a gamepad to shoot", 10, 160, 10, WHITE); DrawText("Press 'X' or 'A' on a gamepad to shoot", 10, 160, 10, WHITE);
DrawText("Avoid", 330, 20, 50, BLUE); DrawText("Avoid", 330, 20, 50, BLUE);
// DrawText("Ver: 0.1", 680, 420, 30, WHITE);
if (titleSelected == 0) DrawText("PLAY", 360, 220, 20, WHITE); if (titleSelected == 0) DrawText("PLAY", 360, 220, 20, WHITE);
else DrawText("PLAY", 360, 220, 20, BLUE); else DrawText("PLAY", 360, 220, 20, BLUE);