#ifndef __SKIZZLE_LEVEL_HPP__ #define __SKIZZLE_LEVEL_HPP__ #include #include #include "../objects/object.hpp" #include "../objects/player.hpp" #include "state.hpp" class Manager; // liste des directions de la gravité enum class GravityDirection {NORTH, EAST, SOUTH, WEST}; /** * La classe Level est une abstraction des * classes affichant une collection d'objets, comme * les classes de l'éditeur et du jeu */ class Level : public State { private: sf::View camera; float camera_angle; GravityDirection gravity_direction; sf::String name; std::string path; int total_time; sf::Sprite background_sprite; std::string background; std::string music; std::vector objects; std::vector players; std::vector zone; protected: /** * Dessine tous les objets et le fond à l'écran */ virtual void draw(); /** * Convertit les coordonnées à l'écran en coordonnées du monde * d'après la vue caméra */ sf::Vector2f pixelToCoords(sf::Vector2i pixel); /** * Convertit les coordonnées du monde en coordonnées à l'écran * d'après la vue caméra */ sf::Vector2i coordsToPixel(sf::Vector2f coords); public: Level(Manager& manager); virtual ~Level(); /** * Active l'état */ virtual void enable(); /** * Charge le niveau de jeu donné depuis le fichier actuel */ void load(); /** * Sauvegarde la configuration actuelle dans le fichier actuel */ void save(); /** * Récupère le chemin actuel du fichier du niveau */ std::string getPath(); /** * Modifie le chemin actuel du fichier du niveau */ void setPath(std::string set_path); /** * Traite l'événement donné */ virtual void processEvent(const sf::Event& event); /** * Récupère le nom du niveau */ sf::String getName() const; /** * Modifie le nom du niveau */ void setName(sf::String set_name); /** * Récupère le temps total alloué pour terminer le niveau */ int getTotalTime() const; /** * Modifie le temps total du niveau */ virtual void setTotalTime(int set_total_time); /** * Récupère la musique du niveau */ std::string getMusic() const; /** * Modifie la musique du niveau */ virtual void setMusic(std::string set_music); /** * Récupère le fond du niveau */ std::string getBackground() const; /** * Modifie le fond du niveau */ void setBackground(std::string set_background); /** * Calcule le vecteur gravité en fonction de la direction de la gravité */ sf::Vector2f getGravity() const; /** * Calcule la direction gauche en fonction de la direction de la gravité */ sf::Vector2f getLeftDirection() const; /** * Calcule la direction droite en fonction de la direction de la gravité */ sf::Vector2f getRightDirection() const; /** * Récupère la direction de la gravité */ GravityDirection getGravityDirection(); /** * Modifie la direction de la gravité */ void setGravityDirection(GravityDirection set_gravity_direction); /** * Récupère la liste des objets */ std::vector& getObjects(); /** * Récupère la liste des objets (constante) */ const std::vector& getObjects() const; /** * Récupère la liste des joueurs */ std::vector& getPlayers(); /** * Récupère la liste des joueurs (constante) */ const std::vector& getPlayers() const; /** * Ajoute un nouvel objet. Retourne l'objet * si il a bien été ajouté, ou nullptr si l'ajout * a été bloqué */ Object::Ptr addObject(Object::Ptr object); /** * Supprime l'objet donné */ void removeObject(Object::Ptr object); void removeObject(Object* object); /** * Récupère la zone du niveau */ std::vector& getZone(); /** * Récupère la zone du niveau (version constante) */ const std::vector& getZone() const; /** * Récupère la caméra actuelle */ sf::View getCamera() const; /** * Modifie la caméra */ void setCamera(sf::View set_camera); }; #endif