mirror of
https://github.com/godotengine/godot.git
synced 2024-11-22 12:12:28 +00:00
Merge pull request #81735 from KoBeWi/360_no_scope
Fix rotated 2D movement gizmo
This commit is contained in:
commit
ba54c34551
@ -2056,27 +2056,31 @@ bool CanvasItemEditor::_gui_input_move(const Ref<InputEvent> &p_event) {
|
||||
|
||||
if (drag_type == DRAG_MOVE || drag_type == DRAG_MOVE_X || drag_type == DRAG_MOVE_Y) {
|
||||
// Move the nodes
|
||||
if (m.is_valid()) {
|
||||
if (m.is_valid() && !drag_selection.is_empty()) {
|
||||
_restore_canvas_item_state(drag_selection, true);
|
||||
|
||||
drag_to = transform.affine_inverse().xform(m->get_position());
|
||||
Point2 previous_pos;
|
||||
if (!drag_selection.is_empty()) {
|
||||
if (drag_selection.size() == 1) {
|
||||
Transform2D xform = drag_selection[0]->get_global_transform_with_canvas() * drag_selection[0]->get_transform().affine_inverse();
|
||||
previous_pos = xform.xform(drag_selection[0]->_edit_get_position());
|
||||
if (drag_selection.size() == 1) {
|
||||
Transform2D xform = drag_selection[0]->get_global_transform_with_canvas() * drag_selection[0]->get_transform().affine_inverse();
|
||||
previous_pos = xform.xform(drag_selection[0]->_edit_get_position());
|
||||
} else {
|
||||
previous_pos = _get_encompassing_rect_from_list(drag_selection).position;
|
||||
}
|
||||
|
||||
Point2 drag_delta = drag_to - drag_from;
|
||||
if (drag_selection.size() == 1 && (drag_type == DRAG_MOVE_X || drag_type == DRAG_MOVE_Y)) {
|
||||
const CanvasItem *selected = drag_selection.front()->get();
|
||||
drag_delta = selected->get_transform().affine_inverse().basis_xform(drag_delta);
|
||||
|
||||
if (drag_type == DRAG_MOVE_X) {
|
||||
drag_delta.y = 0;
|
||||
} else {
|
||||
previous_pos = _get_encompassing_rect_from_list(drag_selection).position;
|
||||
drag_delta.x = 0;
|
||||
}
|
||||
drag_delta = selected->get_transform().basis_xform(drag_delta);
|
||||
}
|
||||
|
||||
Point2 new_pos = snap_point(previous_pos + (drag_to - drag_from), SNAP_GRID | SNAP_GUIDES | SNAP_PIXEL | SNAP_NODE_PARENT | SNAP_NODE_ANCHORS | SNAP_OTHER_NODES, 0, nullptr, drag_selection);
|
||||
|
||||
if (drag_type == DRAG_MOVE_X) {
|
||||
new_pos.y = previous_pos.y;
|
||||
} else if (drag_type == DRAG_MOVE_Y) {
|
||||
new_pos.x = previous_pos.x;
|
||||
}
|
||||
Point2 new_pos = snap_point(previous_pos + drag_delta, SNAP_GRID | SNAP_GUIDES | SNAP_PIXEL | SNAP_NODE_PARENT | SNAP_NODE_ANCHORS | SNAP_OTHER_NODES, 0, nullptr, drag_selection);
|
||||
|
||||
bool single_axis = m->is_shift_pressed();
|
||||
if (single_axis) {
|
||||
|
Loading…
Reference in New Issue
Block a user