Compare commits
22 Commits
5Przeciwni
...
refactor
| Author | SHA1 | Date | |
|---|---|---|---|
| 6b45443c75 | |||
| c4c83382c3 | |||
| 0a5a26208a | |||
| 76203a8b29 | |||
| 36984b859f | |||
| 15a8d82176 | |||
| 5459b97e74 | |||
| 94eddb457f | |||
| 9432cd94fe | |||
| 34424da9d6 | |||
| 80a4b1b397 | |||
| fdf67f4bc2 | |||
| 8b4b25747e | |||
| 3f4a937257 | |||
| d87143d98b | |||
| 1298bab79a | |||
| 9929a5dd40 | |||
| da33fcc718 | |||
| 74c739a09e | |||
| 71f8ebe285 | |||
| 2f9e0ba236 | |||
| 3b637508e1 |
@@ -40,6 +40,8 @@ add_executable(LotoStatek main.cpp
|
|||||||
sources/Wiazkowiec.cpp
|
sources/Wiazkowiec.cpp
|
||||||
headers/Beam.h
|
headers/Beam.h
|
||||||
sources/Beam.cpp
|
sources/Beam.cpp
|
||||||
|
headers/Heart.hpp
|
||||||
|
sources/Heart.cpp
|
||||||
)
|
)
|
||||||
|
|
||||||
if(WIN32)
|
if(WIN32)
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 11 KiB After Width: | Height: | Size: 2.1 KiB |
|
Before Width: | Height: | Size: 8.3 KiB After Width: | Height: | Size: 1.7 KiB |
BIN
assets/img/bullets/old/bomba.png
Normal file
|
After Width: | Height: | Size: 11 KiB |
BIN
assets/img/bullets/old/enemy_bullet.png
Normal file
|
After Width: | Height: | Size: 8.3 KiB |
|
Before Width: | Height: | Size: 12 KiB After Width: | Height: | Size: 30 KiB |
|
Before Width: | Height: | Size: 11 KiB After Width: | Height: | Size: 32 KiB |
|
Before Width: | Height: | Size: 18 KiB After Width: | Height: | Size: 20 KiB |
|
Before Width: | Height: | Size: 6.1 KiB After Width: | Height: | Size: 21 KiB |
BIN
assets/img/enemy/old/advanced_enemy.png
Normal file
|
After Width: | Height: | Size: 12 KiB |
BIN
assets/img/enemy/old/bomber.png
Normal file
|
After Width: | Height: | Size: 11 KiB |
BIN
assets/img/enemy/old/enemy.png
Normal file
|
After Width: | Height: | Size: 18 KiB |
BIN
assets/img/enemy/old/kamikadze.png
Normal file
|
After Width: | Height: | Size: 6.1 KiB |
BIN
assets/img/enemy/old/wiazkowiec.png
Normal file
|
After Width: | Height: | Size: 7.9 KiB |
|
Before Width: | Height: | Size: 7.9 KiB After Width: | Height: | Size: 28 KiB |
BIN
assets/img/hearts/heart_gray.png
Normal file
|
After Width: | Height: | Size: 958 B |
|
Before Width: | Height: | Size: 773 B |
BIN
assets/ship/nova.png
Normal file
|
After Width: | Height: | Size: 154 KiB |
BIN
assets/ship/pulsar.png
Normal file
|
After Width: | Height: | Size: 188 KiB |
BIN
assets/ship/zenith.png
Normal file
|
After Width: | Height: | Size: 221 KiB |
@@ -5,17 +5,18 @@
|
|||||||
#include "SFML/Graphics/Texture.hpp"
|
#include "SFML/Graphics/Texture.hpp"
|
||||||
#include "Bullet.h"
|
#include "Bullet.h"
|
||||||
#include "Position.h"
|
#include "Position.h"
|
||||||
|
#include "SFML/System/Clock.hpp"
|
||||||
|
|
||||||
|
|
||||||
class Actor {
|
class Actor {
|
||||||
public:
|
public:
|
||||||
Actor(int x, int y, const sf::Texture& texture);
|
Actor(int x, int y, const sf::Texture& texture);
|
||||||
|
virtual ~Actor() = default;
|
||||||
void loadTexture(std::string path);
|
|
||||||
|
|
||||||
sf::Sprite& getSprite();
|
sf::Sprite& getSprite();
|
||||||
|
unsigned int getHP();
|
||||||
Position getPosition();
|
Position getPosition();
|
||||||
|
std::vector<Bullet>& getBullets();
|
||||||
|
|
||||||
virtual void move(float deltaX, float deltaY) = 0;
|
virtual void move(float deltaX, float deltaY) = 0;
|
||||||
virtual void moveLeft() = 0;
|
virtual void moveLeft() = 0;
|
||||||
@@ -24,23 +25,23 @@ public:
|
|||||||
virtual void moveDown() = 0;
|
virtual void moveDown() = 0;
|
||||||
virtual void shoot() = 0;
|
virtual void shoot() = 0;
|
||||||
|
|
||||||
std::vector<Bullet>& getBullets();
|
|
||||||
|
|
||||||
void updateBullets();
|
void updateBullets();
|
||||||
|
|
||||||
void setMovingSpeed(float speed);
|
void setMovingSpeed(float speed);
|
||||||
|
void dealDamage();
|
||||||
|
void healUP();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
Position position;
|
||||||
sf::Sprite actorSprite;
|
sf::Sprite actorSprite;
|
||||||
sf::Texture actorTexture;
|
sf::Texture actorTexture;
|
||||||
sf::Texture bulletTextureLeft;
|
sf::Texture bulletTexture;
|
||||||
sf::Texture bulletTextureRight;
|
sf::Texture rocketTexture;
|
||||||
Position position;
|
std::vector<Bullet> bullets;
|
||||||
unsigned int hp;
|
sf::Clock damageDealClock;
|
||||||
|
int hp;
|
||||||
unsigned int damage;
|
unsigned int damage;
|
||||||
unsigned int firerate;
|
unsigned int firerate;
|
||||||
float moving_speed;
|
float moving_speed;
|
||||||
std::vector<Bullet> bullets;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif //ACTOR_H
|
#endif //ACTOR_H
|
||||||
|
|||||||
@@ -3,8 +3,6 @@
|
|||||||
|
|
||||||
#include "Enemy.h"
|
#include "Enemy.h"
|
||||||
|
|
||||||
#include <cmath>
|
|
||||||
|
|
||||||
enum class DirectionA {
|
enum class DirectionA {
|
||||||
Up,
|
Up,
|
||||||
Down,
|
Down,
|
||||||
|
|||||||
@@ -2,27 +2,16 @@
|
|||||||
#define LOTOSTATEK_BEAM_H
|
#define LOTOSTATEK_BEAM_H
|
||||||
|
|
||||||
#include <SFML/Graphics.hpp>
|
#include <SFML/Graphics.hpp>
|
||||||
#include "Position.h"
|
|
||||||
|
|
||||||
class Beam {
|
class Beam {
|
||||||
public:
|
public:
|
||||||
Beam(float x, float y, float width, float height, const sf::Color& color);
|
Beam() = default;
|
||||||
|
Beam(int x, int y, const sf::Texture &texture);
|
||||||
void draw(sf::RenderWindow &window);
|
|
||||||
|
|
||||||
void update();
|
|
||||||
void render(sf::RenderWindow& window);
|
|
||||||
|
|
||||||
sf::FloatRect getBounds() const;
|
|
||||||
|
|
||||||
bool isVisible() const;
|
|
||||||
void setVisible(bool visible);
|
|
||||||
|
|
||||||
|
sf::Sprite getSprite();
|
||||||
|
|
||||||
|
void setRotation(float angle);
|
||||||
private:
|
private:
|
||||||
sf::RectangleShape beamShape;
|
|
||||||
bool visible;
|
|
||||||
sf::Texture beamTexture;
|
|
||||||
sf::Sprite beamSprite;
|
sf::Sprite beamSprite;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -2,14 +2,11 @@
|
|||||||
#define LOTOSTATEK_BULLET_H
|
#define LOTOSTATEK_BULLET_H
|
||||||
|
|
||||||
#include "Projectile.h"
|
#include "Projectile.h"
|
||||||
#include "SFML/Graphics/Texture.hpp"
|
|
||||||
|
|
||||||
class Bullet : public Projectile {
|
class Bullet : public Projectile {
|
||||||
public:
|
public:
|
||||||
Bullet(float x, float y, sf::Texture &texture) : Projectile(x,y, texture) {};
|
Bullet(float x, float y, sf::Texture &texture) : Projectile(x,y, texture) {};
|
||||||
void update() override;
|
void update() override;
|
||||||
private:
|
|
||||||
float directionY;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
13
headers/Heart.hpp
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
#ifndef LOTOSTATEK_HEART_HPP
|
||||||
|
#define LOTOSTATEK_HEART_HPP
|
||||||
|
|
||||||
|
#include "SFML/Graphics/Texture.hpp"
|
||||||
|
#include "ObjectItem.hpp"
|
||||||
|
|
||||||
|
class Heart : public ObjectItem {
|
||||||
|
public:
|
||||||
|
Heart(float x, float y, sf::Texture &texture);
|
||||||
|
void update() override;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif //LOTOSTATEK_HEART_HPP
|
||||||
@@ -8,7 +8,7 @@
|
|||||||
|
|
||||||
class Meteor : public ObjectItem {
|
class Meteor : public ObjectItem {
|
||||||
public:
|
public:
|
||||||
Meteor(float x, float y, sf::Texture &texture);
|
Meteor(float x, float y, sf::Texture &texture_);
|
||||||
void update();
|
void update();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -12,7 +12,7 @@ public:
|
|||||||
bool getStatus();
|
bool getStatus();
|
||||||
virtual void update() = 0;
|
virtual void update() = 0;
|
||||||
protected:
|
protected:
|
||||||
sf::Texture texture;
|
sf::Texture texture_;
|
||||||
sf::Sprite sprite;
|
sf::Sprite sprite;
|
||||||
Position position;
|
Position position;
|
||||||
float rotationSpeed;
|
float rotationSpeed;
|
||||||
|
|||||||
@@ -1,75 +1,93 @@
|
|||||||
#ifndef PLANSZA_H
|
#ifndef PLANSZA_H
|
||||||
#define PLANSZA_H
|
#define PLANSZA_H
|
||||||
|
|
||||||
|
#include "SFML/System/Clock.hpp"
|
||||||
|
#include "SFML/Graphics/RenderWindow.hpp"
|
||||||
|
|
||||||
#include "Meteor.h"
|
#include "Meteor.h"
|
||||||
#include "Enemy.h"
|
#include "Enemy.h"
|
||||||
#include "AdvancedEnemy.h"
|
#include "AdvancedEnemy.h"
|
||||||
#include "Bomber.h"
|
#include "Bomber.h"
|
||||||
#include "Kamikadze.h"
|
#include "Kamikadze.h"
|
||||||
#include "Wiazkowiec.h"
|
#include "Wiazkowiec.h"
|
||||||
#include "Beam.h"
|
|
||||||
#include "RandomNumberGenerator.h"
|
|
||||||
#include "SFML/System/Clock.hpp"
|
|
||||||
#include "SFML/Graphics/RenderWindow.hpp"
|
|
||||||
#include "Size.h"
|
|
||||||
#include <memory>
|
|
||||||
|
|
||||||
#include "Player.h"
|
#include "Player.h"
|
||||||
#include "Background.h"
|
#include "Background.h"
|
||||||
#include "AudioManager.h"
|
#include "AudioManager.h"
|
||||||
#include "Meteor.h"
|
|
||||||
#include "Plansza.h"
|
#include "Plansza.h"
|
||||||
|
#include "Heart.hpp"
|
||||||
|
#include "Size.h"
|
||||||
|
|
||||||
|
enum ships{
|
||||||
|
nova,
|
||||||
|
pulsar,
|
||||||
|
zenith,
|
||||||
|
none
|
||||||
|
};
|
||||||
|
|
||||||
class Plansza {
|
class Plansza {
|
||||||
public:
|
public:
|
||||||
Plansza(unsigned int windowHeight, unsigned int windowWidth, sf::RenderWindow *mainWindow,
|
Plansza(unsigned int windowHeight, unsigned int windowWidth, sf::RenderWindow *mainWindow, ships selectedShip);
|
||||||
const sf::Texture& playerTexture, const sf::Texture& playerBulletTexture, const sf::Texture& playerRocketTexture);
|
|
||||||
Size getSize();
|
Size getSize();
|
||||||
std::vector<Meteor> &getMeteors();
|
std::vector<Meteor> &getMeteors();
|
||||||
|
|
||||||
|
|
||||||
void spawn_meteor();
|
void spawn_meteor();
|
||||||
|
void spawn_hearts();
|
||||||
void update_meteors();
|
void update_meteors();
|
||||||
|
void update_hearts();
|
||||||
void update();
|
void update();
|
||||||
|
void update_score();
|
||||||
|
void spawn_player();
|
||||||
void spawn_enemy();
|
void spawn_enemy();
|
||||||
void setOutOfBounds(bool status);
|
|
||||||
void spawn_advanced_enemy();
|
void spawn_advanced_enemy();
|
||||||
void spawn_wiazkowiec();
|
void spawn_wiazkowiec();
|
||||||
void spawn_bomber();
|
void spawn_bomber();
|
||||||
void spawn_kamikadze();
|
void spawn_kamikadze();
|
||||||
|
~Plansza() {
|
||||||
|
delete ship; // usuwanie wskaźnika ship
|
||||||
|
}
|
||||||
|
|
||||||
|
static ships selectedShip;
|
||||||
|
static unsigned int score;
|
||||||
private:
|
private:
|
||||||
Size size;
|
|
||||||
Background background;
|
Background background;
|
||||||
Player ship;
|
|
||||||
AudioManager audioManager;
|
AudioManager audioManager;
|
||||||
sf::Texture meteorTexture1;
|
Player *ship;
|
||||||
sf::Texture meteorTexture2;
|
Size size;
|
||||||
sf::Texture enemyBulletTexture;
|
sf::RenderWindow *window;
|
||||||
sf::Texture WiazkaTexture;
|
sf::Font font;
|
||||||
sf::Texture BombaTexture;
|
sf::Clock meteorSpawnClock;
|
||||||
sf::Texture playerTexture;
|
sf::Clock heartSpawnClock;
|
||||||
sf::Texture playerBulletTexture;
|
|
||||||
sf::Texture playerRocketTexture;
|
|
||||||
sf::Texture enemyTexture;
|
|
||||||
sf::Texture advancedEnemyTexture;
|
|
||||||
sf::Texture BomberEnemyTexture;
|
|
||||||
sf::Texture KamikadzeTexture;
|
|
||||||
sf::Texture WiazkowiecTexture;
|
|
||||||
sf::Clock spawnClock;
|
sf::Clock spawnClock;
|
||||||
|
sf::Clock scoreClock;
|
||||||
sf::Clock shooterSpawnClock;
|
sf::Clock shooterSpawnClock;
|
||||||
std::vector<Enemy> enemies;
|
|
||||||
std::vector<AdvancedEnemy> AEnemies;
|
|
||||||
std::vector<Bomber> BEnemies;
|
|
||||||
std::vector<Kamikadze> KEnemies;
|
|
||||||
std::vector<Wiazkowiec> WEnemies;
|
|
||||||
sf::Clock enemySpawnClock;
|
sf::Clock enemySpawnClock;
|
||||||
sf::Clock AenemySpawnClock;
|
sf::Clock AenemySpawnClock;
|
||||||
sf::Clock BomberSpawnClock;
|
sf::Clock BomberSpawnClock;
|
||||||
sf::Clock KamikadzeSpawnClock;
|
sf::Clock KamikadzeSpawnClock;
|
||||||
sf::Clock WiazkowiecSpawnClock;
|
sf::Clock WiazkowiecSpawnClock;
|
||||||
|
sf::Texture playerTexture;
|
||||||
|
sf::Texture playerBulletTexture;
|
||||||
|
sf::Texture playerRocketTexture;
|
||||||
|
sf::Texture enemyTexture;
|
||||||
|
sf::Texture enemyBulletTexture;
|
||||||
|
sf::Texture advancedEnemyTexture;
|
||||||
|
sf::Texture BomberEnemyTexture;
|
||||||
|
sf::Texture BombaTexture;
|
||||||
|
sf::Texture KamikadzeTexture;
|
||||||
|
sf::Texture WiazkowiecTexture;
|
||||||
|
sf::Texture WiazkaTexture;
|
||||||
|
sf::Texture meteorTexture1;
|
||||||
|
sf::Texture meteorTexture2;
|
||||||
|
sf::Texture heartTexture;
|
||||||
|
sf::Texture heartTextureGray;
|
||||||
|
std::vector<Enemy> enemies;
|
||||||
|
std::vector<AdvancedEnemy> AEnemies;
|
||||||
|
std::vector<Bomber> BEnemies;
|
||||||
|
std::vector<Kamikadze> KEnemies;
|
||||||
|
std::vector<Wiazkowiec> WEnemies;
|
||||||
std::vector<Meteor> meteors;
|
std::vector<Meteor> meteors;
|
||||||
sf::RenderWindow *window;
|
std::vector<Heart> hearts;
|
||||||
|
std::vector<sf::Sprite> heartStats;
|
||||||
|
bool gameOver = false;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif //PLANSZA_H
|
#endif //PLANSZA_H
|
||||||
|
|||||||
@@ -9,9 +9,17 @@
|
|||||||
#include "Rocket.h"
|
#include "Rocket.h"
|
||||||
|
|
||||||
class Player : public Actor {
|
class Player : public Actor {
|
||||||
|
// Zgodnie z refactoring.guru singleton pattern
|
||||||
|
// https://refactoring.guru/design-patterns/singleton/cpp/example
|
||||||
|
protected:
|
||||||
|
Player(int x, int y, const sf::Texture &texture);
|
||||||
|
static Player* player_;
|
||||||
public:
|
public:
|
||||||
Player(int x, int y, const sf::Texture& texture, const sf::Texture& bulletTexture, const sf::Texture& rocketTexture);
|
Player(Player &other) = delete;
|
||||||
void setTextures(const sf::Texture& shipTexture, const sf::Texture& bulletTexture, const sf::Texture& rocketTexture);
|
void operator=(const Player &) = delete;
|
||||||
|
static Player* getInstance(int x, int y, const sf::Texture &texture);
|
||||||
|
// Tu się kończy definicja singletona
|
||||||
|
|
||||||
void shoot() override;
|
void shoot() override;
|
||||||
void alternate_shoot();
|
void alternate_shoot();
|
||||||
void setFirerate(unsigned int firerate);
|
void setFirerate(unsigned int firerate);
|
||||||
@@ -21,18 +29,21 @@ public:
|
|||||||
void moveUp() override;
|
void moveUp() override;
|
||||||
void moveDown() override;
|
void moveDown() override;
|
||||||
void takeDamage();
|
void takeDamage();
|
||||||
bool isAlive() const;
|
|
||||||
void update();
|
void update();
|
||||||
std::vector<Rocket>& getRockets();
|
std::vector<Rocket>& getRockets();
|
||||||
|
|
||||||
|
void loadTexture();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::chrono::steady_clock::time_point lastShotTime = std::chrono::steady_clock::now();
|
std::chrono::steady_clock::time_point lastShotTime = std::chrono::steady_clock::now();
|
||||||
std::vector<Rocket> rockets;
|
std::vector<Rocket> rockets;
|
||||||
sf::Texture rocketTexture;
|
sf::Texture rocketTexture;
|
||||||
int health = 3; // Liczba punktów życia gracza
|
|
||||||
sf::Texture bulletTexture;
|
sf::Texture bulletTexture;
|
||||||
bool isImmortal = false; // flaga na immortal
|
sf::Color originalColor;
|
||||||
sf::Clock immortalityClock; // Zegar kontrolujący czas nieśmiertelności
|
sf::Clock immortalityClock; // Zegar kontrolujący czas nieśmiertelności
|
||||||
float immortalityDuration = 1.5f; // Czas trwania nieśmiertelności w sec
|
float immortalityDuration = 1.5f; // Czas trwania nieśmiertelności w sec
|
||||||
|
bool isImmortal = false; // flaga na immortal
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -6,4 +6,14 @@ struct Position {
|
|||||||
int y;
|
int y;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct PositionU {
|
||||||
|
unsigned int x;
|
||||||
|
unsigned int y;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct PositionF {
|
||||||
|
float x;
|
||||||
|
float y;
|
||||||
|
};
|
||||||
|
|
||||||
#endif //LOTOSTATEK_POSITION_H
|
#endif //LOTOSTATEK_POSITION_H
|
||||||
|
|||||||
@@ -13,42 +13,47 @@ enum class DirectionW {
|
|||||||
|
|
||||||
class Wiazkowiec : public Actor {
|
class Wiazkowiec : public Actor {
|
||||||
public:
|
public:
|
||||||
Wiazkowiec(int x, int y, const sf::Texture& texture);
|
Wiazkowiec(int x, int y, const sf::Texture& texture, sf::RenderWindow *window);
|
||||||
|
|
||||||
void shoot() override;
|
|
||||||
void move(float deltaX, float deltaY) override;
|
void move(float deltaX, float deltaY) override;
|
||||||
void moveLeft() override;
|
void moveLeft() override;
|
||||||
void moveRight() override;
|
void moveRight() override;
|
||||||
void moveUp() override;
|
void moveUp() override;
|
||||||
void moveDown() override;
|
void moveDown() override;
|
||||||
|
|
||||||
|
void takeDamage();
|
||||||
|
|
||||||
void setRandomDirection();
|
void setRandomDirection();
|
||||||
|
void checkIfBeamShootOutOfBounds();
|
||||||
|
|
||||||
void update();
|
void update();
|
||||||
|
void shoot() override;
|
||||||
void render(sf::RenderWindow &window);
|
void render(sf::RenderWindow &window);
|
||||||
|
|
||||||
bool isAlive() const;
|
bool isAlive() const;
|
||||||
void takeDamage();
|
|
||||||
void updateDirection();
|
|
||||||
bool isShooting() const;
|
bool isShooting() const;
|
||||||
const Beam& getBeam() const;
|
|
||||||
void setPlanszaHeight(float height, float width);
|
|
||||||
void setMapBounds(float width, float height);
|
|
||||||
|
|
||||||
|
void setPlanszaHeight(int height, int width);
|
||||||
|
Beam* getBeam() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
float planszaHeight = 800.f;
|
|
||||||
float planszaWidth = 600.f;
|
|
||||||
sf::Clock shootClock;
|
|
||||||
sf::Texture WiazkaTexture;
|
sf::Texture WiazkaTexture;
|
||||||
float movementSpeed = 2.0f;
|
sf::Texture beamTexture;
|
||||||
bool alive = true;
|
sf::Clock shootClock;
|
||||||
DirectionW direction = DirectionW::Down;
|
|
||||||
Beam beam; // Wiązka
|
|
||||||
bool shooting = false;
|
|
||||||
sf::Clock shootingClock;
|
sf::Clock shootingClock;
|
||||||
float beamDuration = 1.0f;
|
DirectionW direction = DirectionW::Down;
|
||||||
|
|
||||||
|
Beam *beam; // wskaźnik na wiązkę
|
||||||
|
sf::RenderWindow *window_ptr;
|
||||||
|
|
||||||
void spawnBeam(); // Tworzy wiązkę
|
void spawnBeam(); // Tworzy wiązkę
|
||||||
|
|
||||||
|
int planszaHeight = 800;
|
||||||
|
int planszaWidth = 600;
|
||||||
|
float beamDuration = 1.0f;
|
||||||
|
float movementSpeed = 2.0f;
|
||||||
|
bool shooting = false;
|
||||||
|
bool alive = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif //WIAZKOWIEC_H
|
#endif //WIAZKOWIEC_H
|
||||||
|
|||||||
167
main.cpp
@@ -3,16 +3,14 @@
|
|||||||
|
|
||||||
#include "headers/Plansza.h"
|
#include "headers/Plansza.h"
|
||||||
|
|
||||||
int main()
|
ships selectedShip = none;
|
||||||
{
|
|
||||||
|
void menu();
|
||||||
|
|
||||||
|
int main() {
|
||||||
|
menu();
|
||||||
|
|
||||||
std::clog << "Game started\n";
|
std::clog << "Game started\n";
|
||||||
sf::Texture playerTexture, playerBulletTexture, playerRocketTexture;
|
|
||||||
if (!playerTexture.loadFromFile("../assets/ship/Dreadnought-Base.png") ||
|
|
||||||
!playerBulletTexture.loadFromFile("../assets/img/bullets/bullet_pink.png") ||
|
|
||||||
!playerRocketTexture.loadFromFile("../assets/img/rockets/Rocket_111.png")) {
|
|
||||||
std::cerr << "Failed to load player textures!" << std::endl;
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
sf::RenderWindow mainWindow(sf::VideoMode(600, 800), "LotoStatek");
|
sf::RenderWindow mainWindow(sf::VideoMode(600, 800), "LotoStatek");
|
||||||
mainWindow.setVerticalSyncEnabled(true);
|
mainWindow.setVerticalSyncEnabled(true);
|
||||||
mainWindow.setFramerateLimit(60);
|
mainWindow.setFramerateLimit(60);
|
||||||
@@ -22,8 +20,7 @@ int main()
|
|||||||
mainWindow.setIcon(128, 128, icon.getPixelsPtr());
|
mainWindow.setIcon(128, 128, icon.getPixelsPtr());
|
||||||
|
|
||||||
|
|
||||||
|
Plansza plansza(mainWindow.getSize().y, mainWindow.getSize().x, &mainWindow, selectedShip);
|
||||||
Plansza plansza(mainWindow.getSize().y, mainWindow.getSize().x, &mainWindow,playerTexture, playerBulletTexture, playerRocketTexture);
|
|
||||||
|
|
||||||
while (mainWindow.isOpen()) {
|
while (mainWindow.isOpen()) {
|
||||||
mainWindow.clear();
|
mainWindow.clear();
|
||||||
@@ -31,7 +28,7 @@ int main()
|
|||||||
// Tu są handlowane eventy
|
// Tu są handlowane eventy
|
||||||
sf::Event event{};
|
sf::Event event{};
|
||||||
while (mainWindow.pollEvent(event)) {
|
while (mainWindow.pollEvent(event)) {
|
||||||
if(event.type == sf::Event::Closed || sf::Keyboard::isKeyPressed(sf::Keyboard::Escape))
|
if (event.type == sf::Event::Closed || sf::Keyboard::isKeyPressed(sf::Keyboard::Escape))
|
||||||
mainWindow.close();
|
mainWindow.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -41,4 +38,148 @@ int main()
|
|||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void menu() {
|
||||||
|
sf::RenderWindow menuWindow(sf::VideoMode(800, 400), "LotoStatek->Menu");
|
||||||
|
// Ustawienia ikonki okna
|
||||||
|
sf::Image icon;
|
||||||
|
icon.loadFromFile("../assets/img/icon/ikonka.png");
|
||||||
|
menuWindow.setIcon(128, 128, icon.getPixelsPtr());
|
||||||
|
|
||||||
|
// start button
|
||||||
|
sf::RectangleShape startButton(sf::Vector2f(140, 50));
|
||||||
|
startButton.setPosition(50, 20);
|
||||||
|
startButton.setFillColor(sf::Color::White);
|
||||||
|
|
||||||
|
|
||||||
|
sf::Font font;
|
||||||
|
if (!font.loadFromFile("../assets/fonts/arial.ttf")) {
|
||||||
|
std::cerr << "Nie można załadować czcionki\n";
|
||||||
|
exit(-1);
|
||||||
|
}
|
||||||
|
// tekst dla start button
|
||||||
|
sf::Text startText("Start", font, 24);
|
||||||
|
startText.setFillColor(sf::Color::Black);
|
||||||
|
startText.setPosition(startButton.getSize().x / 2 + 20, startButton.getSize().y / 2 + 5);
|
||||||
|
|
||||||
|
|
||||||
|
// exit button
|
||||||
|
sf::RectangleShape exitButton(sf::Vector2f(140, 50));
|
||||||
|
exitButton.setPosition(600, 20);
|
||||||
|
exitButton.setFillColor(sf::Color::White);
|
||||||
|
|
||||||
|
sf::Text exitText("Exit", font, 24);
|
||||||
|
exitText.setFillColor(sf::Color::Black);
|
||||||
|
exitText.setPosition(exitButton.getPosition().x + 45, exitButton.getPosition().y + 10);
|
||||||
|
|
||||||
|
|
||||||
|
sf::Texture pulsarTexture;
|
||||||
|
pulsarTexture.loadFromFile("../assets/ship/pulsar.png");
|
||||||
|
sf::Sprite pulsarSprite(pulsarTexture);
|
||||||
|
pulsarSprite.setPosition(50, 200);
|
||||||
|
pulsarSprite.setScale(0.25f, 0.25f);
|
||||||
|
|
||||||
|
sf::Texture novaTexture;
|
||||||
|
novaTexture.loadFromFile("../assets/ship/nova.png");
|
||||||
|
sf::Sprite novaSprite(novaTexture);
|
||||||
|
novaSprite.setPosition(330, 200);
|
||||||
|
novaSprite.setScale(0.25f, 0.25f);
|
||||||
|
|
||||||
|
sf::Texture zenithTexture;
|
||||||
|
zenithTexture.loadFromFile("../assets/ship/zenith.png");
|
||||||
|
sf::Sprite zenithSprite(zenithTexture);
|
||||||
|
zenithSprite.setPosition(600, 200);
|
||||||
|
zenithSprite.setScale(0.25f, 0.25f);
|
||||||
|
|
||||||
|
sf::RectangleShape pulsarBorder(sf::Vector2f(pulsarSprite.getGlobalBounds().width + 4,
|
||||||
|
pulsarSprite.getGlobalBounds().height + 4));
|
||||||
|
pulsarBorder.setPosition(pulsarSprite.getPosition().x - 2, pulsarSprite.getPosition().y - 2);
|
||||||
|
pulsarBorder.setFillColor(sf::Color::Transparent);
|
||||||
|
pulsarBorder.setOutlineThickness(2);
|
||||||
|
pulsarBorder.setOutlineColor(sf::Color::Transparent);
|
||||||
|
|
||||||
|
sf::RectangleShape novaBorder(sf::Vector2f(novaSprite.getGlobalBounds().width + 4,
|
||||||
|
novaSprite.getGlobalBounds().height + 4));
|
||||||
|
novaBorder.setPosition(novaSprite.getPosition().x - 2, novaSprite.getPosition().y - 2);
|
||||||
|
novaBorder.setFillColor(sf::Color::Transparent);
|
||||||
|
novaBorder.setOutlineThickness(2);
|
||||||
|
novaBorder.setOutlineColor(sf::Color::Transparent);
|
||||||
|
|
||||||
|
sf::RectangleShape zenithBorder(sf::Vector2f(zenithSprite.getGlobalBounds().width + 4,
|
||||||
|
zenithSprite.getGlobalBounds().height + 4));
|
||||||
|
zenithBorder.setPosition(zenithSprite.getPosition().x - 2, zenithSprite.getPosition().y - 2);
|
||||||
|
zenithBorder.setFillColor(sf::Color::Transparent);
|
||||||
|
zenithBorder.setOutlineThickness(2);
|
||||||
|
zenithBorder.setOutlineColor(sf::Color::Transparent);
|
||||||
|
|
||||||
|
while (menuWindow.isOpen()) {
|
||||||
|
sf::Event event{};
|
||||||
|
while (menuWindow.pollEvent(event)) {
|
||||||
|
if (event.type == sf::Event::Closed || sf::Keyboard::isKeyPressed(sf::Keyboard::Escape)) {
|
||||||
|
menuWindow.close();
|
||||||
|
exit(-2);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (event.type == sf::Event::MouseButtonPressed) {
|
||||||
|
if (event.mouseButton.button == sf::Mouse::Left) {
|
||||||
|
sf::Vector2i mousePos = sf::Mouse::getPosition(menuWindow);
|
||||||
|
if (startButton.getGlobalBounds().contains(static_cast<sf::Vector2f>(mousePos))) {
|
||||||
|
std::cout << "Przycisk Start zostal kliknięty\n";
|
||||||
|
menuWindow.close();
|
||||||
|
}
|
||||||
|
if (exitButton.getGlobalBounds().contains(static_cast<sf::Vector2f>(mousePos))) {
|
||||||
|
std::cout << "Przycisk Exit zostal kliknięty\n";
|
||||||
|
menuWindow.close();
|
||||||
|
exit(-2);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (pulsarSprite.getGlobalBounds().contains(static_cast<sf::Vector2f>(mousePos))) {
|
||||||
|
pulsarBorder.setOutlineColor(sf::Color::White);
|
||||||
|
selectedShip = pulsar;
|
||||||
|
} else {
|
||||||
|
pulsarBorder.setOutlineColor(sf::Color::Transparent);
|
||||||
|
}
|
||||||
|
if (novaSprite.getGlobalBounds().contains(static_cast<sf::Vector2f>(mousePos))) {
|
||||||
|
novaBorder.setOutlineColor(sf::Color::White);
|
||||||
|
selectedShip = nova;
|
||||||
|
} else {
|
||||||
|
novaBorder.setOutlineColor(sf::Color::Transparent);
|
||||||
|
}
|
||||||
|
if (zenithSprite.getGlobalBounds().contains(static_cast<sf::Vector2f>(mousePos))) {
|
||||||
|
zenithBorder.setOutlineColor(sf::Color::White);
|
||||||
|
selectedShip = zenith;
|
||||||
|
} else {
|
||||||
|
zenithBorder.setOutlineColor(sf::Color::Transparent);
|
||||||
|
}
|
||||||
|
if (!pulsarSprite.getGlobalBounds().contains(static_cast<sf::Vector2f>(mousePos)) &&
|
||||||
|
!novaSprite.getGlobalBounds().contains(static_cast<sf::Vector2f>(mousePos)) &&
|
||||||
|
!zenithSprite.getGlobalBounds().contains(static_cast<sf::Vector2f>(mousePos)) &&
|
||||||
|
!startButton.getGlobalBounds().contains(static_cast<sf::Vector2f>(mousePos)) &&
|
||||||
|
!exitButton.getGlobalBounds().contains(static_cast<sf::Vector2f>(mousePos))) {
|
||||||
|
selectedShip = none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
menuWindow.clear();
|
||||||
|
|
||||||
|
menuWindow.draw(startButton);
|
||||||
|
menuWindow.draw(startText);
|
||||||
|
|
||||||
|
menuWindow.draw(exitButton);
|
||||||
|
menuWindow.draw(exitText);
|
||||||
|
|
||||||
|
menuWindow.draw(pulsarSprite);
|
||||||
|
menuWindow.draw(novaSprite);
|
||||||
|
menuWindow.draw(zenithSprite);
|
||||||
|
|
||||||
|
menuWindow.draw(pulsarBorder);
|
||||||
|
menuWindow.draw(novaBorder);
|
||||||
|
menuWindow.draw(zenithBorder);
|
||||||
|
|
||||||
|
menuWindow.display();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
@@ -10,14 +10,6 @@ Actor::Actor(int x, int y, const sf::Texture& texture) {
|
|||||||
actorSprite.setPosition(float(x), float(y));
|
actorSprite.setPosition(float(x), float(y));
|
||||||
}
|
}
|
||||||
|
|
||||||
void Actor::loadTexture(std::string path) {
|
|
||||||
actorTexture.loadFromFile(path);
|
|
||||||
actorSprite.setTexture(actorTexture);
|
|
||||||
|
|
||||||
bulletTextureLeft.loadFromFile("../assets/img/bullets/bullet_pink.png");
|
|
||||||
bulletTextureRight.loadFromFile("../assets/img/rockets/Rocket_111.png");
|
|
||||||
}
|
|
||||||
|
|
||||||
sf::Sprite &Actor::getSprite() {
|
sf::Sprite &Actor::getSprite() {
|
||||||
if (!actorSprite.getTexture()) {
|
if (!actorSprite.getTexture()) {
|
||||||
std::cerr << "actorSprite has no texture set!" << std::endl;
|
std::cerr << "actorSprite has no texture set!" << std::endl;
|
||||||
@@ -29,6 +21,25 @@ Position Actor::getPosition() {
|
|||||||
return {position.x, position.y};
|
return {position.x, position.y};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
unsigned int Actor::getHP() {
|
||||||
|
return hp;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Actor::dealDamage() {
|
||||||
|
if(damageDealClock.getElapsedTime().asSeconds() > 1.5) {
|
||||||
|
if(hp > 0) {
|
||||||
|
hp--;
|
||||||
|
}
|
||||||
|
damageDealClock.restart();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Actor::healUP() {
|
||||||
|
if(hp < 3){
|
||||||
|
hp++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
std::vector<Bullet> &Actor::getBullets() {
|
std::vector<Bullet> &Actor::getBullets() {
|
||||||
return bullets;
|
return bullets;
|
||||||
}
|
}
|
||||||
@@ -47,4 +58,4 @@ void Actor::updateBullets() {
|
|||||||
|
|
||||||
void Actor::setMovingSpeed(float speed) {
|
void Actor::setMovingSpeed(float speed) {
|
||||||
moving_speed = speed;
|
moving_speed = speed;
|
||||||
}
|
}
|
||||||
@@ -1,8 +1,8 @@
|
|||||||
#include "../headers/AdvancedEnemy.h"
|
#include "../headers/AdvancedEnemy.h"
|
||||||
#include "../headers/Bullet.h"
|
#include "../headers/Bullet.h"
|
||||||
|
#include "../headers/Plansza.h"
|
||||||
|
|
||||||
AdvancedEnemy::AdvancedEnemy(int x, int y, const sf::Texture& texture, const sf::Texture& bulletTexture) : Actor(x, y, texture) {
|
AdvancedEnemy::AdvancedEnemy(int x, int y, const sf::Texture& texture, const sf::Texture& bulletTexture) : Actor(x, y, texture) {
|
||||||
actorSprite.setTexture(texture);
|
|
||||||
enemyBulletTexture = bulletTexture;
|
enemyBulletTexture = bulletTexture;
|
||||||
hp = 2; // 2 punkty życia
|
hp = 2; // 2 punkty życia
|
||||||
firerate = 2000; // Strzela co 2
|
firerate = 2000; // Strzela co 2
|
||||||
@@ -85,5 +85,6 @@ bool AdvancedEnemy::isAlive() const {
|
|||||||
void AdvancedEnemy::takeDamage() {
|
void AdvancedEnemy::takeDamage() {
|
||||||
if (--hp <= 0) {
|
if (--hp <= 0) {
|
||||||
alive = false;
|
alive = false;
|
||||||
|
Plansza::score += 10;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -2,50 +2,21 @@
|
|||||||
|
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
|
||||||
Beam::Beam(float x, float y, float width, float height, const sf::Color& color)
|
Beam::Beam(int x, int y, const sf::Texture& texture) {
|
||||||
: visible(false) {
|
beamSprite.setOrigin(beamSprite.getLocalBounds().width/2, beamSprite.getLocalBounds().height/2);
|
||||||
beamShape.setPosition(x, y);
|
if (texture.getSize().x > 0 && texture.getSize().y > 0) {
|
||||||
beamShape.setSize({width, height});
|
|
||||||
beamShape.setFillColor(color);
|
|
||||||
|
|
||||||
if (!beamTexture.loadFromFile("../assets/img/wiazka/wiazka.png")) {
|
|
||||||
std::cerr << "Błąd! Nie można załadować tekstury wiazka.png" << std::endl;
|
|
||||||
}
|
|
||||||
beamSprite.setTexture(beamTexture);
|
|
||||||
|
|
||||||
if (beamTexture.getSize().x > 0 && beamTexture.getSize().y > 0) {
|
|
||||||
float scaleX = width / beamTexture.getSize().x;
|
|
||||||
float scaleY = height / beamTexture.getSize().y;
|
|
||||||
beamSprite.setScale(scaleX, scaleY);
|
|
||||||
beamSprite.setPosition(x, y);
|
beamSprite.setPosition(x, y);
|
||||||
} else {
|
} else {
|
||||||
std::cerr << "Błąd: Tekstura wiązki nie została poprawnie załadowana." << std::endl;
|
std::cerr << "Błąd: Tekstura wiązki nie została poprawnie załadowana." << std::endl;
|
||||||
}
|
}
|
||||||
|
beamSprite.setTexture(texture);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Beam::draw(sf::RenderWindow& window) {
|
sf::Sprite Beam::getSprite() {
|
||||||
|
return beamSprite;
|
||||||
window.draw(beamSprite);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Beam::update() {
|
void Beam::setRotation(float angle) {
|
||||||
}
|
beamSprite.setRotation(angle);
|
||||||
|
|
||||||
void Beam::render(sf::RenderWindow& window) {
|
|
||||||
window.draw(beamSprite);
|
|
||||||
}
|
|
||||||
|
|
||||||
sf::FloatRect Beam::getBounds() const {
|
|
||||||
return beamShape.getGlobalBounds();
|
|
||||||
}
|
|
||||||
|
|
||||||
bool Beam::isVisible() const {
|
|
||||||
return visible;
|
|
||||||
}
|
|
||||||
|
|
||||||
void Beam::setVisible(bool visible) {
|
|
||||||
this->visible = visible;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
#include "../headers/Bomber.h"
|
#include "../headers/Bomber.h"
|
||||||
#include "../headers/Bullet.h"
|
#include "../headers/Bullet.h"
|
||||||
|
#include "../headers/Plansza.h"
|
||||||
#include <random>
|
#include <random>
|
||||||
|
|
||||||
Bomber::Bomber(int x, int y, const sf::Texture& texture, const sf::Texture& bulletTexture) : Actor(x, y, texture) {
|
Bomber::Bomber(int x, int y, const sf::Texture& texture, const sf::Texture& bulletTexture) : Actor(x, y, texture) {
|
||||||
actorSprite.setTexture(texture);
|
|
||||||
BombaTexture = bulletTexture;
|
BombaTexture = bulletTexture;
|
||||||
hp = 2; // 2 punkty życia
|
hp = 2; // 2 punkty życia
|
||||||
firerate = 10000; // Strzela co 10
|
firerate = 10000; // Strzela co 10
|
||||||
@@ -121,5 +121,6 @@ bool Bomber::isAlive() const {
|
|||||||
void Bomber::takeDamage() {
|
void Bomber::takeDamage() {
|
||||||
if (--hp <= 0) {
|
if (--hp <= 0) {
|
||||||
alive = false;
|
alive = false;
|
||||||
|
Plansza::score += 15;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1,8 +1,5 @@
|
|||||||
#include "../headers/Bullet.h"
|
#include "../headers/Bullet.h"
|
||||||
|
|
||||||
#include <iostream>
|
|
||||||
#include <ostream>
|
|
||||||
|
|
||||||
void Bullet::update() {
|
void Bullet::update() {
|
||||||
//std::cout << "Start update: speed = " << speed << ", position.y = " << position.y << std::endl;
|
//std::cout << "Start update: speed = " << speed << ", position.y = " << position.y << std::endl;
|
||||||
sprite.move(0.0f, speed);
|
sprite.move(0.0f, speed);
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
#include "../headers/Enemy.h"
|
#include "../headers/Enemy.h"
|
||||||
#include "../headers/Bullet.h"
|
#include "../headers/Bullet.h"
|
||||||
|
#include "../headers/Plansza.h"
|
||||||
|
|
||||||
Enemy::Enemy(int x, int y, const sf::Texture& texture) : Actor(x, y, texture) {
|
Enemy::Enemy(int x, int y, const sf::Texture& texture) : Actor(x, y, texture) {
|
||||||
actorSprite.setTexture(texture);
|
|
||||||
hp = 1; // Przeciwnik ma 1 punkt życia
|
hp = 1; // Przeciwnik ma 1 punkt życia
|
||||||
firerate = 2000; // Strzela co 2
|
firerate = 2000; // Strzela co 2
|
||||||
moving_speed = 2.0f; // Prędkość
|
moving_speed = 2.0f; // Prędkość
|
||||||
@@ -75,5 +75,6 @@ bool Enemy::isAlive() const {
|
|||||||
void Enemy::takeDamage() {
|
void Enemy::takeDamage() {
|
||||||
if (--hp <= 0) {
|
if (--hp <= 0) {
|
||||||
alive = false;
|
alive = false;
|
||||||
|
Plansza::score += 5;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
23
sources/Heart.cpp
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
#include "../headers/Heart.hpp"
|
||||||
|
|
||||||
|
Heart::Heart(float x, float y, sf::Texture &texture) : ObjectItem(x,y,texture) {
|
||||||
|
outOfBounds = false;
|
||||||
|
texture = texture;
|
||||||
|
sprite.setTexture(texture);
|
||||||
|
sprite.setOrigin(sprite.getLocalBounds().width / 2, sprite.getLocalBounds().height / 2); // wycentrowanie sprite
|
||||||
|
sprite.setPosition(x, y);
|
||||||
|
movingSpeed = 3.0f;
|
||||||
|
// sprite.scale(0.05f, 0.05f);
|
||||||
|
position.x = x;
|
||||||
|
position.y = y;
|
||||||
|
rotationSpeed = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Heart::update() {
|
||||||
|
sprite.move(0.0f, movingSpeed); // przesunięcie sprajta
|
||||||
|
position.y += int(movingSpeed); // przesunięcie pozycji
|
||||||
|
// sprite.rotate(rotationSpeed); // obracanie tym meteorkiem pięknym
|
||||||
|
if(position.y > 900) {
|
||||||
|
outOfBounds = true; // jeżeli wyszedł poza granice ekranu ustaw tą zmienną
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,12 +1,12 @@
|
|||||||
#include "../headers/Kamikadze.h"
|
|
||||||
|
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <random>
|
#include <random>
|
||||||
|
#include "../headers/Kamikadze.h"
|
||||||
#include "../headers/RandomNumberGenerator.h"
|
#include "../headers/RandomNumberGenerator.h"
|
||||||
|
#include "../headers/Plansza.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Kamikadze::Kamikadze(int x, int y, const sf::Texture& texture) : Actor(x, y, texture) {
|
Kamikadze::Kamikadze(int x, int y, const sf::Texture& texture) : Actor(x, y, texture) {
|
||||||
actorSprite.setTexture(texture);
|
|
||||||
hp = 3; // 3 punkty życia
|
hp = 3; // 3 punkty życia
|
||||||
moving_speed = 2.0f; // Prędkość
|
moving_speed = 2.0f; // Prędkość
|
||||||
}
|
}
|
||||||
@@ -130,5 +130,6 @@ bool Kamikadze::isAlive() const {
|
|||||||
void Kamikadze::takeDamage() {
|
void Kamikadze::takeDamage() {
|
||||||
if (--hp <= 0) {
|
if (--hp <= 0) {
|
||||||
alive = false;
|
alive = false;
|
||||||
|
Plansza::score += 20;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
Meteor::Meteor(float x, float y, sf::Texture &texture) : ObjectItem(x, y, texture) {
|
Meteor::Meteor(float x, float y, sf::Texture &texture) : ObjectItem(x, y, texture) {
|
||||||
outOfBounds = false;
|
outOfBounds = false;
|
||||||
texture = texture;
|
texture_ = texture;
|
||||||
sprite.setTexture(texture);
|
sprite.setTexture(texture);
|
||||||
sprite.setOrigin(sprite.getLocalBounds().width / 2, sprite.getLocalBounds().height / 2); // wycentrowanie sprite
|
sprite.setOrigin(sprite.getLocalBounds().width / 2, sprite.getLocalBounds().height / 2); // wycentrowanie sprite
|
||||||
sprite.setPosition(x, y);
|
sprite.setPosition(x, y);
|
||||||
|
|||||||
@@ -1,11 +1,11 @@
|
|||||||
#include "../headers/ObjectItem.hpp"
|
#include "../headers/ObjectItem.hpp"
|
||||||
|
|
||||||
ObjectItem::ObjectItem(float x, float y, sf::Texture &texture) {
|
ObjectItem::ObjectItem(float x, float y, sf::Texture &texture) {
|
||||||
Position position_;
|
Position position_ = {0,0};
|
||||||
position_.x = x;
|
position_.x = static_cast<int>(x);
|
||||||
position_.y = y;
|
position_.y = static_cast<int>(y);
|
||||||
position = position_;
|
position = position_;
|
||||||
this->texture = texture;
|
this->texture_ = texture;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ObjectItem::getStatus() {
|
bool ObjectItem::getStatus() {
|
||||||
|
|||||||
@@ -1,22 +1,47 @@
|
|||||||
#include <random>
|
#include <random>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include "../headers/Plansza.h"
|
#include "../headers/Plansza.h"
|
||||||
#include "../headers/ObjectItem.hpp"
|
#include "../headers/RandomNumberGenerator.h"
|
||||||
|
|
||||||
Plansza::Plansza(unsigned int windowHeight, unsigned int windowWidth, sf::RenderWindow *mainWindow,
|
Plansza::Plansza(unsigned int windowHeight, unsigned int windowWidth, sf::RenderWindow *mainWindow, ships selectedShip)
|
||||||
const sf::Texture& playerTexture,
|
: background("../assets/img/background/background.png", 2.0f) {
|
||||||
const sf::Texture& playerBulletTexture,
|
|
||||||
const sf::Texture& playerRocketTexture)
|
|
||||||
: background("../assets/img/background/background.png", 2.0f),
|
|
||||||
ship(static_cast<int>(mainWindow->getSize().x) / 2, static_cast<int>(mainWindow->getSize().y) - 100,
|
|
||||||
playerTexture, playerBulletTexture, playerRocketTexture) {
|
|
||||||
window = mainWindow;
|
window = mainWindow;
|
||||||
size.height = static_cast<int>(windowHeight);
|
size.height = static_cast<int>(windowHeight);
|
||||||
size.width = static_cast<int>(windowWidth);
|
size.width = static_cast<int>(windowWidth);
|
||||||
|
|
||||||
|
Plansza::selectedShip = selectedShip;
|
||||||
|
|
||||||
ship.setMovingSpeed(8);
|
try {
|
||||||
ship.setFirerate(200);
|
if(selectedShip == nova) {
|
||||||
|
playerTexture.loadFromFile("../assets/ship/nova.png");
|
||||||
|
} else if(selectedShip == pulsar) {
|
||||||
|
playerTexture.loadFromFile("../assets/ship/pulsar.png");
|
||||||
|
} else if(selectedShip == zenith) {
|
||||||
|
playerTexture.loadFromFile("../assets/ship/zenith.png");
|
||||||
|
} else {
|
||||||
|
playerTexture.loadFromFile("../assets/ship/Dreadnought-Base.png");
|
||||||
|
}
|
||||||
|
meteorTexture1.loadFromFile("../assets/img/meteors/meteor-1.png");
|
||||||
|
meteorTexture2.loadFromFile("../assets/img/meteors/meteor-2.png");
|
||||||
|
// Ładowanie tekstur wrogów
|
||||||
|
enemyTexture.loadFromFile("../assets/img/enemy/enemy.png");
|
||||||
|
advancedEnemyTexture.loadFromFile("../assets/img/enemy/advanced_enemy.png");
|
||||||
|
BomberEnemyTexture.loadFromFile("../assets/img/enemy/bomber.png");
|
||||||
|
KamikadzeTexture.loadFromFile("../assets/img/enemy/kamikadze.png");
|
||||||
|
BombaTexture.loadFromFile("../assets/img/bullets/bomba.png");
|
||||||
|
WiazkowiecTexture.loadFromFile("../assets/img/enemy/wiazkowiec.png");
|
||||||
|
} catch (std::exception &e) {
|
||||||
|
std::cerr << "Failed to load textures: " << e.what() << std::endl;
|
||||||
|
exit(-500);
|
||||||
|
}
|
||||||
|
|
||||||
|
score = 0;
|
||||||
|
|
||||||
|
// Wczytywanie czcionki dla licznika punktów
|
||||||
|
if (!font.loadFromFile("../assets/fonts/arial.ttf")) {
|
||||||
|
std::cerr << "Error loading font\n";
|
||||||
|
exit(-500);
|
||||||
|
}
|
||||||
|
|
||||||
audioManager.loadBackgroundMusic("../assets/music/background.ogg");
|
audioManager.loadBackgroundMusic("../assets/music/background.ogg");
|
||||||
audioManager.playBackgroundMusic();
|
audioManager.playBackgroundMusic();
|
||||||
@@ -25,206 +50,216 @@ Plansza::Plansza(unsigned int windowHeight, unsigned int windowWidth, sf::Render
|
|||||||
audioManager.loadSoundEffect("shoot_alt", "../assets/sounds/shoot_alt.ogg");
|
audioManager.loadSoundEffect("shoot_alt", "../assets/sounds/shoot_alt.ogg");
|
||||||
audioManager.loadSoundEffect("fail", "../assets/sounds/fail.mp3");
|
audioManager.loadSoundEffect("fail", "../assets/sounds/fail.mp3");
|
||||||
|
|
||||||
|
|
||||||
meteorTexture1.loadFromFile("../assets/img/meteors/meteor-1.png");
|
meteorTexture1.loadFromFile("../assets/img/meteors/meteor-1.png");
|
||||||
meteorTexture2.loadFromFile("../assets/img/meteors/meteor-2.png");
|
meteorTexture2.loadFromFile("../assets/img/meteors/meteor-2.png");
|
||||||
|
|
||||||
// Ładowanie tekstur wrogów
|
heartTexture.loadFromFile("../assets/img/hearts/heart.png");
|
||||||
if (!enemyTexture.loadFromFile("../assets/img/enemy/enemy.png")) {
|
heartTextureGray.loadFromFile("../assets/img/hearts/heart_gray.png");
|
||||||
std::cerr << "Failed to load enemy texture!" << std::endl;
|
|
||||||
exit(-1);
|
heartStats.emplace_back(heartTexture);
|
||||||
}
|
heartStats.emplace_back(heartTexture);
|
||||||
if (!advancedEnemyTexture.loadFromFile("../assets/img/enemy/advanced_enemy.png")) {
|
heartStats.emplace_back(heartTexture);
|
||||||
std::cerr << "Failed to load advanced enemy texture!" << std::endl;
|
heartStats[0].setPosition(565, 10);
|
||||||
exit(-1);
|
heartStats[1].setPosition(530, 10);
|
||||||
}
|
heartStats[2].setPosition(495, 10);
|
||||||
if (!BomberEnemyTexture.loadFromFile("../assets/img/enemy/bomber.png")) {
|
|
||||||
std::cerr << "Failed to load advanced enemy texture!" << std::endl;
|
meteorSpawnClock.restart();
|
||||||
exit(-1);
|
spawn_player();
|
||||||
}
|
|
||||||
if (!KamikadzeTexture.loadFromFile("../assets/img/enemy/kamikadze.png")) {
|
|
||||||
std::cerr << "Failed to load advanced enemy texture!" << std::endl;
|
|
||||||
exit(-1);
|
|
||||||
}
|
|
||||||
if (!BombaTexture.loadFromFile("../assets/img/bullets/bomba.png")) {
|
|
||||||
std::cerr << "Failed to load BombaTexture!" << std::endl;
|
|
||||||
exit(-1);
|
|
||||||
}
|
|
||||||
if (!WiazkowiecTexture.loadFromFile("../assets/img/enemy/wiazkowiec.png")) {
|
|
||||||
std::cerr << "Failed to load Wiazkowiec texture!" << std::endl;
|
|
||||||
exit(-1);
|
|
||||||
}
|
|
||||||
spawnClock.restart();
|
spawnClock.restart();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO: Refactor tej metody bo rozrosła się za bardzo już
|
||||||
void Plansza::update() {
|
void Plansza::update() {
|
||||||
// tło
|
// tło
|
||||||
background.update();
|
background.update();
|
||||||
background.draw(*window);
|
background.draw(*window);
|
||||||
|
|
||||||
// poruszanie się statkiem
|
// poruszanie się statkiem
|
||||||
if(sf::Keyboard::isKeyPressed(sf::Keyboard::A)) {
|
if (sf::Keyboard::isKeyPressed(sf::Keyboard::A)) {
|
||||||
if(ship.getPosition().x > 50) {
|
if (ship->getPosition().x > 50) {
|
||||||
ship.moveLeft();
|
ship->moveLeft();
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if (sf::Keyboard::isKeyPressed(sf::Keyboard::W)) {
|
}
|
||||||
if(ship.getPosition().y > 80) {
|
if (sf::Keyboard::isKeyPressed(sf::Keyboard::W)) {
|
||||||
ship.moveUp();
|
if (ship->getPosition().y > 80) {
|
||||||
}
|
ship->moveUp();
|
||||||
}
|
}
|
||||||
if (sf::Keyboard::isKeyPressed(sf::Keyboard::S)) {
|
}
|
||||||
if(ship.getPosition().y < 720) {
|
if (sf::Keyboard::isKeyPressed(sf::Keyboard::S)) {
|
||||||
ship.moveDown();
|
if (ship->getPosition().y < 720) {
|
||||||
}
|
ship->moveDown();
|
||||||
}
|
}
|
||||||
if (sf::Keyboard::isKeyPressed(sf::Keyboard::D)) {
|
}
|
||||||
if(ship.getPosition().x < 550) {
|
if (sf::Keyboard::isKeyPressed(sf::Keyboard::D)) {
|
||||||
ship.moveRight();
|
if (ship->getPosition().x < 550) {
|
||||||
}
|
ship->moveRight();
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: Przenieść obiekt dźwięku wewnątrz klasy Bullet
|
|
||||||
if (sf::Mouse::isButtonPressed(sf::Mouse::Left)) {
|
|
||||||
ship.shoot();
|
|
||||||
audioManager.playSoundEffect("shoot", 70.f); // Odtworzenie dźwięku wystrzału
|
|
||||||
}
|
|
||||||
if (sf::Mouse::isButtonPressed(sf::Mouse::Right)) {
|
|
||||||
ship.alternate_shoot();
|
|
||||||
audioManager.playSoundEffect("shoot_alt", 70.f); // Odtworzenie dźwięku dla alternatywnego strzału
|
|
||||||
}
|
|
||||||
|
|
||||||
// generowanie nowego meteoru
|
|
||||||
ship.update();
|
|
||||||
spawn_meteor();
|
|
||||||
spawn_enemy();
|
|
||||||
spawn_advanced_enemy();
|
|
||||||
spawn_wiazkowiec();
|
|
||||||
spawn_bomber();
|
|
||||||
spawn_kamikadze();
|
|
||||||
|
|
||||||
// utrzymanie meteorów i pocisków w ruchu
|
|
||||||
for (auto& meteor : getMeteors()) {
|
|
||||||
meteor.update();
|
|
||||||
window->draw(meteor.getSprite());
|
|
||||||
}
|
|
||||||
|
|
||||||
for (auto& bullet : ship.getBullets()) {
|
|
||||||
bullet.update();
|
|
||||||
window->draw(bullet.getSprite());
|
|
||||||
}
|
|
||||||
|
|
||||||
for (auto& rocket : ship.getRockets()) {
|
|
||||||
rocket.update();
|
|
||||||
window->draw(rocket.getSprite());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Sprawdzenie czy meteory i pociski są poza granicami ekranu
|
|
||||||
update_meteors();
|
|
||||||
ship.updateBullets();
|
|
||||||
|
|
||||||
window->draw(ship.getSprite());
|
|
||||||
|
|
||||||
// trochę dziwny sposób ale jednak działa
|
|
||||||
for (auto& meteor : getMeteors()) {
|
|
||||||
if(ship.getSprite().getGlobalBounds().intersects(meteor.getSprite().getGlobalBounds())) {
|
|
||||||
std::cout << "You lost the game!\n";
|
|
||||||
sf::RenderWindow errorWindow(sf::VideoMode(350, 200), "The end");
|
|
||||||
sf::Font font;
|
|
||||||
if (!font.loadFromFile("../assets/fonts/arial.ttf")) {
|
|
||||||
std::cerr << "Error loading font\n";
|
|
||||||
exit(-500);
|
|
||||||
}
|
|
||||||
sf::Text text("Your ship is destroyed!", font, 24);
|
|
||||||
text.setFillColor(sf::Color::Red);
|
|
||||||
text.setPosition(50, 80);
|
|
||||||
|
|
||||||
// zatrzymanie muzyki i odtworzenie dźwięku przegranej
|
|
||||||
audioManager.playSoundEffect("fail", 70.f);
|
|
||||||
audioManager.stopBackgroundMusic();
|
|
||||||
sf::Event event{};
|
|
||||||
while (errorWindow.isOpen()) {
|
|
||||||
while (errorWindow.pollEvent(event)) {
|
|
||||||
if (event.type == sf::Event::Closed || sf::Keyboard::isKeyPressed(sf::Keyboard::Escape)) {
|
|
||||||
errorWindow.close();
|
|
||||||
window->close();
|
|
||||||
exit(-2);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
errorWindow.clear();
|
|
||||||
errorWindow.draw(text);
|
|
||||||
errorWindow.display();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (!ship.isAlive()) {
|
|
||||||
std::cout << "Game Over! Player is dead." << std::endl;
|
|
||||||
std::cout << "You lost the game!\n";
|
|
||||||
sf::RenderWindow errorWindow(sf::VideoMode(350, 200), "The end");
|
|
||||||
sf::Font font;
|
|
||||||
if (!font.loadFromFile("../assets/fonts/arial.ttf")) {
|
|
||||||
std::cerr << "Error loading font\n";
|
|
||||||
exit(-500);
|
|
||||||
}
|
|
||||||
sf::Text text("Your ship is destroyed!", font, 24);
|
|
||||||
text.setFillColor(sf::Color::Red);
|
|
||||||
text.setPosition(50, 80);
|
|
||||||
|
|
||||||
// zatrzymanie muzyki i odtworzenie dźwięku przegranej
|
|
||||||
audioManager.playSoundEffect("fail", 70.f);
|
|
||||||
audioManager.stopBackgroundMusic();
|
|
||||||
sf::Event event{};
|
|
||||||
while (errorWindow.isOpen()) {
|
|
||||||
while (errorWindow.pollEvent(event)) {
|
|
||||||
if (event.type == sf::Event::Closed || sf::Keyboard::isKeyPressed(sf::Keyboard::Escape)) {
|
|
||||||
errorWindow.close();
|
|
||||||
window->close();
|
|
||||||
exit(-2);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
errorWindow.clear();
|
|
||||||
errorWindow.draw(text);
|
|
||||||
errorWindow.display();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for (auto meteorIt = getMeteors().begin(); meteorIt != getMeteors().end(); ) {
|
// TODO: Przenieść obiekt dźwięku wewnątrz klasy Bullet
|
||||||
bool meteorHit = false;
|
if (sf::Mouse::isButtonPressed(sf::Mouse::Left)) {
|
||||||
for (auto rocketIt = ship.getBullets().begin(); rocketIt != ship.getBullets().end(); ) {
|
ship->shoot();
|
||||||
if (meteorIt->getSprite().getGlobalBounds().intersects(rocketIt->getSprite().getGlobalBounds())) {
|
audioManager.playSoundEffect("shoot", 70.f); // Odtworzenie dźwięku wystrzału
|
||||||
ship.getBullets().erase(rocketIt);
|
}
|
||||||
meteorIt = getMeteors().erase(meteorIt);
|
if (sf::Mouse::isButtonPressed(sf::Mouse::Right)) {
|
||||||
meteorHit = true;
|
ship->alternate_shoot();
|
||||||
break;
|
audioManager.playSoundEffect("shoot_alt", 70.f); // Odtworzenie dźwięku dla alternatywnego strzału
|
||||||
} else {
|
}
|
||||||
++rocketIt;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!meteorHit) {
|
|
||||||
++meteorIt;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for (auto meteorIt = getMeteors().begin(); meteorIt != getMeteors().end(); ) {
|
// generowanie nowego meteoru
|
||||||
bool meteorHit = false;
|
ship->update(); // migotanie statku
|
||||||
for (auto rocketIt = ship.getRockets().begin(); rocketIt != ship.getRockets().end(); ) {
|
update_score(); // naliczanie punktów
|
||||||
if (meteorIt->getSprite().getGlobalBounds().intersects(rocketIt->getSprite().getGlobalBounds())) {
|
// Sprawnowanie wszystkich rodzajów wrogów
|
||||||
ship.getRockets().erase(rocketIt);
|
// spawn_meteor();
|
||||||
meteorIt = getMeteors().erase(meteorIt);
|
// spawn_hearts();
|
||||||
meteorHit = true;
|
// spawn_enemy();
|
||||||
break;
|
// spawn_advanced_enemy();
|
||||||
} else {
|
spawn_wiazkowiec();
|
||||||
++rocketIt;
|
// spawn_bomber();
|
||||||
}
|
// spawn_kamikadze();
|
||||||
}
|
|
||||||
if (!meteorHit) {
|
// utrzymanie meteorów i pocisków w ruchu
|
||||||
++meteorIt;
|
for (auto &meteor: meteors) {
|
||||||
|
meteor.update();
|
||||||
|
window->draw(meteor.getSprite());
|
||||||
|
}
|
||||||
|
|
||||||
|
for (auto &heart: hearts) {
|
||||||
|
heart.update();
|
||||||
|
window->draw(heart.getSprite());
|
||||||
|
}
|
||||||
|
|
||||||
|
for (auto &bullet: ship->getBullets()) {
|
||||||
|
bullet.update();
|
||||||
|
window->draw(bullet.getSprite());
|
||||||
|
}
|
||||||
|
|
||||||
|
for (auto &rocket: ship->getRockets()) {
|
||||||
|
rocket.update();
|
||||||
|
window->draw(rocket.getSprite());
|
||||||
|
}
|
||||||
|
|
||||||
|
// Sprawdzenie, czy meteory i pociski są poza granicami ekranu
|
||||||
|
update_meteors();
|
||||||
|
update_hearts();
|
||||||
|
ship->updateBullets();
|
||||||
|
|
||||||
|
window->draw(ship->getSprite());
|
||||||
|
|
||||||
|
for (auto &meteor: meteors) {
|
||||||
|
if (ship->getSprite().getGlobalBounds().intersects(meteor.getSprite().getGlobalBounds())) {
|
||||||
|
ship->takeDamage();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (auto heartIt = hearts.begin(); heartIt != hearts.end();) {
|
||||||
|
if (ship->getSprite().getGlobalBounds().intersects(heartIt->getSprite().getGlobalBounds())) {
|
||||||
|
ship->healUP();
|
||||||
|
heartIt = hearts.erase(heartIt);
|
||||||
|
} else {
|
||||||
|
++heartIt;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (auto meteorIt = getMeteors().begin(); meteorIt != getMeteors().end();) {
|
||||||
|
bool meteorHit = false;
|
||||||
|
for (auto rocketIt = ship->getBullets().begin(); rocketIt != ship->getBullets().end();) {
|
||||||
|
if (meteorIt->getSprite().getGlobalBounds().intersects(rocketIt->getSprite().getGlobalBounds())) {
|
||||||
|
ship->getBullets().erase(rocketIt);
|
||||||
|
meteorIt = getMeteors().erase(meteorIt);
|
||||||
|
meteorHit = true;
|
||||||
|
break;
|
||||||
|
} else {
|
||||||
|
++rocketIt;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (!meteorHit) {
|
||||||
|
++meteorIt;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (auto meteorIt = getMeteors().begin(); meteorIt != getMeteors().end();) {
|
||||||
|
bool meteorHit = false;
|
||||||
|
for (auto rocketIt = ship->getRockets().begin(); rocketIt != ship->getRockets().end();) {
|
||||||
|
if (meteorIt->getSprite().getGlobalBounds().intersects(rocketIt->getSprite().getGlobalBounds())) {
|
||||||
|
ship->getRockets().erase(rocketIt);
|
||||||
|
meteorIt = getMeteors().erase(meteorIt);
|
||||||
|
meteorHit = true;
|
||||||
|
break;
|
||||||
|
} else {
|
||||||
|
++rocketIt;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!meteorHit) {
|
||||||
|
++meteorIt;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (gameOver) {
|
||||||
|
sf::RenderWindow errorWindow(sf::VideoMode(350, 200), "The end");
|
||||||
|
sf::Font font;
|
||||||
|
if (!font.loadFromFile("../assets/fonts/arial.ttf")) {
|
||||||
|
std::cerr << "Error loading font\n";
|
||||||
|
exit(-500);
|
||||||
|
}
|
||||||
|
sf::Text text("Your ship is destroyed!", font, 24);
|
||||||
|
text.setFillColor(sf::Color::Red);
|
||||||
|
text.setPosition(50, 80);
|
||||||
|
|
||||||
|
// zatrzymanie muzyki i odtworzenie dźwięku przegranej
|
||||||
|
audioManager.playSoundEffect("fail", 70.f);
|
||||||
|
audioManager.stopBackgroundMusic();
|
||||||
|
sf::Event event{};
|
||||||
|
while (errorWindow.isOpen()) {
|
||||||
|
while (errorWindow.pollEvent(event)) {
|
||||||
|
if (event.type == sf::Event::Closed || sf::Keyboard::isKeyPressed(sf::Keyboard::Escape)) {
|
||||||
|
errorWindow.close();
|
||||||
|
window->close();
|
||||||
|
exit(-2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
errorWindow.clear();
|
||||||
|
errorWindow.draw(text);
|
||||||
|
errorWindow.display();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (auto meteorIt = getMeteors().begin(); meteorIt != getMeteors().end();) {
|
||||||
|
bool meteorHit = false;
|
||||||
|
for (auto bulletIt = ship->getBullets().begin(); bulletIt != ship->getBullets().end();) {
|
||||||
|
if (meteorIt->getSprite().getGlobalBounds().intersects(bulletIt->getSprite().getGlobalBounds())) {
|
||||||
|
ship->getBullets().erase(bulletIt);
|
||||||
|
meteorIt = getMeteors().erase(meteorIt);
|
||||||
|
meteorHit = true;
|
||||||
|
break;
|
||||||
|
} else {
|
||||||
|
++bulletIt;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!meteorHit) {
|
||||||
|
++meteorIt;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (auto meteorIt = getMeteors().begin(); meteorIt != getMeteors().end();) {
|
||||||
|
bool meteorHit = false;
|
||||||
|
for (auto rocketIt = ship->getRockets().begin(); rocketIt != ship->getRockets().end();) {
|
||||||
|
if (meteorIt->getSprite().getGlobalBounds().intersects(rocketIt->getSprite().getGlobalBounds())) {
|
||||||
|
ship->getRockets().erase(rocketIt);
|
||||||
|
meteorIt = getMeteors().erase(meteorIt);
|
||||||
|
meteorHit = true;
|
||||||
|
break;
|
||||||
|
} else {
|
||||||
|
++rocketIt;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!meteorHit) {
|
||||||
|
++meteorIt;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Ruch i render przeciwnika
|
// Ruch i render przeciwnika
|
||||||
for (auto it = enemies.begin(); it != enemies.end();) {
|
for (auto it = enemies.begin(); it != enemies.end();) {
|
||||||
it->update(); // Aktualizacja kierunku i ruchu
|
it->update(); // Aktualizacja kierunku i ruchu
|
||||||
@@ -269,16 +304,16 @@ void Plansza::update() {
|
|||||||
|
|
||||||
|
|
||||||
for (auto it = KEnemies.begin(); it != KEnemies.end();) {
|
for (auto it = KEnemies.begin(); it != KEnemies.end();) {
|
||||||
sf::Vector2f playerPosition = ship.getSprite().getPosition(); // Aktualna pozycja gracza
|
sf::Vector2f playerPosition = ship->getSprite().getPosition(); // Aktualna pozycja gracza
|
||||||
bool playerHit = false;
|
bool playerHit = false;
|
||||||
|
|
||||||
it->update(playerPosition);
|
it->update(playerPosition);
|
||||||
|
|
||||||
// Wybuch, gdy Kamikadze dotknie gracza
|
// Wybuch, gdy Kamikadze dotknie gracza
|
||||||
if (ship.getSprite().getGlobalBounds().intersects(it->getSprite().getGlobalBounds())) {
|
if (ship->getSprite().getGlobalBounds().intersects(it->getSprite().getGlobalBounds())) {
|
||||||
it->explode(playerPosition, playerHit);
|
it->explode(playerPosition, playerHit);
|
||||||
if (playerHit) {
|
if (playerHit) {
|
||||||
ship.takeDamage(); // Gracz otrzymuje obrażenia
|
ship->takeDamage(); // Gracz otrzymuje obrażenia
|
||||||
std::cout << "Gracz został trafiony przez eksplozję Kamikadze!" << std::endl;
|
std::cout << "Gracz został trafiony przez eksplozję Kamikadze!" << std::endl;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -300,10 +335,10 @@ void Plansza::update() {
|
|||||||
|
|
||||||
|
|
||||||
// Obsługa pocisków zaawansowanych przeciwników
|
// Obsługa pocisków zaawansowanych przeciwników
|
||||||
for (auto& aEnemy : AEnemies) {
|
for (auto &aEnemy: AEnemies) {
|
||||||
for (auto it = aEnemy.getBullets().begin(); it != aEnemy.getBullets().end();) {
|
for (auto it = aEnemy.getBullets().begin(); it != aEnemy.getBullets().end();) {
|
||||||
if (ship.getSprite().getGlobalBounds().intersects(it->getSprite().getGlobalBounds())) {
|
if (ship->getSprite().getGlobalBounds().intersects(it->getSprite().getGlobalBounds())) {
|
||||||
ship.takeDamage(); // Zadanie obrażeń graczowi
|
ship->takeDamage(); // Zadanie obrażeń graczowi
|
||||||
it = aEnemy.getBullets().erase(it); // Usuwanie pocisku po trafieniu
|
it = aEnemy.getBullets().erase(it); // Usuwanie pocisku po trafieniu
|
||||||
} else {
|
} else {
|
||||||
++it;
|
++it;
|
||||||
@@ -312,10 +347,10 @@ void Plansza::update() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Obsługa bomb
|
// Obsługa bomb
|
||||||
for (auto& aEnemy : BEnemies) {
|
for (auto &aEnemy: BEnemies) {
|
||||||
for (auto it = aEnemy.getBullets().begin(); it != aEnemy.getBullets().end();) {
|
for (auto it = aEnemy.getBullets().begin(); it != aEnemy.getBullets().end();) {
|
||||||
if (ship.getSprite().getGlobalBounds().intersects(it->getSprite().getGlobalBounds())) {
|
if (ship->getSprite().getGlobalBounds().intersects(it->getSprite().getGlobalBounds())) {
|
||||||
ship.takeDamage(); // Zadanie obrażeń graczowi
|
ship->takeDamage(); // Zadanie obrażeń graczowi
|
||||||
it = aEnemy.getBullets().erase(it); // Usuwanie pocisku po trafieniu
|
it = aEnemy.getBullets().erase(it); // Usuwanie pocisku po trafieniu
|
||||||
} else {
|
} else {
|
||||||
++it;
|
++it;
|
||||||
@@ -324,39 +359,36 @@ void Plansza::update() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
for (auto& enemy : enemies) {
|
for (auto &enemy: enemies) {
|
||||||
enemy.shoot();
|
enemy.shoot();
|
||||||
enemy.updateBullets();
|
enemy.updateBullets();
|
||||||
for (auto& bullet : enemy.getBullets()) {
|
for (auto &bullet: enemy.getBullets()) {
|
||||||
bullet.update();
|
bullet.update();
|
||||||
window->draw(bullet.getSprite());
|
window->draw(bullet.getSprite());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (auto& advancedEnemy : AEnemies) {
|
for (auto &advancedEnemy: AEnemies) {
|
||||||
advancedEnemy.updateBullets(); // Obsługuje pociski zaawansowanych przeciwników
|
advancedEnemy.updateBullets(); // Obsługuje pociski zaawansowanych przeciwników
|
||||||
for (auto& bullet : advancedEnemy.getBullets()) {
|
for (auto &bullet: advancedEnemy.getBullets()) {
|
||||||
bullet.update();
|
bullet.update();
|
||||||
window->draw(bullet.getSprite());
|
window->draw(bullet.getSprite());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (auto& bomberEnemy : BEnemies) {
|
for (auto &bomberEnemy: BEnemies) {
|
||||||
bomberEnemy.updateBullets(); // Obsługuje bomby
|
bomberEnemy.updateBullets(); // Obsługuje bomby
|
||||||
for (auto& bullet : bomberEnemy.getBullets()) {
|
for (auto &bullet: bomberEnemy.getBullets()) {
|
||||||
bullet.update();
|
bullet.update();
|
||||||
window->draw(bullet.getSprite());
|
window->draw(bullet.getSprite());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (auto& enemy : enemies) {
|
for (auto &enemy: enemies) {
|
||||||
for (auto it = enemy.getBullets().begin(); it != enemy.getBullets().end();) {
|
for (auto it = enemy.getBullets().begin(); it != enemy.getBullets().end();) {
|
||||||
if (ship.getSprite().getGlobalBounds().intersects(it->getSprite().getGlobalBounds())) {
|
if (ship->getSprite().getGlobalBounds().intersects(it->getSprite().getGlobalBounds())) {
|
||||||
// Kolizja wykryta
|
// Kolizja wykryta
|
||||||
std::cout << "Player hit by enemy bullet!\n";
|
ship->takeDamage();
|
||||||
|
|
||||||
ship.takeDamage();
|
|
||||||
|
|
||||||
// Usuwanie pocisku
|
// Usuwanie pocisku
|
||||||
it = enemy.getBullets().erase(it);
|
it = enemy.getBullets().erase(it);
|
||||||
} else {
|
} else {
|
||||||
@@ -365,16 +397,16 @@ void Plansza::update() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (auto& bomberEnemy : BEnemies) {
|
for (auto &bomberEnemy: BEnemies) {
|
||||||
for (auto it = bomberEnemy.getBullets().begin(); it != bomberEnemy.getBullets().end();) {
|
for (auto it = bomberEnemy.getBullets().begin(); it != bomberEnemy.getBullets().end();) {
|
||||||
bool bulletDestroyed = false;
|
bool bulletDestroyed = false;
|
||||||
|
|
||||||
// Kolizja pocisku gracza z pociskiem Bombera
|
// Kolizja pocisku gracza z pociskiem Bombera
|
||||||
for (auto playerBulletIt = ship.getBullets().begin(); playerBulletIt != ship.getBullets().end();) {
|
for (auto playerBulletIt = ship->getBullets().begin(); playerBulletIt != ship->getBullets().end();) {
|
||||||
if (playerBulletIt->getSprite().getGlobalBounds().intersects(it->getSprite().getGlobalBounds())) {
|
if (playerBulletIt->getSprite().getGlobalBounds().intersects(it->getSprite().getGlobalBounds())) {
|
||||||
// Usuń pocisk Bombera i pocisk gracza
|
// Usuń pocisk Bombera i pocisk gracza
|
||||||
it = bomberEnemy.getBullets().erase(it);
|
it = bomberEnemy.getBullets().erase(it);
|
||||||
playerBulletIt = ship.getBullets().erase(playerBulletIt);
|
ship->getBullets().erase(playerBulletIt);
|
||||||
bulletDestroyed = true;
|
bulletDestroyed = true;
|
||||||
break;
|
break;
|
||||||
} else {
|
} else {
|
||||||
@@ -384,11 +416,11 @@ void Plansza::update() {
|
|||||||
|
|
||||||
// Kolizja rakiety gracza z pociskiem Bombera
|
// Kolizja rakiety gracza z pociskiem Bombera
|
||||||
if (!bulletDestroyed) {
|
if (!bulletDestroyed) {
|
||||||
for (auto rocketIt = ship.getRockets().begin(); rocketIt != ship.getRockets().end();) {
|
for (auto rocketIt = ship->getRockets().begin(); rocketIt != ship->getRockets().end();) {
|
||||||
if (rocketIt->getSprite().getGlobalBounds().intersects(it->getSprite().getGlobalBounds())) {
|
if (rocketIt->getSprite().getGlobalBounds().intersects(it->getSprite().getGlobalBounds())) {
|
||||||
// Usuń pocisk Bombera i rakietę gracza
|
// Usuń pocisk Bombera i rakietę gracza
|
||||||
it = bomberEnemy.getBullets().erase(it);
|
it = bomberEnemy.getBullets().erase(it);
|
||||||
rocketIt = ship.getRockets().erase(rocketIt);
|
ship->getRockets().erase(rocketIt);
|
||||||
bulletDestroyed = true;
|
bulletDestroyed = true;
|
||||||
break;
|
break;
|
||||||
} else {
|
} else {
|
||||||
@@ -399,9 +431,9 @@ void Plansza::update() {
|
|||||||
|
|
||||||
// Jeśli pocisk Bombera przetrwał dotychczasowe sprawdzenia, wykonaj inne działania
|
// Jeśli pocisk Bombera przetrwał dotychczasowe sprawdzenia, wykonaj inne działania
|
||||||
if (!bulletDestroyed) {
|
if (!bulletDestroyed) {
|
||||||
if (ship.getSprite().getGlobalBounds().intersects(it->getSprite().getGlobalBounds())) {
|
if (ship->getSprite().getGlobalBounds().intersects(it->getSprite().getGlobalBounds())) {
|
||||||
// Kolizja pocisku Bombera z graczem
|
// Kolizja pocisku Bombera z graczem
|
||||||
ship.takeDamage();
|
ship->takeDamage();
|
||||||
it = bomberEnemy.getBullets().erase(it);
|
it = bomberEnemy.getBullets().erase(it);
|
||||||
} else {
|
} else {
|
||||||
++it;
|
++it;
|
||||||
@@ -410,21 +442,21 @@ void Plansza::update() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (auto& wiazkowiec : WEnemies) {
|
for (auto &wiazkowiec: WEnemies) {
|
||||||
wiazkowiec.update();
|
wiazkowiec.update();
|
||||||
|
|
||||||
if (wiazkowiec.isShooting() && wiazkowiec.getBeam().isVisible()) {
|
if (wiazkowiec.isShooting()) {
|
||||||
if (ship.getSprite().getGlobalBounds().intersects(wiazkowiec.getBeam().getBounds())) {
|
if (ship->getSprite().getGlobalBounds().intersects(wiazkowiec.getBeam()->getSprite().getGlobalBounds())) {
|
||||||
ship.takeDamage(); // Gracz otrzymuje obrażenia
|
ship->takeDamage(); // Gracz otrzymuje obrażenia
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
window->draw(wiazkowiec.getSprite());
|
window->draw(wiazkowiec.getSprite());
|
||||||
wiazkowiec.render(*window);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO: naprawić to co średnio działa
|
||||||
// Usuwanie pocisków, które są poza ekranem srednio to dziala
|
// Usuwanie pocisków, które są poza ekranem srednio to dziala
|
||||||
for (auto enemyIt = enemies.begin(); enemyIt != enemies.end(); ) {
|
for (auto enemyIt = enemies.begin(); enemyIt != enemies.end();) {
|
||||||
for (auto bulletIt = enemyIt->getBullets().begin(); bulletIt != enemyIt->getBullets().end();) {
|
for (auto bulletIt = enemyIt->getBullets().begin(); bulletIt != enemyIt->getBullets().end();) {
|
||||||
if (bulletIt->isOutOfBounds()) {
|
if (bulletIt->isOutOfBounds()) {
|
||||||
bulletIt = enemyIt->getBullets().erase(bulletIt); // Usuwamy pocisk, który wyszedł poza ekran
|
bulletIt = enemyIt->getBullets().erase(bulletIt); // Usuwamy pocisk, który wyszedł poza ekran
|
||||||
@@ -439,9 +471,9 @@ void Plansza::update() {
|
|||||||
// Kolizje między pociskami gracza a przeciwnikami
|
// Kolizje między pociskami gracza a przeciwnikami
|
||||||
for (auto enemyIt = enemies.begin(); enemyIt != enemies.end();) {
|
for (auto enemyIt = enemies.begin(); enemyIt != enemies.end();) {
|
||||||
bool hit = false;
|
bool hit = false;
|
||||||
for (auto bulletIt = ship.getBullets().begin(); bulletIt != ship.getBullets().end();) {
|
for (auto bulletIt = ship->getBullets().begin(); bulletIt != ship->getBullets().end();) {
|
||||||
if (enemyIt->getSprite().getGlobalBounds().intersects(bulletIt->getSprite().getGlobalBounds())) {
|
if (enemyIt->getSprite().getGlobalBounds().intersects(bulletIt->getSprite().getGlobalBounds())) {
|
||||||
bulletIt = ship.getBullets().erase(bulletIt);
|
ship->getBullets().erase(bulletIt);
|
||||||
enemyIt->takeDamage();
|
enemyIt->takeDamage();
|
||||||
hit = true;
|
hit = true;
|
||||||
break;
|
break;
|
||||||
@@ -458,9 +490,9 @@ void Plansza::update() {
|
|||||||
|
|
||||||
for (auto advancedIt = AEnemies.begin(); advancedIt != AEnemies.end();) {
|
for (auto advancedIt = AEnemies.begin(); advancedIt != AEnemies.end();) {
|
||||||
bool hit = false;
|
bool hit = false;
|
||||||
for (auto bulletIt = ship.getBullets().begin(); bulletIt != ship.getBullets().end();) {
|
for (auto bulletIt = ship->getBullets().begin(); bulletIt != ship->getBullets().end();) {
|
||||||
if (advancedIt->getSprite().getGlobalBounds().intersects(bulletIt->getSprite().getGlobalBounds())) {
|
if (advancedIt->getSprite().getGlobalBounds().intersects(bulletIt->getSprite().getGlobalBounds())) {
|
||||||
bulletIt = ship.getBullets().erase(bulletIt);
|
ship->getBullets().erase(bulletIt);
|
||||||
advancedIt->takeDamage();
|
advancedIt->takeDamage();
|
||||||
hit = true;
|
hit = true;
|
||||||
break;
|
break;
|
||||||
@@ -477,9 +509,9 @@ void Plansza::update() {
|
|||||||
|
|
||||||
for (auto bomberIt = BEnemies.begin(); bomberIt != BEnemies.end();) {
|
for (auto bomberIt = BEnemies.begin(); bomberIt != BEnemies.end();) {
|
||||||
bool hit = false;
|
bool hit = false;
|
||||||
for (auto bulletIt = ship.getBullets().begin(); bulletIt != ship.getBullets().end();) {
|
for (auto bulletIt = ship->getBullets().begin(); bulletIt != ship->getBullets().end();) {
|
||||||
if (bomberIt->getSprite().getGlobalBounds().intersects(bulletIt->getSprite().getGlobalBounds())) {
|
if (bomberIt->getSprite().getGlobalBounds().intersects(bulletIt->getSprite().getGlobalBounds())) {
|
||||||
bulletIt = ship.getBullets().erase(bulletIt);
|
ship->getBullets().erase(bulletIt);
|
||||||
bomberIt->takeDamage();
|
bomberIt->takeDamage();
|
||||||
hit = true;
|
hit = true;
|
||||||
break;
|
break;
|
||||||
@@ -496,9 +528,9 @@ void Plansza::update() {
|
|||||||
|
|
||||||
for (auto kamikadzeIt = KEnemies.begin(); kamikadzeIt != KEnemies.end();) {
|
for (auto kamikadzeIt = KEnemies.begin(); kamikadzeIt != KEnemies.end();) {
|
||||||
bool hit = false;
|
bool hit = false;
|
||||||
for (auto bulletIt = ship.getBullets().begin(); bulletIt != ship.getBullets().end();) {
|
for (auto bulletIt = ship->getBullets().begin(); bulletIt != ship->getBullets().end();) {
|
||||||
if (kamikadzeIt->getSprite().getGlobalBounds().intersects(bulletIt->getSprite().getGlobalBounds())) {
|
if (kamikadzeIt->getSprite().getGlobalBounds().intersects(bulletIt->getSprite().getGlobalBounds())) {
|
||||||
bulletIt = ship.getBullets().erase(bulletIt);
|
ship->getBullets().erase(bulletIt);
|
||||||
kamikadzeIt->takeDamage();
|
kamikadzeIt->takeDamage();
|
||||||
hit = true;
|
hit = true;
|
||||||
break;
|
break;
|
||||||
@@ -515,9 +547,9 @@ void Plansza::update() {
|
|||||||
|
|
||||||
for (auto wiazkowiecIt = WEnemies.begin(); wiazkowiecIt != WEnemies.end();) {
|
for (auto wiazkowiecIt = WEnemies.begin(); wiazkowiecIt != WEnemies.end();) {
|
||||||
bool hit = false;
|
bool hit = false;
|
||||||
for (auto bulletIt = ship.getBullets().begin(); bulletIt != ship.getBullets().end();) {
|
for (auto bulletIt = ship->getBullets().begin(); bulletIt != ship->getBullets().end();) {
|
||||||
if (wiazkowiecIt->getSprite().getGlobalBounds().intersects(bulletIt->getSprite().getGlobalBounds())) {
|
if (wiazkowiecIt->getSprite().getGlobalBounds().intersects(bulletIt->getSprite().getGlobalBounds())) {
|
||||||
bulletIt = ship.getBullets().erase(bulletIt);
|
ship->getBullets().erase(bulletIt);
|
||||||
wiazkowiecIt->takeDamage();
|
wiazkowiecIt->takeDamage();
|
||||||
hit = true;
|
hit = true;
|
||||||
break;
|
break;
|
||||||
@@ -537,9 +569,9 @@ void Plansza::update() {
|
|||||||
//oblsuga dla rakiety
|
//oblsuga dla rakiety
|
||||||
for (auto enemyIt = enemies.begin(); enemyIt != enemies.end();) {
|
for (auto enemyIt = enemies.begin(); enemyIt != enemies.end();) {
|
||||||
bool hit = false;
|
bool hit = false;
|
||||||
for (auto rocketIt = ship.getRockets().begin(); rocketIt != ship.getRockets().end();) {
|
for (auto rocketIt = ship->getRockets().begin(); rocketIt != ship->getRockets().end();) {
|
||||||
if (enemyIt->getSprite().getGlobalBounds().intersects(rocketIt->getSprite().getGlobalBounds())) {
|
if (enemyIt->getSprite().getGlobalBounds().intersects(rocketIt->getSprite().getGlobalBounds())) {
|
||||||
rocketIt = ship.getRockets().erase(rocketIt);
|
ship->getRockets().erase(rocketIt);
|
||||||
enemyIt->takeDamage();
|
enemyIt->takeDamage();
|
||||||
hit = true;
|
hit = true;
|
||||||
break;
|
break;
|
||||||
@@ -556,9 +588,9 @@ void Plansza::update() {
|
|||||||
|
|
||||||
for (auto advancedIt = AEnemies.begin(); advancedIt != AEnemies.end();) {
|
for (auto advancedIt = AEnemies.begin(); advancedIt != AEnemies.end();) {
|
||||||
bool hit = false;
|
bool hit = false;
|
||||||
for (auto rocketIt = ship.getRockets().begin(); rocketIt != ship.getRockets().end();) {
|
for (auto rocketIt = ship->getRockets().begin(); rocketIt != ship->getRockets().end();) {
|
||||||
if (advancedIt->getSprite().getGlobalBounds().intersects(rocketIt->getSprite().getGlobalBounds())) {
|
if (advancedIt->getSprite().getGlobalBounds().intersects(rocketIt->getSprite().getGlobalBounds())) {
|
||||||
rocketIt = ship.getRockets().erase(rocketIt);
|
ship->getRockets().erase(rocketIt);
|
||||||
advancedIt->takeDamage();
|
advancedIt->takeDamage();
|
||||||
hit = true;
|
hit = true;
|
||||||
break;
|
break;
|
||||||
@@ -575,9 +607,9 @@ void Plansza::update() {
|
|||||||
|
|
||||||
for (auto bomberIt = BEnemies.begin(); bomberIt != BEnemies.end();) {
|
for (auto bomberIt = BEnemies.begin(); bomberIt != BEnemies.end();) {
|
||||||
bool hit = false;
|
bool hit = false;
|
||||||
for (auto rocketIt = ship.getRockets().begin(); rocketIt != ship.getRockets().end();) {
|
for (auto rocketIt = ship->getRockets().begin(); rocketIt != ship->getRockets().end();) {
|
||||||
if (bomberIt->getSprite().getGlobalBounds().intersects(rocketIt->getSprite().getGlobalBounds())) {
|
if (bomberIt->getSprite().getGlobalBounds().intersects(rocketIt->getSprite().getGlobalBounds())) {
|
||||||
rocketIt = ship.getRockets().erase(rocketIt);
|
ship->getRockets().erase(rocketIt);
|
||||||
bomberIt->takeDamage();
|
bomberIt->takeDamage();
|
||||||
hit = true;
|
hit = true;
|
||||||
break;
|
break;
|
||||||
@@ -594,9 +626,9 @@ void Plansza::update() {
|
|||||||
|
|
||||||
for (auto kamikadzeIt = KEnemies.begin(); kamikadzeIt != KEnemies.end();) {
|
for (auto kamikadzeIt = KEnemies.begin(); kamikadzeIt != KEnemies.end();) {
|
||||||
bool hit = false;
|
bool hit = false;
|
||||||
for (auto rocketIt = ship.getRockets().begin(); rocketIt != ship.getRockets().end();) {
|
for (auto rocketIt = ship->getRockets().begin(); rocketIt != ship->getRockets().end();) {
|
||||||
if (kamikadzeIt->getSprite().getGlobalBounds().intersects(rocketIt->getSprite().getGlobalBounds())) {
|
if (kamikadzeIt->getSprite().getGlobalBounds().intersects(rocketIt->getSprite().getGlobalBounds())) {
|
||||||
rocketIt = ship.getRockets().erase(rocketIt);
|
ship->getRockets().erase(rocketIt);
|
||||||
kamikadzeIt->takeDamage();
|
kamikadzeIt->takeDamage();
|
||||||
hit = true;
|
hit = true;
|
||||||
break;
|
break;
|
||||||
@@ -613,9 +645,9 @@ void Plansza::update() {
|
|||||||
|
|
||||||
for (auto wiazkowiecIt = WEnemies.begin(); wiazkowiecIt != WEnemies.end();) {
|
for (auto wiazkowiecIt = WEnemies.begin(); wiazkowiecIt != WEnemies.end();) {
|
||||||
bool hit = false;
|
bool hit = false;
|
||||||
for (auto rocketIt = ship.getRockets().begin(); rocketIt != ship.getRockets().end();) {
|
for (auto rocketIt = ship->getRockets().begin(); rocketIt != ship->getRockets().end();) {
|
||||||
if (wiazkowiecIt->getSprite().getGlobalBounds().intersects(rocketIt->getSprite().getGlobalBounds())) {
|
if (wiazkowiecIt->getSprite().getGlobalBounds().intersects(rocketIt->getSprite().getGlobalBounds())) {
|
||||||
rocketIt = ship.getRockets().erase(rocketIt);
|
ship->getRockets().erase(rocketIt);
|
||||||
wiazkowiecIt->takeDamage();
|
wiazkowiecIt->takeDamage();
|
||||||
hit = true;
|
hit = true;
|
||||||
break;
|
break;
|
||||||
@@ -631,34 +663,81 @@ void Plansza::update() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
// Statystyka życia gracza (wyświetlanie)
|
||||||
|
switch (ship->getHP()) {
|
||||||
|
case 0:
|
||||||
|
heartStats[0].setTexture(heartTextureGray);
|
||||||
|
heartStats[1].setTexture(heartTextureGray);
|
||||||
|
heartStats[2].setTexture(heartTextureGray);
|
||||||
|
gameOver = true;
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
heartStats[0].setTexture(heartTexture);
|
||||||
|
heartStats[1].setTexture(heartTextureGray);
|
||||||
|
heartStats[2].setTexture(heartTextureGray);
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
heartStats[0].setTexture(heartTexture);
|
||||||
|
heartStats[1].setTexture(heartTexture);
|
||||||
|
heartStats[2].setTexture(heartTextureGray);
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
heartStats[0].setTexture(heartTexture);
|
||||||
|
heartStats[1].setTexture(heartTexture);
|
||||||
|
heartStats[2].setTexture(heartTexture);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
// Meteor-related niżej
|
|
||||||
|
|
||||||
void Plansza::spawn_meteor() {
|
for (const auto& heart: heartStats) {
|
||||||
if (spawnClock.getElapsedTime().asSeconds() > rand() % 10 + 1) { // randomowy spawn meteorytów od 10 do 1 sekundy
|
window->draw(heart);
|
||||||
if (meteors.size() < 5) { // jeśli jest mniej niż 5 meteorów na planszy
|
|
||||||
if(rand() % 2 == 1) {
|
|
||||||
meteors.emplace_back(RandomNumberGenerator::getRandomNumber(50,499), -100, meteorTexture2);
|
|
||||||
} else {
|
|
||||||
meteors.emplace_back(RandomNumberGenerator::getRandomNumber(50,499), -100, meteorTexture1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
spawnClock.restart();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
// Meteor-related niżej
|
||||||
|
|
||||||
|
|
||||||
void Plansza::update_meteors() {
|
void Plansza::update_meteors() {
|
||||||
// usuwanie meteorów które wyleciały poza ekran
|
// usuwanie meteorów, które wyleciały poza ekran
|
||||||
for (auto& meteor : meteors) {
|
for (auto &meteor: meteors) {
|
||||||
if(meteor.getStatus()) {
|
if (meteor.getStatus()) {
|
||||||
meteors.erase(meteors.begin());
|
meteors.erase(meteors.begin());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Plansza::spawn_meteor() {
|
||||||
|
if (meteorSpawnClock.getElapsedTime().asSeconds() > rand() % 10 + 1) { // randomowy spawn meteorytów od 10 do 1 sekundy
|
||||||
|
if (meteors.size() < 5) { // jeśli jest mniej niż 5 meteorów na planszy
|
||||||
|
if (rand() % 2 == 1) {
|
||||||
|
meteors.emplace_back(RandomNumberGenerator::getRandomNumber(50, 499), -100, meteorTexture2);
|
||||||
|
} else {
|
||||||
|
meteors.emplace_back(RandomNumberGenerator::getRandomNumber(50, 499), -100, meteorTexture1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
meteorSpawnClock.restart();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Plansza::spawn_hearts() {
|
||||||
|
if (heartSpawnClock.getElapsedTime().asSeconds() > rand() % 26 + 5) { // randomowy spawn meteorytów od 5 do 30 sekundy
|
||||||
|
if (hearts.size() < 5) { // jeśli jest mniej niż 5 meteorów na planszy
|
||||||
|
hearts.emplace_back(RandomNumberGenerator::getRandomNumber(50, 499), -100, heartTexture);
|
||||||
|
}
|
||||||
|
heartSpawnClock.restart();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Plansza::spawn_player() {
|
||||||
|
ship = Player::getInstance(static_cast<int>(window->getSize().x) / 2, static_cast<int>(window->getSize().y) - 100, this->playerTexture);
|
||||||
|
ship->loadTexture();
|
||||||
|
ship->setMovingSpeed(8);
|
||||||
|
ship->setFirerate(200);
|
||||||
|
}
|
||||||
|
|
||||||
void Plansza::spawn_enemy() {
|
void Plansza::spawn_enemy() {
|
||||||
if (enemySpawnClock.getElapsedTime().asSeconds() >= 110) { // Spawn co 10 sekund
|
if (enemySpawnClock.getElapsedTime().asSeconds() >= 10) { // Spawn co 10 sekund
|
||||||
int spawnX = RandomNumberGenerator::getRandomNumber(50, size.width - 50);
|
int spawnX = RandomNumberGenerator::getRandomNumber(50, size.width - 50);
|
||||||
enemies.emplace_back(spawnX, -50, enemyTexture);
|
enemies.emplace_back(spawnX, -50, enemyTexture);
|
||||||
std::cout << "Spawned Basic Enemy at X: " << spawnX << std::endl;
|
std::cout << "Spawned Basic Enemy at X: " << spawnX << std::endl;
|
||||||
@@ -668,7 +747,7 @@ void Plansza::spawn_enemy() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Plansza::spawn_advanced_enemy() {
|
void Plansza::spawn_advanced_enemy() {
|
||||||
if (AenemySpawnClock.getElapsedTime().asSeconds() >= 80) { // Spawn co 10 sekund
|
if (AenemySpawnClock.getElapsedTime().asSeconds() >= 20) { // Spawn co 10 sekund
|
||||||
int spawnX = RandomNumberGenerator::getRandomNumber(50, size.width - 50);
|
int spawnX = RandomNumberGenerator::getRandomNumber(50, size.width - 50);
|
||||||
AEnemies.emplace_back(spawnX, -50, advancedEnemyTexture, enemyBulletTexture);
|
AEnemies.emplace_back(spawnX, -50, advancedEnemyTexture, enemyBulletTexture);
|
||||||
std::cout << "Spawned Advanced Enemy at X: " << spawnX << std::endl;
|
std::cout << "Spawned Advanced Enemy at X: " << spawnX << std::endl;
|
||||||
@@ -677,7 +756,7 @@ void Plansza::spawn_advanced_enemy() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Plansza::spawn_bomber() {
|
void Plansza::spawn_bomber() {
|
||||||
if (BomberSpawnClock.getElapsedTime().asSeconds() >= 10) { // Spawn co 10 sekund
|
if (BomberSpawnClock.getElapsedTime().asSeconds() >= 30) { // Spawn co 10 sekund
|
||||||
int spawnX = RandomNumberGenerator::getRandomNumber(50, size.width - 50);
|
int spawnX = RandomNumberGenerator::getRandomNumber(50, size.width - 50);
|
||||||
Bomber bomber(spawnX, -50, BomberEnemyTexture, BombaTexture);
|
Bomber bomber(spawnX, -50, BomberEnemyTexture, BombaTexture);
|
||||||
bomber.setPlanszaHeight(size.height, size.width); // Przekazanie wysokości i szerokości okna
|
bomber.setPlanszaHeight(size.height, size.width); // Przekazanie wysokości i szerokości okna
|
||||||
@@ -688,7 +767,7 @@ void Plansza::spawn_bomber() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Plansza::spawn_kamikadze() {
|
void Plansza::spawn_kamikadze() {
|
||||||
if (KamikadzeSpawnClock.getElapsedTime().asSeconds() >= 220) { // Spawn co 10 sekund
|
if (KamikadzeSpawnClock.getElapsedTime().asSeconds() >= 40) { // Spawn co 10 sekund
|
||||||
int spawnX = RandomNumberGenerator::getRandomNumber(50, size.width - 50);
|
int spawnX = RandomNumberGenerator::getRandomNumber(50, size.width - 50);
|
||||||
KEnemies.emplace_back(spawnX, -50, KamikadzeTexture);
|
KEnemies.emplace_back(spawnX, -50, KamikadzeTexture);
|
||||||
std::cout << "Spawned Kamikadze Enemy at X: " << spawnX << std::endl;
|
std::cout << "Spawned Kamikadze Enemy at X: " << spawnX << std::endl;
|
||||||
@@ -697,18 +776,27 @@ void Plansza::spawn_kamikadze() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Plansza::spawn_wiazkowiec() {
|
void Plansza::spawn_wiazkowiec() {
|
||||||
if (WiazkowiecSpawnClock.getElapsedTime().asSeconds() >= 110) { // Spawn co 10 sekund
|
if (WiazkowiecSpawnClock.getElapsedTime().asSeconds() >= 5) { // Spawn co 10 sekund
|
||||||
int spawnX = RandomNumberGenerator::getRandomNumber(50, size.width - 50);
|
if (WEnemies.size() < 1) {
|
||||||
Wiazkowiec wiazkowiec(spawnX, -50, WiazkowiecTexture);
|
int spawnX = RandomNumberGenerator::getRandomNumber(50, size.width - 50);
|
||||||
wiazkowiec.setPlanszaHeight(size.height, size.width); // Przekazanie wysokości i szerokosci okna
|
Wiazkowiec wiazkowiec(spawnX, -50, WiazkowiecTexture, window);
|
||||||
WEnemies.push_back(wiazkowiec);
|
wiazkowiec.setPlanszaHeight(size.height, size.width); // Przekazanie wysokości i szerokosci okna
|
||||||
std::cout << "Spawned Wiazkowiec Enemy at X: " << spawnX << std::endl;
|
WEnemies.push_back(wiazkowiec);
|
||||||
WiazkowiecSpawnClock.restart();
|
std::cout << "Spawned Wiazkowiec Enemy at X: " << spawnX << std::endl;
|
||||||
|
WiazkowiecSpawnClock.restart();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Plansza::update_hearts() {
|
||||||
|
// usuwanie serduszek, które wyleciały poza ekran
|
||||||
|
for (auto& heart : hearts) {
|
||||||
|
if(heart.getStatus()) {
|
||||||
|
hearts.erase(hearts.begin());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Size Plansza::getSize() {
|
Size Plansza::getSize() {
|
||||||
return size;
|
return size;
|
||||||
@@ -718,5 +806,18 @@ std::vector<Meteor> &Plansza::getMeteors() {
|
|||||||
return meteors;
|
return meteors;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO: naliczanie punktów za zabicie wrogów
|
||||||
|
void Plansza::update_score() {
|
||||||
|
if (scoreClock.getElapsedTime().asMilliseconds() > 500) {
|
||||||
|
score++;
|
||||||
|
scoreClock.restart();
|
||||||
|
}
|
||||||
|
|
||||||
|
sf::Text text(std::to_string(score), font, 24);
|
||||||
|
text.setFillColor(sf::Color::White);
|
||||||
|
text.setPosition(25, 25);
|
||||||
|
window->draw(text);
|
||||||
|
}
|
||||||
|
|
||||||
|
ships Plansza::selectedShip = none;
|
||||||
|
unsigned int Plansza::score = 0;
|
||||||
@@ -2,19 +2,35 @@
|
|||||||
|
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <SFML/Graphics/Font.hpp>
|
#include <SFML/Graphics/Font.hpp>
|
||||||
#include <SFML/Graphics/RenderWindow.hpp>
|
|
||||||
#include <SFML/Graphics/Text.hpp>
|
#include <SFML/Graphics/Text.hpp>
|
||||||
|
|
||||||
#include "../headers/Bullet.h"
|
#include "../headers/Plansza.h"
|
||||||
|
|
||||||
Player::Player(int x, int y, const sf::Texture& texture, const sf::Texture& bulletTexture, const sf::Texture& rocketTexture) : Actor(x, y, texture), bulletTexture(bulletTexture), rocketTexture(rocketTexture) {
|
Player::Player(int x, int y, const sf::Texture& texture) : Actor(x, y, texture) {
|
||||||
|
hp = 3;
|
||||||
|
if(Plansza::selectedShip != none) {
|
||||||
|
actorSprite.setScale(0.20f, 0.20f);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
};
|
Player* Player::getInstance(int x, int y, const sf::Texture& texture) {
|
||||||
|
if (player_ == nullptr) {
|
||||||
|
player_ = new Player(x, y, texture);
|
||||||
|
}
|
||||||
|
return player_;
|
||||||
|
}
|
||||||
|
|
||||||
void Player::setTextures(const sf::Texture& shipTexture, const sf::Texture& bulletTexture, const sf::Texture& rocketTexture) {
|
void Player::loadTexture() {
|
||||||
this->actorSprite.setTexture(shipTexture); // Poprawiona nazwa - actorSprite zamiast shipSprite
|
try {
|
||||||
this->bulletTexture = bulletTexture;
|
bulletTexture.loadFromFile("../assets/img/bullets/bullet_pink.png");
|
||||||
this->rocketTexture = rocketTexture;
|
rocketTexture.loadFromFile("../assets/img/rockets/Rocket_111.png");
|
||||||
|
} catch (std::exception &e) {
|
||||||
|
std::cerr << "Failed to load textures: " << e.what() << std::endl;
|
||||||
|
exit(-500);
|
||||||
|
}
|
||||||
|
|
||||||
|
damageDealClock.restart();
|
||||||
|
originalColor = actorSprite.getColor();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Player::shoot() {
|
void Player::shoot() {
|
||||||
@@ -55,26 +71,14 @@ void Player::update() {
|
|||||||
|
|
||||||
void Player::takeDamage() {
|
void Player::takeDamage() {
|
||||||
if (!isImmortal) {
|
if (!isImmortal) {
|
||||||
if (health > 0) {
|
if (hp > 0) {
|
||||||
health--;
|
hp--;
|
||||||
std::cout << "Player hit! Remaining health: " << health << "\n";
|
|
||||||
isImmortal = true; // Aktywuj chwilową nieśmiertelność
|
isImmortal = true; // Aktywuj chwilową nieśmiertelność
|
||||||
immortalityClock.restart();
|
immortalityClock.restart();
|
||||||
|
|
||||||
|
|
||||||
if (health <= 0) {
|
|
||||||
std::cout << "Player has been destroyed!\n";
|
|
||||||
std::cout << "You lost the game!\n";
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Player::isAlive() const {
|
|
||||||
return health > 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void Player::setFirerate(unsigned int firerate) {
|
void Player::setFirerate(unsigned int firerate) {
|
||||||
this->firerate = firerate;
|
this->firerate = firerate;
|
||||||
}
|
}
|
||||||
@@ -106,3 +110,5 @@ void Player::moveDown() {
|
|||||||
std::vector<Rocket> &Player::getRockets() {
|
std::vector<Rocket> &Player::getRockets() {
|
||||||
return rockets;
|
return rockets;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Player* Player::player_ = nullptr;
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
void Rocket::update() {
|
void Rocket::update() {
|
||||||
sprite.move(0.0f, speed);
|
sprite.move(0.0f, speed);
|
||||||
position.y += int(speed);
|
position.y += static_cast<int>(speed);
|
||||||
if(position.y < -100) {
|
if(position.y < -100) {
|
||||||
outOfBounds = true;
|
outOfBounds = true;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,56 +1,60 @@
|
|||||||
#include "../headers/Wiazkowiec.h"
|
#include "../headers/Wiazkowiec.h"
|
||||||
|
#include "../headers/Plansza.h"
|
||||||
|
#include "../headers/RandomNumberGenerator.h"
|
||||||
|
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
|
||||||
#include "../headers/Bullet.h"
|
|
||||||
#include <random>
|
|
||||||
|
|
||||||
Wiazkowiec::Wiazkowiec(int x, int y, const sf::Texture& texture) : Actor(x, y, texture), beam(0, 0, 50.f, 50.f, sf::Color::Red) {
|
Wiazkowiec::Wiazkowiec(int x, int y, const sf::Texture &texture, sf::RenderWindow *window) : Actor(x, y, texture),
|
||||||
actorSprite.setTexture(texture);
|
beam(nullptr)
|
||||||
|
{
|
||||||
|
window_ptr = window;
|
||||||
|
|
||||||
|
try {
|
||||||
|
beamTexture.loadFromFile("../assets/img/wiazka/laser.png");
|
||||||
|
} catch (std::exception &e) {
|
||||||
|
std::cerr << "Failed to load textures: " << e.what() << std::endl;
|
||||||
|
exit(-500);
|
||||||
|
}
|
||||||
|
|
||||||
hp = 2; // 2 punkty życia
|
hp = 2; // 2 punkty życia
|
||||||
firerate = 5000; // Strzela co 10
|
firerate = 5000; // Strzela co 10
|
||||||
moving_speed = 5.0f; // Prędkość
|
moving_speed = 5.0f; // Prędkość
|
||||||
}
|
}
|
||||||
|
|
||||||
void Wiazkowiec::setPlanszaHeight(float height, float width) {
|
void Wiazkowiec::setPlanszaHeight(int height, int width) {
|
||||||
planszaHeight = height;
|
planszaHeight = height;
|
||||||
planszaWidth = width;
|
planszaWidth = width;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Wiazkowiec::spawnBeam() {
|
void Wiazkowiec::spawnBeam() {
|
||||||
float beamX = position.x;
|
int beamX = actorSprite.getPosition().x;
|
||||||
float beamY = position.y;
|
int beamY = actorSprite.getPosition().y;
|
||||||
float beamWidth = 50.f;
|
|
||||||
float beamHeight = 0.f;
|
|
||||||
|
|
||||||
switch (direction) {
|
switch (direction) {
|
||||||
case DirectionW::Up:
|
case DirectionW::Up: {
|
||||||
beamHeight = position.y;
|
beam = new Beam(beamX, beamY, beamTexture);
|
||||||
beamY -= beamHeight;
|
beam->setRotation(180);
|
||||||
beam = Beam(beamX, beamY, beamWidth, beamHeight, sf::Color::Red);
|
break;
|
||||||
break;
|
}
|
||||||
case DirectionW::Down:
|
case DirectionW::Down: {
|
||||||
beamHeight = planszaHeight - position.y;
|
beam = new Beam(beamX, beamY, beamTexture);
|
||||||
beam = Beam(beamX, beamY, beamWidth, beamHeight, sf::Color::Red);
|
break;
|
||||||
break;
|
}
|
||||||
case DirectionW::Left:
|
case DirectionW::Left: {
|
||||||
beamHeight = 50.f;
|
beam = new Beam(beamX, beamY, beamTexture);
|
||||||
beamWidth = position.x;
|
beam->setRotation(90);
|
||||||
beamX -= beamWidth;
|
break;
|
||||||
beamY = position.y + (actorSprite.getGlobalBounds().height / 2) - 25.f;
|
}
|
||||||
beam = Beam(beamX, beamY, beamWidth, beamHeight, sf::Color::Red);
|
case DirectionW::Right: {
|
||||||
break;
|
beam = new Beam(beamX, beamY, beamTexture);
|
||||||
case DirectionW::Right:
|
beam->setRotation(270);
|
||||||
beamHeight = 50.f;
|
break;
|
||||||
beamWidth = 800 - position.x;
|
}
|
||||||
beamY = position.y + (actorSprite.getGlobalBounds().height / 2) - 25.f;
|
default:
|
||||||
beam = Beam(beamX, beamY, beamWidth, beamHeight, sf::Color::Red);
|
break;
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
beam = Beam(beamX, beamY, beamWidth, beamHeight, sf::Color::Red);
|
|
||||||
beam.setVisible(true);
|
|
||||||
|
|
||||||
shooting = true;
|
shooting = true;
|
||||||
shootingClock.restart();
|
shootingClock.restart();
|
||||||
}
|
}
|
||||||
@@ -59,31 +63,53 @@ void Wiazkowiec::spawnBeam() {
|
|||||||
void Wiazkowiec::shoot() {
|
void Wiazkowiec::shoot() {
|
||||||
if (!shooting) {
|
if (!shooting) {
|
||||||
spawnBeam();
|
spawnBeam();
|
||||||
std::cout << "Wiazkowiec shot a beam!" << std::endl;
|
}
|
||||||
|
switch (direction) {
|
||||||
|
case DirectionW::Up: {
|
||||||
|
std::cout << "Direction is up" << std::endl;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case DirectionW::Down: {
|
||||||
|
std::cout << "Direction is down" << std::endl;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case DirectionW::Left: {
|
||||||
|
std::cout << "Direction is left" << std::endl;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case DirectionW::Right: {
|
||||||
|
std::cout << "Direction is right" << std::endl;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Wiazkowiec::setRandomDirection() {
|
void Wiazkowiec::setRandomDirection() {
|
||||||
// Losowanie kierunku: 0 = Up, 1 = Down, 2 = Left, 3 = Right
|
// Losowanie kierunku: 0 = Up, 1 = Down, 2 = Left, 3 = Right
|
||||||
int directionIndex = std::rand() % 4;
|
|
||||||
|
|
||||||
switch (directionIndex) {
|
int whatNumber = rand() % 4;
|
||||||
|
|
||||||
|
switch (whatNumber) {
|
||||||
case 0:
|
case 0:
|
||||||
direction = DirectionW::Up;
|
direction = DirectionW::Up;
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
direction = DirectionW::Down;
|
direction = DirectionW::Down;
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
direction = DirectionW::Left;
|
direction = DirectionW::Left;
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
direction = DirectionW::Right;
|
direction = DirectionW::Right;
|
||||||
break;
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Wiazkowiec::updateDirection() {
|
void Wiazkowiec::checkIfBeamShootOutOfBounds() {
|
||||||
auto spriteBounds = actorSprite.getGlobalBounds(); // Pobierz rozmiar i pozycję sprite'a
|
auto spriteBounds = actorSprite.getGlobalBounds(); // Pobierz rozmiar i pozycję sprite'a
|
||||||
|
|
||||||
// Kontrola górnej i dolnej krawędzi
|
// Kontrola górnej i dolnej krawędzi
|
||||||
@@ -106,17 +132,17 @@ void Wiazkowiec::move(float deltaX, float deltaY) {
|
|||||||
auto spriteBounds = actorSprite.getGlobalBounds(); // Rozmiar i pozycja sprite'a
|
auto spriteBounds = actorSprite.getGlobalBounds(); // Rozmiar i pozycja sprite'a
|
||||||
|
|
||||||
// Zapobiegaj wyjściu poza poziome granice
|
// Zapobiegaj wyjściu poza poziome granice
|
||||||
if (position.x + deltaX < 0) {
|
if (static_cast<float>(position.x) + deltaX < 0) {
|
||||||
deltaX = -position.x;
|
deltaX = static_cast<float>(-position.x);
|
||||||
} else if (position.x + spriteBounds.width + deltaX > planszaWidth) {
|
} else if (static_cast<float>(position.x) + spriteBounds.width + deltaX > static_cast<float>(planszaWidth)) {
|
||||||
deltaX = planszaWidth - (position.x + spriteBounds.width);
|
deltaX = static_cast<float>(planszaWidth) - (static_cast<float>(position.x) + spriteBounds.width);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Zapobiegaj wyjściu poza pionowe granice
|
// Zapobiegaj wyjściu poza pionowe granice
|
||||||
if (position.y + deltaY < 0) {
|
if (static_cast<float>(position.y) + deltaY < 0) {
|
||||||
deltaY = -position.y;
|
deltaY = static_cast<float>(-position.y);
|
||||||
} else if (position.y + spriteBounds.height + deltaY > planszaHeight) {
|
} else if (static_cast<float>(position.y) + spriteBounds.height + deltaY > static_cast<float>(planszaHeight)) {
|
||||||
deltaY = planszaHeight - (position.y + spriteBounds.height);
|
deltaY = static_cast<float>(planszaHeight) - (static_cast<float>(position.y) + spriteBounds.height);
|
||||||
}
|
}
|
||||||
|
|
||||||
actorSprite.move(deltaX, deltaY);
|
actorSprite.move(deltaX, deltaY);
|
||||||
@@ -133,42 +159,39 @@ void Wiazkowiec::update() {
|
|||||||
if (shooting) {
|
if (shooting) {
|
||||||
// Kontrola zakończenia strzału
|
// Kontrola zakończenia strzału
|
||||||
if (shootingClock.getElapsedTime().asSeconds() >= beamDuration) {
|
if (shootingClock.getElapsedTime().asSeconds() >= beamDuration) {
|
||||||
beam.setVisible(false);
|
|
||||||
shooting = false;
|
shooting = false;
|
||||||
|
delete beam;
|
||||||
|
beam = nullptr;
|
||||||
setRandomDirection(); // Zmień kierunek po strzale
|
setRandomDirection(); // Zmień kierunek po strzale
|
||||||
|
} else {
|
||||||
|
window_ptr->draw(beam->getSprite());
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
updateDirection();
|
checkIfBeamShootOutOfBounds();
|
||||||
|
|
||||||
switch (direction) {
|
switch (direction) {
|
||||||
case DirectionW::Up:
|
case DirectionW::Up:
|
||||||
moveUp();
|
moveUp();
|
||||||
break;
|
break;
|
||||||
case DirectionW::Down:
|
case DirectionW::Down:
|
||||||
moveDown();
|
moveDown();
|
||||||
break;
|
break;
|
||||||
case DirectionW::Left:
|
case DirectionW::Left:
|
||||||
moveLeft();
|
moveLeft();
|
||||||
break;
|
break;
|
||||||
case DirectionW::Right:
|
case DirectionW::Right:
|
||||||
moveRight();
|
moveRight();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (shootClock.getElapsedTime().asSeconds() >= 3.0f) { // Co 3 sekundy
|
if (shootClock.getElapsedTime().asSeconds() >= 3.0f) {
|
||||||
|
// Co 3 sekundy
|
||||||
shoot();
|
shoot();
|
||||||
shootClock.restart();
|
shootClock.restart();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Ustawianie widoczności wiązki podczas renderowania
|
|
||||||
void Wiazkowiec::render(sf::RenderWindow& window) {
|
|
||||||
if (beam.isVisible()) {
|
|
||||||
beam.render(window);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
bool Wiazkowiec::isAlive() const {
|
bool Wiazkowiec::isAlive() const {
|
||||||
return alive;
|
return alive;
|
||||||
}
|
}
|
||||||
@@ -176,6 +199,7 @@ bool Wiazkowiec::isAlive() const {
|
|||||||
void Wiazkowiec::takeDamage() {
|
void Wiazkowiec::takeDamage() {
|
||||||
if (--hp <= 0) {
|
if (--hp <= 0) {
|
||||||
alive = false;
|
alive = false;
|
||||||
|
Plansza::score += 10;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -183,6 +207,6 @@ bool Wiazkowiec::isShooting() const {
|
|||||||
return shooting;
|
return shooting;
|
||||||
}
|
}
|
||||||
|
|
||||||
const Beam& Wiazkowiec::getBeam() const {
|
Beam* Wiazkowiec::getBeam() const {
|
||||||
return beam;
|
return beam;
|
||||||
}
|
}
|
||||||
|
|||||||