X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=mainwindow.cpp;h=3b8561fac7a32fa3a14217a85ff8ff890cac23cb;hb=6911c97816e4dde727ed3aa0fa0631c4047d2bd6;hp=6b100ac358160244fceafda29882c61bd860fd51;hpb=3d434f33aa5bd4a5a412ba91ac6b0326c00aa88f;p=nageru diff --git a/mainwindow.cpp b/mainwindow.cpp index 6b100ac..3b8561f 100644 --- a/mainwindow.cpp +++ b/mainwindow.cpp @@ -272,9 +272,14 @@ bool MainWindow::eventFilter(QObject *watched, QEvent *event) constexpr int dead_zone_pixels = 3; // To avoid that simple clicks get misinterpreted. constexpr int scrub_sensitivity = 100; // pts units per pixel. constexpr int wheel_sensitivity = 100; // pts units per degree. + constexpr int camera_degrees_per_pixel = 15; // One click of most mice. unsigned stream_idx = ui->preview_display->get_stream_idx(); + if (event->type() != QEvent::Wheel) { + last_mousewheel_camera_row = -1; + } + if (event->type() == QEvent::MouseButtonPress) { QMouseEvent *mouse = (QMouseEvent *)event; @@ -337,28 +342,30 @@ bool MainWindow::eventFilter(QObject *watched, QEvent *event) int64_t pts = scrub_pts_origin + adjusted_offset * scrub_sensitivity; if (scrub_type == SCRUBBING_CLIP_LIST) { + ClipProxy clip = cliplist_clips->clip(scrub_row); if (scrub_column == int(ClipList::Column::IN)) { pts = std::max(pts, 0); - pts = std::min(pts, cliplist_clips->clip(scrub_row)->pts_out); - cliplist_clips->clip(scrub_row)->pts_in = pts; + pts = std::min(pts, clip->pts_out); + clip->pts_in = pts; preview_single_frame(pts, stream_idx, FIRST_AT_OR_AFTER); } else { - pts = std::max(pts, cliplist_clips->clip(scrub_row)->pts_in); + pts = std::max(pts, clip->pts_in); pts = std::min(pts, current_pts); - cliplist_clips->clip(scrub_row)->pts_out = pts; + clip->pts_out = pts; preview_single_frame(pts, stream_idx, LAST_BEFORE); } } else { + ClipProxy clip = playlist_clips->clip(scrub_row); if (scrub_column == int(PlayList::Column::IN)) { pts = std::max(pts, 0); - pts = std::min(pts, playlist_clips->clip(scrub_row)->pts_out); - playlist_clips->clip(scrub_row)->pts_in = pts; - preview_single_frame(pts, stream_idx, FIRST_AT_OR_AFTER); + pts = std::min(pts, clip->pts_out); + clip->pts_in = pts; + preview_single_frame(pts, clip->stream_idx, FIRST_AT_OR_AFTER); } else { - pts = std::max(pts, playlist_clips->clip(scrub_row)->pts_in); + pts = std::max(pts, clip->pts_in); pts = std::min(pts, current_pts); - playlist_clips->clip(scrub_row)->pts_out = pts; - preview_single_frame(pts, stream_idx, LAST_BEFORE); + clip->pts_out = pts; + preview_single_frame(pts, clip->stream_idx, LAST_BEFORE); } } @@ -368,16 +375,20 @@ bool MainWindow::eventFilter(QObject *watched, QEvent *event) QWheelEvent *wheel = (QWheelEvent *)event; QTableView *destination; - int in_column, out_column; + int in_column, out_column, camera_column; if (watched == ui->clip_list->viewport()) { destination = ui->clip_list; in_column = int(ClipList::Column::IN); out_column = int(ClipList::Column::OUT); + camera_column = -1; + last_mousewheel_camera_row = -1; } else if (watched == ui->playlist->viewport()) { destination = ui->playlist; in_column = int(PlayList::Column::IN); out_column = int(PlayList::Column::OUT); + camera_column = int(PlayList::Column::CAMERA); } else { + last_mousewheel_camera_row = -1; return false; } int column = destination->columnAt(wheel->x()); @@ -386,7 +397,13 @@ bool MainWindow::eventFilter(QObject *watched, QEvent *event) ClipProxy clip = (watched == ui->clip_list->viewport()) ? cliplist_clips->clip(row) : playlist_clips->clip(row); + if (watched == ui->playlist->viewport()) { + stream_idx = clip->stream_idx; + } + if (column != camera_column) { + last_mousewheel_camera_row = -1; + } if (column == in_column) { int64_t pts = clip->pts_in + wheel->angleDelta().y() * wheel_sensitivity; pts = std::max(pts, 0); @@ -399,6 +416,21 @@ bool MainWindow::eventFilter(QObject *watched, QEvent *event) pts = std::min(pts, current_pts); clip->pts_out = pts; preview_single_frame(pts, stream_idx, LAST_BEFORE); + } else if (column == camera_column) { + int angle_degrees = wheel->angleDelta().y(); + if (last_mousewheel_camera_row == row) { + angle_degrees += leftover_angle_degrees; + } + + int stream_idx = clip->stream_idx + angle_degrees / camera_degrees_per_pixel; + stream_idx = std::max(stream_idx, 0); + stream_idx = std::min(stream_idx, NUM_CAMERAS - 1); + clip->stream_idx = stream_idx; + + last_mousewheel_camera_row = row; + leftover_angle_degrees = angle_degrees % camera_degrees_per_pixel; + + // Don't update the live view, that's rarely what the operator wants. } } else if (event->type() == QEvent::MouseButtonRelease) { scrubbing = false;