Merge zrobiony

This commit is contained in:
2024-11-22 12:48:38 +01:00
parent ec3d4e78ce
commit c4a3203153

View File

@@ -28,16 +28,18 @@ int main()
audioManager.loadSoundEffect("shoot", "../assets/sounds/shoot.ogg"); audioManager.loadSoundEffect("shoot", "../assets/sounds/shoot.ogg");
audioManager.loadSoundEffect("shoot_alt", "../assets/sounds/shoot_alt.ogg"); audioManager.loadSoundEffect("shoot_alt", "../assets/sounds/shoot_alt.ogg");
// TODO: Przenieść tworzenie statku wewnątrz klasy Plansza // TODO: Przenieść tworzenie statku wewnątrz klasy Plansza
Player ship(mainWindow.getSize().x / 2, mainWindow.getSize().y - 100, "../assets/ship/Dreadnought-Base.png"); // tworzenie statku Player ship(mainWindow.getSize().x / 2, mainWindow.getSize().y - 100, "../assets/ship/Dreadnought-Base.png"); // tworzenie statku
ship.setMovingSpeed(8); ship.setMovingSpeed(8);
ship.setFirerate(200); ship.setFirerate(200);
while (mainWindow.isOpen()) { while (mainWindow.isOpen()) {
// std::cout << "Liczba: " << RandomNumberGenerator::getRandomNumber(0,499) << std::endl;
mainWindow.clear(); mainWindow.clear();
// tło
background.update();
background.draw(mainWindow);
// Tu są handlowane eventy // Tu są handlowane eventy
sf::Event event{}; sf::Event event{};
while (mainWindow.pollEvent(event)) { while (mainWindow.pollEvent(event)) {
@@ -46,23 +48,9 @@ int main()
if(sf::Keyboard::isKeyPressed(sf::Keyboard::Escape)) { if(sf::Keyboard::isKeyPressed(sf::Keyboard::Escape)) {
mainWindow.close(); mainWindow.close();
} }
if(sf::Keyboard::isKeyPressed(sf::Keyboard::Space)) {
ship.shoot();
audioManager.playSoundEffect("shoot");
}
} }
if(event.type == sf::Event::MouseButtonPressed) { // poruszanie się statkiem
if(event.mouseButton.button == sf::Mouse::Left) {
ship.shoot();
audioManager.playSoundEffect("shoot", 70.f); // Odtworzenie dźwięku wystrzału
} else {
ship.alternate_shoot();
audioManager.playSoundEffect("shoot_alt", 70.f); // Odtworzenie dźwięku dla alternatywnego strzału
}
}
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();
@@ -83,19 +71,22 @@ int main()
ship.moveRight(); ship.moveRight();
} }
} }
if(sf::Keyboard::isKeyPressed(sf::Keyboard::Space)) {
// strzelanie ze statku
if(sf::Mouse::isButtonPressed(sf::Mouse::Left)) {
ship.shoot(); 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
if(sf::Mouse::isButtonPressed(sf::Mouse::Left)) ship.shoot();
if(sf::Mouse::isButtonPressed(sf::Mouse::Right)) ship.alternate_shoot();
// Generate a new meteor at a random position at the top of the screen
plansza.spawn_meteor(); plansza.spawn_meteor();
// Update and draw meteors // utrzymanie meteorów i pocisków w ruchu
for (auto& meteor : plansza.getMeteors()) { for (auto& meteor : plansza.getMeteors()) {
meteor.update(); meteor.update();
mainWindow.draw(meteor.getSprite()); mainWindow.draw(meteor.getSprite());
@@ -106,13 +97,10 @@ int main()
mainWindow.draw(bullet.getSprite()); mainWindow.draw(bullet.getSprite());
} }
// tło // Sprawdzenie czy meteory i pociski są poza granicami ekranu
background.update();
background.draw(mainWindow);
plansza.update_meteors(); plansza.update_meteors();
ship.updateBullets(); ship.updateBullets();
mainWindow.draw(ship.getSprite()); mainWindow.draw(ship.getSprite());
// trochę dziwny sposób ale jednak działa // trochę dziwny sposób ale jednak działa
@@ -152,7 +140,7 @@ int main()
bulletIt = ship.getBullets().erase(bulletIt); bulletIt = ship.getBullets().erase(bulletIt);
meteorIt = plansza.getMeteors().erase(meteorIt); meteorIt = plansza.getMeteors().erase(meteorIt);
meteorHit = true; meteorHit = true;
break; // Exit the inner loop to avoid invalidating the iterator break;
} else { } else {
++bulletIt; ++bulletIt;
} }