diff options
author | emild <emil.dobetsberger@gmail.com> | 2024-02-15 00:44:40 +0100 |
---|---|---|
committer | emild <emil.dobetsberger@gmail.com> | 2024-02-15 00:44:40 +0100 |
commit | af08997de7bc05fc60ca3c8695a659c934cd7473 (patch) | |
tree | fc1c1683d7e43bdf6266064ff3845beb028697ea /editor/animation_bezier_editor.cpp | |
parent | e92d55bbf417aa9f4592a863cb5b2c7ba0740e21 (diff) | |
download | redot-engine-af08997de7bc05fc60ca3c8695a659c934cd7473.tar.gz |
implemented cut selected keys in animation player
Diffstat (limited to 'editor/animation_bezier_editor.cpp')
-rw-r--r-- | editor/animation_bezier_editor.cpp | 29 |
1 files changed, 26 insertions, 3 deletions
diff --git a/editor/animation_bezier_editor.cpp b/editor/animation_bezier_editor.cpp index 34ca653ff7..268a819641 100644 --- a/editor/animation_bezier_editor.cpp +++ b/editor/animation_bezier_editor.cpp @@ -842,7 +842,7 @@ void AnimationBezierTrackEdit::gui_input(const Ref<InputEvent> &p_event) { } if (ED_GET_SHORTCUT("animation_editor/copy_selected_keys")->matches_event(p_event)) { if (!read_only) { - copy_selected_keys(); + copy_selected_keys(false); } accept_event(); } @@ -959,6 +959,7 @@ void AnimationBezierTrackEdit::gui_input(const Ref<InputEvent> &p_event) { if (selected || selection.size()) { menu->add_separator(); menu->add_icon_item(get_editor_theme_icon(SNAME("Duplicate")), TTR("Duplicate Selected Key(s)"), MENU_KEY_DUPLICATE); + menu->add_icon_item(get_editor_theme_icon(SNAME("ActionCut")), TTR("Cut Selected Key(s)"), MENU_KEY_CUT); menu->add_icon_item(get_editor_theme_icon(SNAME("ActionCopy")), TTR("Copy Selected Key(s)"), MENU_KEY_COPY); } @@ -1600,8 +1601,11 @@ void AnimationBezierTrackEdit::_menu_selected(int p_index) { case MENU_KEY_DELETE: { delete_selection(); } break; + case MENU_KEY_CUT: { + copy_selected_keys(true); + } break; case MENU_KEY_COPY: { - copy_selected_keys(); + copy_selected_keys(false); } break; case MENU_KEY_PASTE: { paste_keys(time); @@ -1681,7 +1685,7 @@ void AnimationBezierTrackEdit::duplicate_selected_keys(real_t p_ofs) { undo_redo->commit_action(); } -void AnimationBezierTrackEdit::copy_selected_keys() { +void AnimationBezierTrackEdit::copy_selected_keys(bool p_cut) { if (selection.is_empty()) { return; } @@ -1704,6 +1708,25 @@ void AnimationBezierTrackEdit::copy_selected_keys() { keys.insert(sk, ki); } editor->_set_key_clipboard(selected_track, top_time, keys); + + if (p_cut) { + EditorUndoRedoManager *undo_redo = EditorUndoRedoManager::get_singleton(); + undo_redo->create_action(TTR("Animation Cut Keys"), UndoRedo::MERGE_DISABLE, animation.ptr()); + undo_redo->add_do_method(this, "_clear_selection_for_anim", animation); + undo_redo->add_undo_method(this, "_clear_selection_for_anim", animation); + for (RBMap<AnimationTrackEditor::SelectedKey, AnimationTrackEditor::KeyInfo>::Element *E = keys.back(); E; E = E->prev()) { + int track_idx = E->key().track; + int key_idx = E->key().key; + float time = E->value().pos; + undo_redo->add_do_method(animation.ptr(), "track_remove_key_at_time", track_idx, time); + undo_redo->add_undo_method(animation.ptr(), "track_insert_key", track_idx, time, animation->track_get_key_value(track_idx, key_idx), animation->track_get_key_transition(track_idx, key_idx)); + undo_redo->add_undo_method(this, "_select_at_anim", animation, track_idx, time); + } + for (RBMap<AnimationTrackEditor::SelectedKey, AnimationTrackEditor::KeyInfo>::Element *E = keys.back(); E; E = E->prev()) { + undo_redo->add_undo_method(this, "_select_at_anim", animation, E->key().track, E->value().pos); + } + undo_redo->commit_action(); + } } void AnimationBezierTrackEdit::paste_keys(real_t p_ofs) { |