Skip to content

Commit

Permalink
timeline: Add up arrow support
Browse files Browse the repository at this point in the history
Signed-off-by: Thomas Wilshaw <thomaswilshaw@gmail.com>
  • Loading branch information
ThomasWilshaw committed Dec 2, 2024
1 parent 12ebf08 commit adb2a3f
Showing 1 changed file with 41 additions and 1 deletion.
42 changes: 41 additions & 1 deletion timeline.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1544,14 +1544,15 @@ void DrawTimeline(otio::Timeline* timeline) {
}
}
}

if (ImGui::IsKeyPressed(ImGuiKey::ImGuiKey_LeftArrow)) {
std::string selected_type = appState.selected_object->schema_name();
if (selected_type == "Clip" || selected_type == "Gap" || selected_type == "Transition") {
// Loop through selected items parent track to find the previous item
auto parent = dynamic_cast<otio::Composable*>(appState.selected_object)->parent();
for(auto it = parent->children().begin(); it != parent->children().end(); it++ ){
if (*it == appState.selected_object) {
// If first item do nothin
// If first item do nothing
if (it == parent->children().begin()) {
break;
}
Expand All @@ -1564,6 +1565,45 @@ void DrawTimeline(otio::Timeline* timeline) {
}
}

if (ImGui::IsKeyPressed(ImGuiKey::ImGuiKey_UpArrow)) {
std::string selected_type = appState.selected_object->schema_name();
if (selected_type == "Clip" || selected_type == "Gap" || selected_type == "Transition") {
// Finding start time varies depending on object type
otio::RationalTime start_time;
if (selected_type == "Clip" || selected_type == "Gap") {
auto child = dynamic_cast<otio::Item*>(appState.selected_object);
start_time = child->range_in_parent().start_time();
} else if (selected_type == "Transition") {
auto child = dynamic_cast<otio::Transition*>(appState.selected_object);
start_time = child->range_in_parent().value().start_time();
}

auto parent = dynamic_cast<otio::Composable*>(appState.selected_object)->parent();
auto tracks = dynamic_cast<otio::Stack*>(parent->parent());

// Loop through tracks until we find the current one
for(auto it = tracks->children().begin(); it != tracks->children().end(); it++ ){
otio::Composable* track = *it;
if (track == parent) {
// If last item then do nothing
if (std::next(it) == tracks->children().end()) {
break;
}
// Select the next track up
std::advance(it, 1);
otio::Composable* next_track = *it;

// If there is an iten that overlaps with the current selection start time
// select it
if (dynamic_cast<otio::Track*>(next_track)->child_at_time(start_time)){
SelectObject(dynamic_cast<otio::Track*>(next_track)->child_at_time(start_time));
break;
}
}
}
}
}

// This is helpful when debugging visibility performance optimization
// ImGui::SetTooltip("Tracks rendered: %d\nItems rendered: %d",
// __tracks_rendered, __items_rendered);
Expand Down

0 comments on commit adb2a3f

Please sign in to comment.