enemy hurt sprite and shorter feather wait times
This commit is contained in:
parent
21915fc0df
commit
851a13ce0d
8 changed files with 63 additions and 89 deletions
|
@ -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 |
125
src/Gameplay.c
125
src/Gameplay.c
|
@ -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();
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
|
||||||
|
|
|
@ -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();
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue