2019-06-07 02:59:27 +02:00
|
|
|
#include <memory>
|
|
|
|
|
2019-06-06 21:30:39 +02:00
|
|
|
//
|
|
|
|
// Created by trotfunky on 06/06/19.
|
|
|
|
//
|
|
|
|
|
|
|
|
#include "Game.h"
|
|
|
|
|
2019-06-07 02:59:27 +02:00
|
|
|
|
2019-06-07 22:20:34 +02:00
|
|
|
Game::Game(std::vector<std::string>& levels, std::vector<std::string>& textures) : levelFiles(std::move(levels)),
|
|
|
|
textureFiles(std::move(textures))
|
2019-06-07 02:59:27 +02:00
|
|
|
{
|
|
|
|
loadTextures();
|
|
|
|
}
|
|
|
|
|
|
|
|
void Game::loadLevel(int levelId)
|
|
|
|
{
|
|
|
|
pugi::xml_document document;
|
2019-06-07 22:20:34 +02:00
|
|
|
pugi::xml_parse_result result = document.load_file((pro_maat::levelFolder+levelFiles.at(levelId)).c_str());
|
2019-06-07 02:59:27 +02:00
|
|
|
|
|
|
|
if(!result)
|
|
|
|
{
|
2019-06-07 22:20:34 +02:00
|
|
|
pro_maat::errorWindow(result.description());
|
2019-06-07 02:59:27 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
currentLevel = std::make_unique<Level>(document,textures);
|
|
|
|
}
|
|
|
|
|
|
|
|
void Game::loadTextures()
|
|
|
|
{
|
|
|
|
textures.reserve(textureFiles.size());
|
|
|
|
for(const std::string& filePath : textureFiles)
|
|
|
|
{
|
|
|
|
textures.emplace_back(std::make_unique<sf::Texture>());
|
2019-06-07 22:20:34 +02:00
|
|
|
textures.back()->loadFromFile(pro_maat::textureFolder+filePath);
|
2019-06-07 02:59:27 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void Game::runGame()
|
|
|
|
{
|
2019-06-07 22:20:34 +02:00
|
|
|
sf::RenderWindow window(sf::VideoMode(1280,1024),"Project Maat");
|
2019-06-07 02:59:27 +02:00
|
|
|
|
2019-06-08 01:14:52 +02:00
|
|
|
sf::Clock clock;
|
|
|
|
|
2019-06-07 22:20:34 +02:00
|
|
|
while (window.isOpen())
|
|
|
|
{
|
|
|
|
sf::Event event;
|
|
|
|
while (window.pollEvent(event))
|
|
|
|
{
|
|
|
|
if (event.type == sf::Event::Closed)
|
|
|
|
{
|
|
|
|
window.close();
|
|
|
|
}
|
2019-06-08 01:54:58 +02:00
|
|
|
}
|
|
|
|
if (clock.getElapsedTime().asMilliseconds() >= 200)
|
|
|
|
{
|
|
|
|
currentLevel->runStep();
|
|
|
|
clock.restart();
|
2019-06-07 22:20:34 +02:00
|
|
|
}
|
|
|
|
window.clear(sf::Color::White);
|
|
|
|
// TODO : Consider drawing in a sf::RenderTexture to allow positioning the level at a fixed position ?
|
|
|
|
currentLevel->render(window);
|
|
|
|
window.display();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Game::operator bool() const
|
|
|
|
{
|
|
|
|
return (currentLevel ? true : false);
|
2019-06-07 02:59:27 +02:00
|
|
|
}
|