Merge pull request #4006 from TheHX/tilemap-editor

Several improvements for the Tilemap editor
This commit is contained in:
Rémi Verschelde 2016-03-15 19:29:39 +01:00
commit cb065b961c
2 changed files with 927 additions and 499 deletions

File diff suppressed because it is too large Load Diff

View File

@ -31,55 +31,57 @@
#include "tools/editor/editor_plugin.h" #include "tools/editor/editor_plugin.h"
#include "tools/editor/editor_node.h" #include "tools/editor/editor_node.h"
#include "scene/2d/tile_map.h" #include "scene/2d/tile_map.h"
#include "scene/gui/line_edit.h"
#include "scene/gui/tool_button.h" #include "scene/gui/tool_button.h"
#include "scene/gui/button_group.h" #include "scene/gui/menu_button.h"
/** /**
@author Juan Linietsky <reduzio@gmail.com> @author Juan Linietsky <reduzio@gmail.com>
*/ */
class CanvasItemEditor;
class TileMapEditor : public VBoxContainer { class TileMapEditor : public VBoxContainer {
OBJ_TYPE(TileMapEditor, VBoxContainer ); OBJ_TYPE(TileMapEditor, VBoxContainer );
UndoRedo *undo_redo;
enum Tool { enum Tool {
TOOL_NONE, TOOL_NONE,
TOOL_PAINTING, TOOL_PAINTING,
TOOL_SELECTING,
TOOL_ERASING, TOOL_ERASING,
TOOL_RECTANGLE_PAINT,
TOOL_RECTANGLE_ERASE,
TOOL_LINE_PAINT,
TOOL_LINE_ERASE,
TOOL_SELECTING,
TOOL_BUCKET,
TOOL_PICKING,
TOOL_DUPLICATING, TOOL_DUPLICATING,
TOOL_PICKING
}; };
enum DisplayMode { enum Options {
DISPLAY_THUMBNAIL,
DISPLAY_LIST OPTION_BUCKET,
OPTION_PICK_TILE,
OPTION_SELECT,
OPTION_DUPLICATE,
OPTION_ERASE_SELECTION
}; };
Tool tool; TileMap *node;
EditorNode *editor;
UndoRedo *undo_redo;
Control *canvas_item_editor; Control *canvas_item_editor;
int display_mode; LineEdit *search_box;
ItemList *palette; ItemList *palette;
ToolButton *button_thumbnail;
ToolButton *button_list; HBoxContainer *toolbar;
EditorNode *editor;
Panel *panel;
TileMap *node;
MenuButton *options; MenuButton *options;
ToolButton *transp;
bool selection_active;
Point2i selection_begin;
Rect2i selection;
Point2i over_tile;
bool mouse_over;
Label *mirror_label;
ToolButton *transpose;
ToolButton *mirror_x; ToolButton *mirror_x;
ToolButton *mirror_y; ToolButton *mirror_y;
ToolButton *rotate_0; ToolButton *rotate_0;
@ -87,46 +89,83 @@ class TileMapEditor : public VBoxContainer {
ToolButton *rotate_180; ToolButton *rotate_180;
ToolButton *rotate_270; ToolButton *rotate_270;
HBoxContainer *canvas_item_editor_hb; Tool tool;
bool selection_active;
bool mouse_over;
bool flip_h;
bool flip_v;
bool transpose;
Point2i rectangle_begin;
Rect2i rectangle;
Point2i over_tile;
struct CellOp { struct CellOp {
int idx; int idx;
bool xf; bool xf;
bool yf; bool yf;
bool tr; bool tr;
CellOp() { idx=-1; xf=false; yf=false; tr=false; } CellOp() { idx=-1; xf=false; yf=false; tr=false; }
}; };
Map<Point2i,CellOp> paint_undo; Map<Point2i, CellOp> paint_undo;
struct TileData {
Point2i pos;
int cell;
bool flip_h;
bool flip_v;
bool transpose;
};
List<TileData> copydata;
void _pick_tile(const Point2& p_pos);
DVector<Vector2> _bucket_fill(const Point2i& p_start);
void _fill_points(const DVector<Vector2> p_points, const Dictionary& p_op);
void _erase_points(const DVector<Vector2> p_points);
void _select(const Point2i& p_from, const Point2i& p_to);
void _draw_cell(int p_cell, const Point2i& p_point, bool p_flip_h, bool p_flip_v, bool p_transpose, const Matrix32& p_xform);
void _update_copydata();
int get_selected_tile() const; int get_selected_tile() const;
void set_selected_tile(int p_tile); void set_selected_tile(int p_tile);
void _set_display_mode(int p_mode); void _text_entered(const String& p_text);
void _text_changed(const String& p_text);
void _sbox_input(const InputEvent& p_ie);
void _update_palette(); void _update_palette();
void _canvas_draw(); void _canvas_draw();
void _menu_option(int p_option); void _menu_option(int p_option);
void _set_cell(const Point2i& p_pos, int p_value, bool p_flip_h=false, bool p_flip_v=false, bool p_transpose=false, bool p_with_undo=false); void _set_cell(const Point2i& p_pos, int p_value, bool p_flip_h=false, bool p_flip_v=false, bool p_transpose=false, bool p_with_undo=false);
void _set_cell_shortened(const Point2& p_pos, int p_value, bool p_flip_h=false, bool p_flip_v=false, bool p_transpose=false);
void _canvas_mouse_enter(); void _canvas_mouse_enter();
void _canvas_mouse_exit(); void _canvas_mouse_exit();
void _tileset_settings_changed(); void _tileset_settings_changed();
protected: protected:
void _notification(int p_what); void _notification(int p_what);
void _node_removed(Node *p_node);
static void _bind_methods(); static void _bind_methods();
CellOp _get_op_from_cell(const Point2i& p_pos); CellOp _get_op_from_cell(const Point2i& p_pos);
void _update_transform_buttons(Object *p_button=0); void _update_transform_buttons(Object *p_button=NULL);
public: public:
HBoxContainer *get_canvas_item_editor_hb() const { return canvas_item_editor_hb; } HBoxContainer *get_toolbar() const { return toolbar; }
bool forward_input_event(const InputEvent& p_event); bool forward_input_event(const InputEvent& p_event);
void edit(Node *p_tile_map); void edit(Node *p_tile_map);
TileMapEditor(EditorNode *p_editor); TileMapEditor(EditorNode *p_editor);
}; };
@ -135,8 +174,6 @@ class TileMapEditorPlugin : public EditorPlugin {
OBJ_TYPE( TileMapEditorPlugin, EditorPlugin ); OBJ_TYPE( TileMapEditorPlugin, EditorPlugin );
TileMapEditor *tile_map_editor; TileMapEditor *tile_map_editor;
EditorNode *editor;
public: public: