Merge zrobiony
This commit is contained in:
48
main.cpp
48
main.cpp
@@ -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;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user