5 Commits

2 changed files with 56 additions and 14 deletions

View File

@@ -43,7 +43,7 @@ void Boss::dropBomb() {
if (bombClock.getElapsedTime().asMilliseconds() >= 5000) { if (bombClock.getElapsedTime().asMilliseconds() >= 5000) {
Bullet Bomb(position.x, position.y, BombaTexture); Bullet Bomb(position.x, position.y, BombaTexture);
Bomb.setSpeed(0.5f); Bomb.setSpeed(0.5f);
bullets.emplace_back(std::move(Bomb)); // Można zmienić na bombę bombs.emplace_back(std::move(Bomb)); // Można zmienić na bombę
std::cout << "Bombka lezy" << std::endl; std::cout << "Bombka lezy" << std::endl;
bombClock.restart(); bombClock.restart();
} }
@@ -161,9 +161,9 @@ void Boss::setRandomDirection() {
direction = static_cast<BossDirection>(randomValue); direction = static_cast<BossDirection>(randomValue);
} while ( } while (
(direction == BossDirection::Left && position.x <= 0) || (direction == BossDirection::Left && position.x <= 0) ||
(direction == BossDirection::Right && position.x >= planszaWidth) || (direction == BossDirection::Right && position.x >= 600) ||
(direction == BossDirection::Up && position.y <= 0) || (direction == BossDirection::Up && position.y <= 0) ||
(direction == BossDirection::Down && position.y >= planszaHeight) (direction == BossDirection::Down && position.y >= 800)
); );
if (previousDirection == direction) { if (previousDirection == direction) {
std::cerr << "Boss kept the same direction: " << static_cast<int>(direction) << std::endl; std::cerr << "Boss kept the same direction: " << static_cast<int>(direction) << std::endl;
@@ -174,18 +174,14 @@ void Boss::setRandomDirection() {
void Boss::handleBounds() { void Boss::handleBounds() {
if (position.x < 0) { if (position.x < 0) {
position.x = 0;
direction = BossDirection::Right; direction = BossDirection::Right;
} else if (position.x > planszaWidth - actorSprite.getGlobalBounds().width) { } else if (position.x > 600 - actorSprite.getGlobalBounds().width) {
position.x = planszaWidth - actorSprite.getGlobalBounds().width;
direction = BossDirection::Left; direction = BossDirection::Left;
} }
if (position.y < 0) { if (position.y < 0) {
position.y = 0;
direction = BossDirection::Down; direction = BossDirection::Down;
} else if (position.y > planszaHeight - actorSprite.getGlobalBounds().height) { } else if (position.y > 800 - actorSprite.getGlobalBounds().height) {
position.y = planszaHeight - actorSprite.getGlobalBounds().height;
direction = BossDirection::Up; direction = BossDirection::Up;
} }
} }

View File

@@ -118,7 +118,7 @@ void Plansza::update() {
spawn_hearts(); spawn_hearts();
spawn_power_up(); spawn_power_up();
// spawn_enemy(); // spawn_enemy();
spawn_advanced_enemy(); // spawn_advanced_enemy();
// spawn_wiazkowiec(); // spawn_wiazkowiec();
// spawn_bomber(); // spawn_bomber();
// spawn_kamikadze(); // spawn_kamikadze();
@@ -382,10 +382,20 @@ void Plansza::update() {
} }
} }
// Kolizja bossa z graczem for (auto rocketIt = ship->getRockets().begin(); rocketIt != ship->getRockets().end();) {
if (ship->getSprite().getGlobalBounds().intersects(boss->getSprite().getGlobalBounds())) { if (boss->getSprite().getGlobalBounds().intersects(rocketIt->getSprite().getGlobalBounds())) {
ship->takeDamage(); boss->takeDamage();
rocketIt = ship->getRockets().erase(rocketIt);
std::cout << "Rocket hit boss! Boss HP: " << boss->getHP() << std::endl;
} else {
++rocketIt;
}
} }
// Kolizja bossa z graczem
// if (ship->getSprite().getGlobalBounds().intersects(boss->getSprite().getGlobalBounds())) {
// ship->takeDamage();
// }
} else if (bossSpawned && (!boss || !boss->isAlive())) { } else if (bossSpawned && (!boss || !boss->isAlive())) {
std::cout << "Boss defeated!" << std::endl; std::cout << "Boss defeated!" << std::endl;
delete boss; delete boss;
@@ -414,12 +424,48 @@ void Plansza::update() {
} }
} }
if (boss->isShooting() && boss->getBeam() != nullptr) { if (boss->isShooting() && boss->getBeam() != nullptr) {
if (ship->getSprite().getGlobalBounds().intersects(boss->getBeam()->getSprite().getGlobalBounds())) { if (ship->getSprite().getGlobalBounds().intersects(boss->getBeam()->getSprite().getGlobalBounds())) {
ship->takeDamage(); // Gracz otrzymuje obrażenia ship->takeDamage(); // Gracz otrzymuje obrażenia
} }
} }
// Sprawdzenie kolizji pocisków gracza z bombami Bossa
for (auto bombIt = boss->getBombs().begin(); bombIt != boss->getBombs().end();) {
bool bombHit = false;
for (auto bulletIt = ship->getBullets().begin(); bulletIt != ship->getBullets().end();) {
if (bombIt->getSprite().getGlobalBounds().intersects(bulletIt->getSprite().getGlobalBounds())) {
ship->getBullets().erase(bulletIt);
bombIt = boss->getBombs().erase(bombIt);
bombHit = true;
break;
} else {
++bulletIt;
}
}
if (!bombHit) {
++bombIt;
}
}
// Sprawdzenie kolizji rakiet gracza z bombami Bossa
for (auto bombIt = boss->getBombs().begin(); bombIt != boss->getBombs().end();) {
bool bombHit = false;
for (auto rocketIt = ship->getRockets().begin(); rocketIt != ship->getRockets().end();) {
if (bombIt->getSprite().getGlobalBounds().intersects(rocketIt->getSprite().getGlobalBounds())) {
ship->getRockets().erase(rocketIt);
bombIt = boss->getBombs().erase(bombIt);
bombHit = true;
break;
} else {
++rocketIt;
}
}
if (!bombHit) {
++bombIt;
}
}
} }
@@ -858,7 +904,7 @@ void Plansza::spawn_advanced_enemy() {
} }
void Plansza::spawn_bomber() { void Plansza::spawn_bomber() {
if (BomberSpawnClock.getElapsedTime().asSeconds() >= 30) { // Spawn co 10 sekund if (BomberSpawnClock.getElapsedTime().asSeconds() >= 5) { // 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