2016-04-05 23:13:00 +00:00
|
|
|
#ifndef __PTF_EDITOR_HPP__
|
|
|
|
#define __PTF_EDITOR_HPP__
|
2016-04-03 20:08:11 +00:00
|
|
|
|
2016-04-05 17:27:37 +00:00
|
|
|
#include <unordered_map>
|
2016-04-03 20:08:11 +00:00
|
|
|
#include "level.hpp"
|
2016-04-05 22:31:46 +00:00
|
|
|
#include "util/widget_timer.hpp"
|
2016-04-08 13:54:19 +00:00
|
|
|
#include "util/widget_selector.hpp"
|
2016-04-03 20:08:11 +00:00
|
|
|
|
2016-04-07 20:19:38 +00:00
|
|
|
enum class DragMode {NONE, PLACE, SELECT_RECT, SELECT_BULK, REMOVE};
|
2016-04-07 18:59:08 +00:00
|
|
|
enum class SelectionMode {REPLACE, FLIP, ADD};
|
|
|
|
|
2016-04-03 20:08:11 +00:00
|
|
|
/**
|
|
|
|
* La classe Editor permet l'édition de
|
|
|
|
* niveaux du jeu
|
|
|
|
*/
|
|
|
|
class Editor : public Level {
|
2016-04-05 15:50:28 +00:00
|
|
|
private:
|
2016-04-07 09:22:20 +00:00
|
|
|
std::vector<ObjectPtr> selection;
|
2016-04-08 00:21:19 +00:00
|
|
|
sf::Vector2i drag_start;
|
|
|
|
sf::Vector2i drag_end;
|
2016-04-07 18:59:08 +00:00
|
|
|
DragMode drag_mode;
|
2016-04-09 00:32:11 +00:00
|
|
|
|
2016-04-05 22:31:46 +00:00
|
|
|
WidgetTimer widget_timer;
|
2016-04-08 13:54:19 +00:00
|
|
|
WidgetSelector widget_selector;
|
2016-04-05 17:27:37 +00:00
|
|
|
|
2016-04-07 18:59:08 +00:00
|
|
|
/**
|
|
|
|
* Renvoie l'objet pointé à la position donnée
|
|
|
|
* ou nullptr si aucun
|
|
|
|
*/
|
|
|
|
ObjectPtr getObject(sf::Vector2f position);
|
|
|
|
|
2016-04-05 17:27:37 +00:00
|
|
|
/**
|
|
|
|
* Ajoute un objet du type actuel à la position donnée
|
|
|
|
*/
|
2016-04-07 18:59:08 +00:00
|
|
|
ObjectPtr addObject(sf::Vector2f position);
|
2016-04-05 17:27:37 +00:00
|
|
|
|
|
|
|
/**
|
2016-04-07 18:59:08 +00:00
|
|
|
* Supprime l'objet à la position donnée ou passé par pointeur
|
2016-04-05 17:27:37 +00:00
|
|
|
*/
|
2016-04-07 18:59:08 +00:00
|
|
|
void removeObject(ObjectPtr object);
|
2016-04-05 17:27:37 +00:00
|
|
|
void removeObject(sf::Vector2f position);
|
|
|
|
|
|
|
|
/**
|
2016-04-07 20:01:07 +00:00
|
|
|
* Ajoute l'objet/les objets donné(s) (par position, entre deux
|
|
|
|
* positions ou par pointeur) à la sélection
|
2016-04-07 18:59:08 +00:00
|
|
|
*
|
|
|
|
* - REPLACE : remplace toute sélection précédente
|
|
|
|
* - FLIP : sélectionne l'élément s'il ne l'est pas, sinon le désélectionne
|
|
|
|
* - ADD : rajoute à la sélection courante
|
2016-04-05 17:27:37 +00:00
|
|
|
*/
|
2016-04-07 18:59:08 +00:00
|
|
|
void select(ObjectPtr object, SelectionMode mode);
|
|
|
|
void select(sf::Vector2f position, SelectionMode mode);
|
2016-04-07 20:01:07 +00:00
|
|
|
void select(sf::Vector2f top_left, sf::Vector2f bottom_right);
|
2016-04-05 15:50:28 +00:00
|
|
|
|
2016-04-05 23:13:00 +00:00
|
|
|
/**
|
2016-04-07 22:19:01 +00:00
|
|
|
* Vide la sélection
|
2016-04-05 23:13:00 +00:00
|
|
|
*/
|
2016-04-07 22:19:01 +00:00
|
|
|
void clearSelection();
|
2016-04-07 20:01:07 +00:00
|
|
|
|
|
|
|
/**
|
2016-04-07 22:19:01 +00:00
|
|
|
* Sélectionne tout
|
2016-04-07 20:01:07 +00:00
|
|
|
*/
|
2016-04-07 22:19:01 +00:00
|
|
|
void selectAll();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Lance le test du niveau
|
|
|
|
*/
|
|
|
|
void test();
|
2016-04-05 23:13:00 +00:00
|
|
|
|
2016-04-05 15:50:28 +00:00
|
|
|
protected:
|
|
|
|
/**
|
|
|
|
* Dessine tous les objets, le fond et
|
|
|
|
* l'interface de l'éditeur
|
|
|
|
*/
|
|
|
|
virtual void draw();
|
|
|
|
|
2016-04-07 22:19:01 +00:00
|
|
|
/**
|
2016-04-08 00:35:17 +00:00
|
|
|
* Traite un événement
|
2016-04-07 22:19:01 +00:00
|
|
|
*/
|
2016-04-08 00:35:17 +00:00
|
|
|
virtual void processEvent(const sf::Event& event);
|
2016-04-07 22:19:01 +00:00
|
|
|
|
2016-04-03 20:08:11 +00:00
|
|
|
public:
|
|
|
|
Editor(Manager& manager);
|
|
|
|
virtual ~Editor();
|
|
|
|
|
2016-04-05 18:07:58 +00:00
|
|
|
/**
|
2016-04-09 00:32:11 +00:00
|
|
|
* Appelé par le manager lorsque la vue commence à
|
|
|
|
* être utilisée
|
2016-04-05 18:07:58 +00:00
|
|
|
*/
|
2016-04-09 00:32:11 +00:00
|
|
|
virtual void begin();
|
2016-04-05 18:07:58 +00:00
|
|
|
|
2016-04-03 20:08:11 +00:00
|
|
|
/**
|
2016-04-09 00:32:11 +00:00
|
|
|
* Demande le passage à la frame suivante sur cette vue
|
2016-04-03 20:08:11 +00:00
|
|
|
*/
|
2016-04-09 00:32:11 +00:00
|
|
|
virtual void frame(const std::vector<sf::Event>& events);
|
2016-04-03 20:08:11 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|