skizzle/include/level.hpp

175 lines
3.7 KiB
C++
Raw Normal View History

#ifndef __PTF_LEVEL_HPP__
#define __PTF_LEVEL_HPP__
#include <fstream>
#include <vector>
#include "state.hpp"
#include "object.hpp"
#include "manager.hpp"
#include "resource_manager.hpp"
// 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;
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<std::pair<float, float>> zone;
protected:
2016-04-09 00:32:11 +00:00
/**
* 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();
/**
* Charge un niveau de jeu avec le nom donné
*/
2016-04-10 04:53:45 +00:00
virtual void load(std::string filename);
/**
* Sauvegarde la configuration actuelle dans le niveau donné
*/
2016-04-10 04:53:45 +00:00
virtual void save(std::string filename);
2016-04-09 00:32:11 +00:00
/**
2016-04-09 21:57:23 +00:00
* Appelé par le manager lorsque l'état est utilisé
2016-04-09 00:32:11 +00:00
*/
virtual void begin();
/**
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
*/
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
*/
void setMusic(std::string set_music);
/**
* 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 (version constante)
*/
2016-04-10 05:37:09 +00:00
const std::vector<Object::Ptr>& getObjects() const;
/**
* Récupère la zone du niveau
*/
std::vector<std::pair<float, float>>& getZone();
/**
* Récupère la zone du niveau (version constante)
*/
const std::vector<std::pair<float, float>>& 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