skizzle/include/level.hpp

209 lines
4.5 KiB
C++
Raw Normal View History

2016-04-11 21:38:03 +00:00
#ifndef __SKIZZLE_LEVEL_HPP__
#define __SKIZZLE_LEVEL_HPP__
#include <fstream>
#include <vector>
#include "state.hpp"
#include "object.hpp"
#include "player.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:
2016-04-08 00:21:19 +00:00
sf::View camera;
2016-04-09 14:31:09 +00:00
float camera_angle;
GravityDirection gravity_direction;
sf::String name;
std::string current_path;
int total_time;
2016-04-10 04:53:45 +00:00
sf::Sprite background_sprite;
std::string background;
std::string music;
2016-04-10 05:37:09 +00:00
std::vector<Object::Ptr> objects;
std::vector<Player::Ptr> players;
std::vector<sf::Vector2f> zone;
protected:
/**
* Dessine tous les objets et le fond à l'écran
*/
virtual void draw();
2016-04-08 00:21:19 +00:00
/**
* 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();
/**
* Obtient le nom du niveau dont le chemin complet
* et absolu est en paramètre
*/
static sf::String getLevelName(std::string path);
/**
* Charge le niveau de jeu donné depuis le fichier
* dont le chemin complet absolu est en paramètre
*/
void load(std::string path);
/**
* Écrase le niveau chargé avec les données en mémoire
*/
void save();
/**
* Sauvegarde la configuration actuelle dans le fichier donné
* dont le chemin complet absolu est donné en paramètre
*/
void save(std::string path);
/**
2016-04-09 21:57:23 +00:00
* Traite l'événement donné
*/
2016-04-09 21:57:23 +00:00
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
*/
2016-04-11 21:07:05 +00:00
virtual void setTotalTime(int set_total_time);
2016-04-10 04:53:45 +00:00
/**
* Récupère la musique du niveau
*/
std::string getMusic() const;
/**
* Modifie la musique du niveau
*/
2016-04-11 21:07:05 +00:00
virtual void setMusic(std::string set_music);
2016-04-10 04:53:45 +00:00
/**
* Récupère le fond du niveau
*/
2016-04-10 04:53:45 +00:00
std::string getBackground() const;
/**
* Modifie le fond du niveau
*/
2016-04-10 04:53:45 +00:00
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
*/
2016-04-10 05:37:09 +00:00
std::vector<Object::Ptr>& getObjects();
/**
* Récupère la liste des objets (constante)
*/
2016-04-10 05:37:09 +00:00
const std::vector<Object::Ptr>& getObjects() const;
/**
* Récupère la liste des joueurs
*/
std::vector<Player::Ptr>& getPlayers();
/**
* Récupère la liste des joueurs (constante)
*/
const std::vector<Player::Ptr>& getPlayers() const;
/**
2016-04-10 23:37:07 +00:00
* Ajoute un nouvel objet. Retourne l'objet
* si il a bien é ajouté, ou nullptr si l'ajout
* a é bloqué
*/
2016-04-10 23:37:07 +00:00
Object::Ptr addObject(Object::Ptr object);
/**
* Supprime l'objet donné
*/
void removeObject(Object::Ptr object);
2016-04-10 22:56:22 +00:00
void removeObject(Object* object);
/**
* Récupère la zone du niveau
*/
std::vector<sf::Vector2f>& getZone();
/**
* Récupère la zone du niveau (version constante)
*/
const std::vector<sf::Vector2f>& getZone() const;
/**
2016-04-08 00:21:19 +00:00
* Récupère la caméra actuelle
*/
sf::View getCamera() const;
/**
2016-04-08 00:21:19 +00:00
* Modifie la caméra
*/
2016-04-08 00:21:19 +00:00
void setCamera(sf::View set_camera);
};
#endif