Merge pull request #15185 from damarindra/master
Improve : ease of use TileSet Editor
This commit is contained in:
commit
361ade53aa
2 changed files with 57 additions and 13 deletions
|
@ -333,7 +333,7 @@ AutotileEditor::AutotileEditor(EditorNode *p_editor) {
|
||||||
autotile_list = memnew(ItemList);
|
autotile_list = memnew(ItemList);
|
||||||
autotile_list->set_v_size_flags(SIZE_EXPAND_FILL);
|
autotile_list->set_v_size_flags(SIZE_EXPAND_FILL);
|
||||||
autotile_list->set_h_size_flags(SIZE_EXPAND_FILL);
|
autotile_list->set_h_size_flags(SIZE_EXPAND_FILL);
|
||||||
autotile_list->set_custom_minimum_size(Size2(02, 200));
|
autotile_list->set_custom_minimum_size(Size2(10, 200));
|
||||||
autotile_list->connect("item_selected", this, "_on_autotile_selected");
|
autotile_list->connect("item_selected", this, "_on_autotile_selected");
|
||||||
split->add_child(autotile_list);
|
split->add_child(autotile_list);
|
||||||
|
|
||||||
|
@ -531,7 +531,7 @@ AutotileEditor::AutotileEditor(EditorNode *p_editor) {
|
||||||
|
|
||||||
main_vb->add_child(toolbar);
|
main_vb->add_child(toolbar);
|
||||||
|
|
||||||
ScrollContainer *scroll = memnew(ScrollContainer);
|
scroll = memnew(ScrollContainer);
|
||||||
main_vb->add_child(scroll);
|
main_vb->add_child(scroll);
|
||||||
scroll->set_v_size_flags(SIZE_EXPAND_FILL);
|
scroll->set_v_size_flags(SIZE_EXPAND_FILL);
|
||||||
|
|
||||||
|
@ -619,6 +619,7 @@ void AutotileEditor::_on_edit_mode_changed(int p_edit_mode) {
|
||||||
tool_containers[TOOLBAR_BITMASK]->hide();
|
tool_containers[TOOLBAR_BITMASK]->hide();
|
||||||
tool_containers[TOOLBAR_SHAPE]->show();
|
tool_containers[TOOLBAR_SHAPE]->show();
|
||||||
tools[TOOL_SELECT]->set_tooltip(TTR("Select current edited sub-tile."));
|
tools[TOOL_SELECT]->set_tooltip(TTR("Select current edited sub-tile."));
|
||||||
|
current_shape = PoolVector2Array();
|
||||||
spin_priority->hide();
|
spin_priority->hide();
|
||||||
} break;
|
} break;
|
||||||
default: {
|
default: {
|
||||||
|
@ -1061,20 +1062,43 @@ void AutotileEditor::_on_workspace_input(const Ref<InputEvent> &p_ie) {
|
||||||
} else {
|
} else {
|
||||||
int t_id = get_current_tile();
|
int t_id = get_current_tile();
|
||||||
if (t_id >= 0) {
|
if (t_id >= 0) {
|
||||||
Vector<TileSet::ShapeData> sd = tile_set->tile_get_shapes(t_id);
|
if (edit_mode == EDITMODE_COLLISION) {
|
||||||
for (int i = 0; i < sd.size(); i++) {
|
Vector<TileSet::ShapeData> sd = tile_set->tile_get_shapes(t_id);
|
||||||
if (sd[i].autotile_coord == edited_shape_coord) {
|
for (int i = 0; i < sd.size(); i++) {
|
||||||
Ref<ConvexPolygonShape2D> shape = sd[i].shape;
|
if (sd[i].autotile_coord == edited_shape_coord) {
|
||||||
|
Ref<ConvexPolygonShape2D> shape = sd[i].shape;
|
||||||
|
|
||||||
if (!shape.is_null()) {
|
if (!shape.is_null()) {
|
||||||
sd.remove(i);
|
sd.remove(i);
|
||||||
tile_set->tile_set_shapes(get_current_tile(), sd);
|
tile_set->tile_set_shapes(get_current_tile(), sd);
|
||||||
edited_collision_shape = Ref<Shape2D>();
|
edited_collision_shape = Ref<Shape2D>();
|
||||||
current_shape.resize(0);
|
workspace->update();
|
||||||
workspace->update();
|
}
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
} else if (edit_mode == EDITMODE_OCCLUSION) {
|
||||||
|
Map<Vector2, Ref<OccluderPolygon2D> > map = tile_set->autotile_get_light_oclusion_map(t_id);
|
||||||
|
for (Map<Vector2, Ref<OccluderPolygon2D> >::Element *E = map.front(); E; E = E->next()) {
|
||||||
|
if (E->key() == edited_shape_coord) {
|
||||||
|
tile_set->autotile_set_light_occluder(get_current_tile(), Ref<OccluderPolygon2D>(), edited_shape_coord);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
edited_occlusion_shape = Ref<OccluderPolygon2D>();
|
||||||
|
workspace->update();
|
||||||
|
} else if (edit_mode == EDITMODE_NAVIGATION) {
|
||||||
|
Map<Vector2, Ref<NavigationPolygon> > map = tile_set->autotile_get_navigation_map(t_id);
|
||||||
|
for (Map<Vector2, Ref<NavigationPolygon> >::Element *E = map.front(); E; E = E->next()) {
|
||||||
|
if (E->key() == edited_shape_coord) {
|
||||||
|
tile_set->autotile_set_navigation_polygon(t_id, Ref<NavigationPolygon>(), edited_shape_coord);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
edited_navigation_shape = Ref<NavigationPolygon>();
|
||||||
|
workspace->update();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1095,6 +1119,16 @@ void AutotileEditor::_on_workspace_input(const Ref<InputEvent> &p_ie) {
|
||||||
}
|
}
|
||||||
} break;
|
} break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//Drag Middle Mouse
|
||||||
|
if (mm.is_valid()) {
|
||||||
|
if (mm->get_button_mask() & BUTTON_MASK_MIDDLE) {
|
||||||
|
|
||||||
|
Vector2 dragged(mm->get_relative().x, mm->get_relative().y);
|
||||||
|
scroll->set_h_scroll(scroll->get_h_scroll() - dragged.x * workspace->get_scale().x);
|
||||||
|
scroll->set_v_scroll(scroll->get_v_scroll() - dragged.y * workspace->get_scale().x);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1453,11 +1487,20 @@ void AutotileEditor::close_shape(const Vector2 &shape_anchor) {
|
||||||
Ref<ConvexPolygonShape2D> shape = memnew(ConvexPolygonShape2D);
|
Ref<ConvexPolygonShape2D> shape = memnew(ConvexPolygonShape2D);
|
||||||
|
|
||||||
Vector<Vector2> segments;
|
Vector<Vector2> segments;
|
||||||
|
float p_total = 0;
|
||||||
|
|
||||||
for (int i = 0; i < current_shape.size(); i++) {
|
for (int i = 0; i < current_shape.size(); i++) {
|
||||||
segments.push_back(current_shape[i] - shape_anchor);
|
segments.push_back(current_shape[i] - shape_anchor);
|
||||||
|
|
||||||
|
if (i != current_shape.size() - 1)
|
||||||
|
p_total += ((current_shape[i + 1].x - current_shape[i].x) * (-current_shape[i + 1].y + (-current_shape[i].y)));
|
||||||
|
else
|
||||||
|
p_total += ((current_shape[0].x - current_shape[i].x) * (-current_shape[0].y + (-current_shape[i].y)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (p_total < 0)
|
||||||
|
segments.invert();
|
||||||
|
|
||||||
shape->set_points(segments);
|
shape->set_points(segments);
|
||||||
|
|
||||||
tile_set->tile_add_shape(get_current_tile(), shape, Transform2D(), false, edited_shape_coord);
|
tile_set->tile_add_shape(get_current_tile(), shape, Transform2D(), false, edited_shape_coord);
|
||||||
|
|
|
@ -86,6 +86,7 @@ class AutotileEditor : public Control {
|
||||||
|
|
||||||
int current_item_index;
|
int current_item_index;
|
||||||
Sprite *preview;
|
Sprite *preview;
|
||||||
|
ScrollContainer *scroll;
|
||||||
Control *workspace_container;
|
Control *workspace_container;
|
||||||
Control *workspace;
|
Control *workspace;
|
||||||
Button *tool_editmode[EDITMODE_MAX];
|
Button *tool_editmode[EDITMODE_MAX];
|
||||||
|
|
Loading…
Reference in a new issue