skizzle/src/manager.cpp

251 lines
7.2 KiB
C++
Raw Permalink Normal View History

#include <algorithm>
2016-04-20 17:03:02 +00:00
#include <boost/filesystem.hpp>
#include "states/state.hpp"
#include "resource_manager.hpp"
#include "manager.hpp"
const unsigned int Manager::FPS = 60;
const sf::Time Manager::FRAME_TIME = sf::seconds(1.f / Manager::FPS);
const float Manager::GRID = 32;
2016-04-20 15:31:13 +00:00
Manager::Manager() : title(sf::String(L"")), previous_time(sf::seconds(0)),
2016-04-18 10:05:45 +00:00
previous_state(nullptr) {
ResourceManager& res = ResourceManager::get();
2016-04-20 15:31:13 +00:00
// ajout des polices dans le gestionnaire de ressources
// de la librairie pour l'interface
desktop.GetEngine().GetResourceManager().AddFont(
"overpass", ResourceManager::get().getFont("overpass.ttf")
);
2016-04-20 15:31:13 +00:00
desktop.GetEngine().GetResourceManager().AddFont(
"overpass-bold", ResourceManager::get().getFont("overpass-bold.ttf")
);
2016-04-20 15:31:13 +00:00
desktop.GetEngine().GetResourceManager().AddFont(
"monoid", ResourceManager::get().getFont("monoid.ttf")
);
// chargement du thème de l'interface
2016-04-19 22:29:13 +00:00
desktop.LoadThemeFromFile("res/gui.theme");
// préchargement des textures dans le GPU
2016-04-20 17:03:02 +00:00
for (const auto &texture : res.getFiles(res.getTexturesPath())) {
res.getTexture(texture);
// on vide la file d'attente des événements pendant le
// chargement des textures pour éviter que le système
// pense que le programme a planté
sf::Event event;
while (window.pollEvent(event)) {}
}
// préchargement des images dans la RAM
for (const auto &image : res.getFiles(res.getImagesPath())) {
res.getImage(image);
// mêmes raisons que ci-dessus
sf::Event event;
while (window.pollEvent(event)) {}
}
2016-04-20 15:31:13 +00:00
// création de la fenêtre du jeu
2016-04-20 16:07:24 +00:00
window.create(
sf::VideoMode(704, 480), "Skizzle", sf::Style::Default,
sf::ContextSettings(0, 0, 1)
);
2016-04-20 15:31:13 +00:00
// FIXME: après avoir supprimé ::useGUIView(), supprimer ceci
// récupération de la vue par défaut comme vue du gui
gui_view = window.getDefaultView();
}
Manager::~Manager() {
widgets.clear();
desktop.RemoveAll();
}
void Manager::start() {
2016-04-11 19:11:34 +00:00
while (!states.empty()) {
sf::Event event;
// traitement des évènements reçus
while (window.pollEvent(event)) {
2016-04-11 19:11:34 +00:00
// fermeture de la fenêtre : on dépile tous les états
if (event.type == sf::Event::Closed) {
2016-04-11 19:11:34 +00:00
while (!states.empty()) {
states.pop();
}
}
2016-04-20 15:31:13 +00:00
// FIXME: après avoir supprimé ::useGUIView(), supprimer ceci
2016-04-09 00:32:11 +00:00
// redimensionnement de la vue par défaut
2016-04-08 00:21:19 +00:00
if (event.type == sf::Event::Resized) {
gui_view = sf::View(sf::FloatRect(
2016-04-08 00:21:19 +00:00
0, 0, event.size.width, event.size.height
));
}
2016-04-20 15:31:13 +00:00
///////////////////////////
2016-04-08 00:21:19 +00:00
2016-04-18 10:05:45 +00:00
// événements de l'interface
desktop.HandleEvent(event);
2016-04-11 19:11:34 +00:00
// s'il n'y a plus d'état, on quitte
if (states.empty()) {
return;
}
// seulement si l'événement ne s'est pas passé dans l'interface
// on le fait passer aux gestionnaires "normaux"
if (!isInsideGUI(event)) {
states.top()->processEvent(event);
}
2016-04-11 19:11:34 +00:00
}
2016-04-11 19:11:34 +00:00
// s'il n'y a plus d'état, on quitte
if (states.empty()) {
return;
}
2016-04-18 10:05:45 +00:00
// si l'état que l'on va utiliser n'est pas le même que précédemment,
// on l'active. Ceci permet un partage plus facile des ressources
// globales (vue, musique)
if (previous_state != states.top().get()) {
previous_state = states.top().get();
2016-04-18 10:05:45 +00:00
// on masque tous les widgets de l'interface
for (const auto &widget : widgets) {
widget->Show(false);
}
2016-04-18 10:05:45 +00:00
// on initialise le nouvel état
previous_state->enable();
}
2016-04-18 10:05:45 +00:00
// demande à l'état actuel de dessiner une frame
2016-04-11 19:11:34 +00:00
states.top()->frame();
2016-04-18 10:05:45 +00:00
// dessin de l'interface
sf::View normal_view = window.getView();
desktop.Update((getCurrentTime() - previous_time).asSeconds());
previous_time = getCurrentTime();
sfgui.Display(window);
window.setView(normal_view);
// envoi à l'écran pour affichage
window.display();
}
}
2016-04-11 19:11:34 +00:00
void Manager::pushState(std::unique_ptr<State> set_state) {
states.push(std::move(set_state));
}
2016-04-11 19:11:34 +00:00
void Manager::popState() {
states.pop();
2016-03-28 17:57:55 +00:00
}
bool Manager::isInsideGUI(const sf::Event& event) {
sf::Vector2f check_point;
bool should_check_point = false;
if (event.type == sf::Event::MouseButtonPressed ||
event.type == sf::Event::MouseButtonReleased) {
check_point.x = event.mouseButton.x;
check_point.y = event.mouseButton.y;
should_check_point = true;
}
if (event.type == sf::Event::MouseMoved) {
check_point.x = event.mouseMove.x;
check_point.y = event.mouseMove.y;
should_check_point = true;
}
if (event.type == sf::Event::MouseWheelScrolled) {
check_point.x = event.mouseWheelScroll.x;
check_point.y = event.mouseWheelScroll.y;
should_check_point = true;
}
// si l'événement est de type souris, on regarde que
// le point en question ne se trouve pas dans un des widgets
if (should_check_point) {
for (auto const &widget : widgets) {
if (widget->GetAllocation().contains(check_point)) {
return true;
}
}
}
return false;
}
2016-04-20 15:31:13 +00:00
sf::Time Manager::getCurrentTime() const {
return clock.getElapsedTime();
}
sf::RenderWindow& Manager::getWindow() {
return window;
}
// FIXME: à supprimer après avoir supprimé ::useGUIView()
void Manager::useGUIView() {
window.setView(gui_view);
}
///////////////////////////
void Manager::addWidget(sfg::Widget::Ptr widget) {
widgets.push_back(widget);
desktop.Add(widget);
}
void Manager::removeWidget(sfg::Widget::Ptr widget) {
desktop.Remove(widget);
widgets.erase(std::remove(
widgets.begin(), widgets.end(), widget
), widgets.end());
2016-04-18 10:05:45 +00:00
}
2016-04-06 11:41:12 +00:00
sf::String Manager::getTitle() {
return title;
}
2016-04-06 11:41:12 +00:00
void Manager::setTitle(sf::String set_title) {
if (title != set_title) {
title = set_title;
// màj du titre selon le titre donné par l'état
if (title.isEmpty()) {
window.setTitle(sf::String(L"Skizzle"));
} else {
window.setTitle(sf::String(L"Skizzle ") + title);
}
}
}
bool Manager::isKeyPressed(sf::Keyboard::Key key) const {
return sf::Keyboard::isKeyPressed(key) && window.hasFocus();
}
bool Manager::isKeyPressed(Manager::Modifier modifier) const {
switch (modifier) {
case Manager::Modifier::CONTROL:
return isKeyPressed(sf::Keyboard::LControl) || isKeyPressed(sf::Keyboard::RControl);
case Manager::Modifier::ALT:
return isKeyPressed(sf::Keyboard::LAlt) || isKeyPressed(sf::Keyboard::RAlt);
case Manager::Modifier::SYSTEM:
return isKeyPressed(sf::Keyboard::LSystem) || isKeyPressed(sf::Keyboard::RSystem);
case Manager::Modifier::SHIFT:
return isKeyPressed(sf::Keyboard::LShift) || isKeyPressed(sf::Keyboard::RShift);
}
return false;
}