Merge pull request #28178 from dankan1890/tileset_editor_add_1

Tileset-Editor: Added alternative tool for drawing a rectangular shape.
This commit is contained in:
Mariano Javier Suligoy 2019-04-22 14:08:50 -03:00 committed by GitHub
commit 1bbe95b452
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -1561,13 +1561,42 @@ void TileSetEditor::_on_workspace_input(const Ref<InputEvent> &p_ie) {
if (mb->is_pressed() && mb->get_button_index() == BUTTON_LEFT) { if (mb->is_pressed() && mb->get_button_index() == BUTTON_LEFT) {
_set_edited_collision_shape(Ref<ConvexPolygonShape2D>()); _set_edited_collision_shape(Ref<ConvexPolygonShape2D>());
current_shape.resize(0); current_shape.resize(0);
current_shape.push_back(snap_point(shape_anchor)); Vector2 pos = mb->get_position();
current_shape.push_back(snap_point(shape_anchor + Vector2(current_tile_region.size.x, 0))); pos = snap_point(pos);
current_shape.push_back(snap_point(shape_anchor + current_tile_region.size)); current_shape.push_back(pos);
current_shape.push_back(snap_point(shape_anchor + Vector2(0, current_tile_region.size.y))); current_shape.push_back(pos);
close_shape(shape_anchor); current_shape.push_back(pos);
current_shape.push_back(pos);
creating_shape = true;
workspace->update(); workspace->update();
return;
} else if (mb->is_pressed() && mb->get_button_index() == BUTTON_RIGHT) { } else if (mb->is_pressed() && mb->get_button_index() == BUTTON_RIGHT) {
if (creating_shape) {
creating_shape = false;
_select_edited_shape_coord();
workspace->update();
}
} else if (!mb->is_pressed() && mb->get_button_index() == BUTTON_LEFT) {
if (creating_shape) {
if ((current_shape[0] - current_shape[1]).length_squared() <= grab_threshold) {
current_shape.set(0, snap_point(shape_anchor));
current_shape.set(1, snap_point(shape_anchor + Vector2(current_tile_region.size.x, 0)));
current_shape.set(2, snap_point(shape_anchor + current_tile_region.size));
current_shape.set(3, snap_point(shape_anchor + Vector2(0, current_tile_region.size.y)));
}
close_shape(shape_anchor);
workspace->update();
return;
}
}
} else if (mm.is_valid()) {
if (creating_shape) {
Vector2 pos = mm->get_position();
pos = snap_point(pos);
Vector2 p = current_shape[2];
current_shape.set(3, snap_point(Vector2(pos.x, p.y)));
current_shape.set(0, snap_point(pos));
current_shape.set(1, snap_point(Vector2(p.x, pos.y)));
workspace->update(); workspace->update();
} }
} }