2023-01-04 14:37:54 +03:00
|
|
|
#pragma once
|
2023-01-04 14:56:03 +03:00
|
|
|
#include <SFML/Window.hpp>
|
|
|
|
#include <SFML/Graphics.hpp>
|
|
|
|
class Paddle;
|
|
|
|
class Ball;
|
2023-01-04 14:37:54 +03:00
|
|
|
class Arkanoid;
|
|
|
|
|
2023-01-04 13:46:41 +03:00
|
|
|
class Bonus
|
|
|
|
{
|
2023-01-06 00:44:44 +03:00
|
|
|
protected:
|
2023-01-04 13:46:41 +03:00
|
|
|
inline static const float speed = 120;
|
|
|
|
inline static const float radius = 15;
|
|
|
|
|
|
|
|
sf::Vector2f m_position;
|
|
|
|
float m_time;
|
|
|
|
|
|
|
|
public:
|
|
|
|
Bonus(sf::Vector2f position);
|
|
|
|
void update(float dt);
|
2023-01-07 14:44:06 +03:00
|
|
|
virtual void draw(sf::RenderWindow& window) const = 0;
|
|
|
|
virtual void activate(Arkanoid& game) = 0;
|
|
|
|
virtual ~Bonus() = default;
|
2023-01-04 13:46:41 +03:00
|
|
|
|
|
|
|
bool isColiding(const Paddle& paddle) const;
|
|
|
|
// Класс Arkanoid должен быть дружественным, так как он может менять внутреннее объекта-бонуса
|
|
|
|
friend class Arkanoid;
|
|
|
|
};
|
|
|
|
|
2023-01-06 00:44:44 +03:00
|
|
|
class TripleBallBonus : public Bonus {
|
|
|
|
public:
|
|
|
|
TripleBallBonus(sf::Vector2f position): Bonus(position) {};
|
|
|
|
void draw(sf::RenderWindow& window) const;
|
|
|
|
void activate(Arkanoid& game);
|
|
|
|
};
|
|
|
|
|
|
|
|
class EnlargePaddleBonus : public Bonus {
|
|
|
|
public:
|
|
|
|
EnlargePaddleBonus(sf::Vector2f position): Bonus(position) {};
|
|
|
|
void draw(sf::RenderWindow& window) const;
|
|
|
|
void activate(Arkanoid& game);
|
|
|
|
};
|
|
|
|
|
|
|
|
class ShrinkPaddleBonus : public Bonus {
|
|
|
|
public:
|
|
|
|
ShrinkPaddleBonus(sf::Vector2f position): Bonus(position) {};
|
|
|
|
void draw(sf::RenderWindow& window) const;
|
|
|
|
void activate(Arkanoid& game);
|
|
|
|
};
|
|
|
|
|
|
|
|
class SlowingBonus : public Bonus {
|
|
|
|
private:
|
|
|
|
double mDuration = 10;
|
|
|
|
public:
|
|
|
|
SlowingBonus(sf::Vector2f position): Bonus(position) {};
|
|
|
|
void draw(sf::RenderWindow& window) const;
|
|
|
|
void activate(Arkanoid& game);
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Effects
|
|
|
|
* */
|
2023-01-07 14:44:06 +03:00
|
|
|
#define _EFFECT_SLOWING_ID 0
|
2023-01-06 00:44:44 +03:00
|
|
|
class Effect {
|
2023-01-07 14:44:06 +03:00
|
|
|
protected:
|
2023-01-07 12:33:46 +03:00
|
|
|
char effectId;
|
2023-01-06 00:44:44 +03:00
|
|
|
double mStartTime;
|
|
|
|
double mDuration;
|
|
|
|
public:
|
2023-01-07 12:33:46 +03:00
|
|
|
Effect(char id, double start_time, double duration);
|
2023-01-07 14:44:06 +03:00
|
|
|
virtual ~Effect() = default;
|
|
|
|
|
|
|
|
virtual void activate(Arkanoid& game) = 0;
|
|
|
|
virtual void activate(Ball& ball) = 0;
|
|
|
|
virtual void deactivate(Arkanoid& game) = 0;
|
2023-01-06 00:44:44 +03:00
|
|
|
bool isExpired(double time);
|
2023-01-07 12:33:46 +03:00
|
|
|
|
2023-01-07 14:44:06 +03:00
|
|
|
|
2023-01-07 12:33:46 +03:00
|
|
|
friend class SlowingBonus;
|
|
|
|
friend class TripleBallBonus;
|
|
|
|
friend class Arkanoid;
|
2023-01-06 00:44:44 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
class SlowingEffect : public Effect {
|
|
|
|
private:
|
2023-01-07 14:44:06 +03:00
|
|
|
float mSlowingFactor = 0.1;
|
|
|
|
char id = _EFFECT_SLOWING_ID;
|
2023-01-06 00:44:44 +03:00
|
|
|
public:
|
|
|
|
SlowingEffect(double start_time, double duration);
|
|
|
|
void activate(Arkanoid& game);
|
2023-01-07 12:33:46 +03:00
|
|
|
void activate(Ball& ball);
|
2023-01-06 00:44:44 +03:00
|
|
|
void deactivate(Arkanoid& game);
|
|
|
|
};
|