X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fmonitorscene.cpp;h=e6be3de10188933da55b54a6b60c13e3dd682076;hb=c3302003093710ee247ad84c0fe2ef3c579d417f;hp=fe13181cba3675ae6fef42195f8e972b0ad3bb2f;hpb=81be3bf632b306ffd8795f0c81d4372e358e88d2;p=kdenlive diff --git a/src/monitorscene.cpp b/src/monitorscene.cpp index fe13181c..e6be3de1 100644 --- a/src/monitorscene.cpp +++ b/src/monitorscene.cpp @@ -20,11 +20,15 @@ #include "monitorscene.h" #include "renderer.h" +#include "onmonitoritems/rotoscoping/bpointitem.h" +#include "onmonitoritems/rotoscoping/splineitem.h" #include "kdenlivesettings.h" #include #include #include +#include + MonitorScene::MonitorScene(Render *renderer, QObject* parent) : QGraphicsScene(parent), @@ -32,7 +36,8 @@ MonitorScene::MonitorScene(Render *renderer, QObject* parent) : m_view(NULL), m_backgroundImage(QImage()), m_enabled(true), - m_zoom(1.0) + m_zoom(1.0), + m_groupMove(false) { setBackgroundBrush(QBrush(QColor(KdenliveSettings::window_background().name()))); @@ -60,9 +65,20 @@ MonitorScene::MonitorScene(Render *renderer, QObject* parent) : connect(m_renderer, SIGNAL(frameUpdated(QImage)), this, SLOT(slotSetBackgroundImage(QImage))); } +void MonitorScene::centerView() +{ + if (m_view) m_view->centerOn(m_frameBorder); +} + +void MonitorScene::cleanup() +{ + // Reset scene rect + setSceneRect(m_frameBorder->boundingRect()); +} + void MonitorScene::setUp() { - if (views().count() > 0) { + if (!views().isEmpty()) { m_view = views().at(0); m_view->setViewportUpdateMode(QGraphicsView::FullViewportUpdate); } else { @@ -136,14 +152,100 @@ void MonitorScene::slotZoomIn(int by) slotZoom(qMin(300, (int)(m_zoom * 100 + by + 0.5))); } +void MonitorScene::mousePressEvent(QGraphicsSceneMouseEvent* event) +{ + QList selected = selectedItems(); + + QGraphicsScene::mousePressEvent(event); + + if (selected.count() < selectedItems().count()) { + // mouse click on item not in selection group + // -> select only this item + foreach (QGraphicsItem *item, selected) { + if (item) + item->setSelected(false); + } + } + + if (event->isAccepted() && selectedItems().count() > 1) { + // multiple items selected + mouse pressed on an item + selected = selectedItems(); + foreach (QGraphicsItem *item, selected) { + if (qgraphicsitem_cast(item)) { + // works with rotoscoping only for now + m_groupMove = true; + m_lastPos = event->scenePos(); + return; + } + } + } + + if (!event->isAccepted() && event->buttons() & Qt::LeftButton) { + if (event->modifiers() == Qt::ControlModifier) + m_view->setDragMode(QGraphicsView::ScrollHandDrag); + else if (event->modifiers() == Qt::ShiftModifier) + m_view->setDragMode(QGraphicsView::RubberBandDrag); + } +} + void MonitorScene::mouseMoveEvent(QGraphicsSceneMouseEvent *event) { - QGraphicsScene::mouseMoveEvent(event); + if (m_groupMove) { + // we want to move multiple items + // rotoscoping only for now + QPointF diff = event->scenePos() - m_lastPos; + if (diff != QPointF(0, 0)) { + m_lastPos = event->scenePos(); + QList selected = selectedItems(); + int first = -1; + int i = 0; + foreach (QGraphicsItem *item, selected) { + BPointItem *bpoint = qgraphicsitem_cast(item); + if (bpoint) { + if (first < 0) + first = i; + BPoint p = bpoint->getPoint(); + p.setP(p.p + diff); + bpoint->setPoint(p); + } + ++i; + } + + if (first >= 0) { + QGraphicsItem *item = selected.at(first); + if (item->parentItem()) { + SplineItem *parent = qgraphicsitem_cast(item->parentItem()); + if (parent) + parent->updateSpline(true); + } + } + } + } else { + QGraphicsScene::mouseMoveEvent(event); + } } +void MonitorScene::mouseReleaseEvent(QGraphicsSceneMouseEvent* event) +{ + if (m_groupMove) { + QList selected = selectedItems(); + foreach (QGraphicsItem *item, selected) { + if (qgraphicsitem_cast(item) && item->parentItem()) { + SplineItem *parent = qgraphicsitem_cast(item->parentItem()); + if (parent) { + parent->updateSpline(false); + break; + } + } + } + m_groupMove = false; + } + QGraphicsScene::mouseReleaseEvent(event); + m_view->setDragMode(QGraphicsView::NoDrag); +} void MonitorScene::mouseDoubleClickEvent(QGraphicsSceneMouseEvent* event) { - Q_UNUSED(event); + Q_UNUSED(event) if (!m_enabled) emit addKeyframe(); @@ -152,12 +254,23 @@ void MonitorScene::mouseDoubleClickEvent(QGraphicsSceneMouseEvent* event) void MonitorScene::wheelEvent(QGraphicsSceneWheelEvent* event) { if (event->modifiers() == Qt::ControlModifier) { - if (event->delta() > 0) + if (event->delta() > 0) { + m_view->setTransformationAnchor(QGraphicsView::AnchorUnderMouse); slotZoomIn(5); - else + m_view->setTransformationAnchor(QGraphicsView::AnchorViewCenter); + } else { slotZoomOut(5); + } } else { - QGraphicsScene::wheelEvent(event); + QAbstractSlider::SliderAction action; + if (event->delta() > 0) + action = QAbstractSlider::SliderSingleStepSub; + else + action = QAbstractSlider::SliderSingleStepAdd; + if (event->orientation() == Qt::Horizontal) + m_view->horizontalScrollBar()->triggerAction(action); + else + m_view->verticalScrollBar()->triggerAction(action); } event->accept();