Merge pull request #27770 from KoBeWi/moving_pan_v2
Allow panning while moving a node
This commit is contained in:
commit
853af06f5a
2 changed files with 39 additions and 39 deletions
|
@ -1072,36 +1072,36 @@ bool CanvasItemEditor::_gui_input_zoom_or_pan(const Ref<InputEvent> &p_event) {
|
|||
}
|
||||
}
|
||||
|
||||
if (drag_type == DRAG_NONE) {
|
||||
if (!panning) {
|
||||
if (b->is_pressed() &&
|
||||
(b->get_button_index() == BUTTON_MIDDLE ||
|
||||
(b->get_button_index() == BUTTON_LEFT && tool == TOOL_PAN) ||
|
||||
(b->get_button_index() == BUTTON_LEFT && !EditorSettings::get_singleton()->get("editors/2d/simple_spacebar_panning") && Input::get_singleton()->is_key_pressed(KEY_SPACE)))) {
|
||||
// Pan the viewport
|
||||
drag_type = DRAG_PAN;
|
||||
panning = true;
|
||||
}
|
||||
}
|
||||
|
||||
if (drag_type == DRAG_PAN) {
|
||||
if (panning) {
|
||||
if (!b->is_pressed()) {
|
||||
// Stop panning the viewport (for any mouse button press)
|
||||
drag_type = DRAG_NONE;
|
||||
panning = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Ref<InputEventKey> k = p_event;
|
||||
if (k.is_valid()) {
|
||||
if (k->get_scancode() == KEY_SPACE && EditorSettings::get_singleton()->get("editors/2d/simple_spacebar_panning")) {
|
||||
if (drag_type == DRAG_NONE) {
|
||||
if (k->get_scancode() == KEY_SPACE && (EditorSettings::get_singleton()->get("editors/2d/simple_spacebar_panning") || drag_type != DRAG_NONE)) {
|
||||
if (!panning) {
|
||||
if (k->is_pressed() && !k->is_echo()) {
|
||||
//Pan the viewport
|
||||
drag_type = DRAG_PAN;
|
||||
panning = true;
|
||||
}
|
||||
} else if (drag_type == DRAG_PAN) {
|
||||
} else if (panning) {
|
||||
if (!k->is_pressed()) {
|
||||
// Stop panning the viewport (for any mouse button press)
|
||||
drag_type = DRAG_NONE;
|
||||
panning = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1109,7 +1109,7 @@ bool CanvasItemEditor::_gui_input_zoom_or_pan(const Ref<InputEvent> &p_event) {
|
|||
|
||||
Ref<InputEventMouseMotion> m = p_event;
|
||||
if (m.is_valid()) {
|
||||
if (drag_type == DRAG_PAN) {
|
||||
if (panning) {
|
||||
// Pan the viewport
|
||||
Point2i relative;
|
||||
if (bool(EditorSettings::get_singleton()->get("editors/2d/warped_mouse_panning"))) {
|
||||
|
@ -2190,6 +2190,7 @@ bool CanvasItemEditor::_gui_input_hover(const Ref<InputEvent> &p_event) {
|
|||
|
||||
void CanvasItemEditor::_gui_input_viewport(const Ref<InputEvent> &p_event) {
|
||||
bool accepted = false;
|
||||
if (EditorSettings::get_singleton()->get("editors/2d/simple_spacebar_panning") || !Input::get_singleton()->is_key_pressed(KEY_SPACE)) {
|
||||
if ((accepted = _gui_input_rulers_and_guides(p_event))) {
|
||||
//printf("Rulers and guides\n");
|
||||
} else if ((accepted = editor->get_editor_plugins_over()->forward_gui_input(p_event))) {
|
||||
|
@ -2208,13 +2209,14 @@ void CanvasItemEditor::_gui_input_viewport(const Ref<InputEvent> &p_event) {
|
|||
//printf("Rotate\n");
|
||||
} else if ((accepted = _gui_input_move(p_event))) {
|
||||
//printf("Move\n");
|
||||
} else if ((accepted = _gui_input_zoom_or_pan(p_event))) {
|
||||
//printf("Zoom or pan\n");
|
||||
} else if ((accepted = _gui_input_select(p_event))) {
|
||||
//printf("Selection\n");
|
||||
} else {
|
||||
//printf("Not accepted\n");
|
||||
}
|
||||
}
|
||||
|
||||
accepted = (_gui_input_zoom_or_pan(p_event) || accepted);
|
||||
|
||||
if (accepted)
|
||||
accept_event();
|
||||
|
@ -2259,9 +2261,6 @@ void CanvasItemEditor::_gui_input_viewport(const Ref<InputEvent> &p_event) {
|
|||
case DRAG_MOVE:
|
||||
c = CURSOR_MOVE;
|
||||
break;
|
||||
case DRAG_PAN:
|
||||
c = CURSOR_DRAG;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
@ -4591,6 +4590,7 @@ CanvasItemEditor::CanvasItemEditor(EditorNode *p_editor) {
|
|||
drag_to = Vector2();
|
||||
dragged_guide_pos = Point2();
|
||||
dragged_guide_index = -1;
|
||||
panning = false;
|
||||
|
||||
bone_last_frame = 0;
|
||||
|
||||
|
|
|
@ -205,8 +205,7 @@ private:
|
|||
DRAG_V_GUIDE,
|
||||
DRAG_H_GUIDE,
|
||||
DRAG_DOUBLE_GUIDE,
|
||||
DRAG_KEY_MOVE,
|
||||
DRAG_PAN
|
||||
DRAG_KEY_MOVE
|
||||
};
|
||||
|
||||
EditorSelection *editor_selection;
|
||||
|
@ -262,6 +261,7 @@ private:
|
|||
bool key_pos;
|
||||
bool key_rot;
|
||||
bool key_scale;
|
||||
bool panning;
|
||||
|
||||
MenuOption last_option;
|
||||
|
||||
|
|
Loading…
Reference in a new issue