Merge pull request #50621 from KoBeWi/feel_good_scroll
Add scrolling to tile atlas view
This commit is contained in:
commit
a0d13995c8
1 changed files with 21 additions and 15 deletions
|
@ -41,25 +41,31 @@
|
||||||
#include "editor/editor_settings.h"
|
#include "editor/editor_settings.h"
|
||||||
|
|
||||||
void TileAtlasView::_gui_input(const Ref<InputEvent> &p_event) {
|
void TileAtlasView::_gui_input(const Ref<InputEvent> &p_event) {
|
||||||
bool ctrl = Input::get_singleton()->is_key_pressed(KEY_CTRL);
|
|
||||||
|
|
||||||
Ref<InputEventMouseButton> mb = p_event;
|
Ref<InputEventMouseButton> mb = p_event;
|
||||||
if (mb.is_valid()) {
|
if (mb.is_valid()) {
|
||||||
drag_type = DRAG_TYPE_NONE;
|
drag_type = DRAG_TYPE_NONE;
|
||||||
if (ctrl && mb->is_pressed() && mb->get_button_index() == MOUSE_BUTTON_WHEEL_DOWN) {
|
|
||||||
// Zoom out
|
|
||||||
zoom_widget->set_zoom_by_increments(-2);
|
|
||||||
emit_signal(SNAME("transform_changed"), zoom_widget->get_zoom(), panning);
|
|
||||||
_update_zoom_and_panning(true);
|
|
||||||
accept_event();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ctrl && mb->is_pressed() && mb->get_button_index() == MOUSE_BUTTON_WHEEL_UP) {
|
Vector2i scroll_vec = Vector2((mb->get_button_index() == MOUSE_BUTTON_WHEEL_LEFT) - (mb->get_button_index() == MOUSE_BUTTON_WHEEL_RIGHT), (mb->get_button_index() == MOUSE_BUTTON_WHEEL_UP) - (mb->get_button_index() == MOUSE_BUTTON_WHEEL_DOWN));
|
||||||
// Zoom in
|
if (scroll_vec != Vector2()) {
|
||||||
zoom_widget->set_zoom_by_increments(2);
|
if (mb->is_ctrl_pressed()) {
|
||||||
emit_signal(SNAME("transform_changed"), zoom_widget->get_zoom(), panning);
|
if (mb->is_shift_pressed()) {
|
||||||
_update_zoom_and_panning(true);
|
panning.x += 32 * mb->get_factor() * scroll_vec.y;
|
||||||
accept_event();
|
panning.y += 32 * mb->get_factor() * scroll_vec.x;
|
||||||
|
} else {
|
||||||
|
panning.y += 32 * mb->get_factor() * scroll_vec.y;
|
||||||
|
panning.x += 32 * mb->get_factor() * scroll_vec.x;
|
||||||
|
}
|
||||||
|
|
||||||
|
emit_signal(SNAME("transform_changed"), zoom_widget->get_zoom(), panning);
|
||||||
|
_update_zoom_and_panning(true);
|
||||||
|
accept_event();
|
||||||
|
|
||||||
|
} else if (!mb->is_shift_pressed()) {
|
||||||
|
zoom_widget->set_zoom_by_increments(scroll_vec.y * 2);
|
||||||
|
emit_signal(SNAME("transform_changed"), zoom_widget->get_zoom(), panning);
|
||||||
|
_update_zoom_and_panning(true);
|
||||||
|
accept_event();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mb->get_button_index() == MOUSE_BUTTON_MIDDLE || mb->get_button_index() == MOUSE_BUTTON_RIGHT) {
|
if (mb->get_button_index() == MOUSE_BUTTON_MIDDLE || mb->get_button_index() == MOUSE_BUTTON_RIGHT) {
|
||||||
|
|
Loading…
Reference in a new issue