]> git.sesse.net Git - kdenlive/commitdiff
Don't send several seek requests for same frame when seeking with monitor ruler
authorJean-Baptiste Mardelle <jb@kdenlive.org>
Fri, 28 Dec 2012 13:07:09 +0000 (14:07 +0100)
committerJean-Baptiste Mardelle <jb@kdenlive.org>
Fri, 28 Dec 2012 13:07:09 +0000 (14:07 +0100)
src/jogshuttle.cpp
src/smallruler.cpp

index 6ffdf3e40a67d1d4cd26a7fda8670ce284fbedb7..362886362f2cd4a25e2fe9fe29aa5256cdaa70f6 100644 (file)
@@ -199,7 +199,7 @@ void ShuttleThread::key(unsigned short code, unsigned int value)
     if (code > 16)
         return;
 
-    kDebug() << "Button PRESSED: " << code;
+    //kDebug() << "Button PRESSED: " << code;
     QApplication::postEvent(m_parent, new QEvent((QEvent::Type)(KEY_EVENT_OFFSET + code)));
 
 }
index 0e035bc033d36c02d1db4e6e32b46b5669a342d2..3673cbb191fb2d451fe2d7fe86795a467d2caf94 100644 (file)
@@ -129,7 +129,7 @@ void SmallRuler::mousePressEvent(QMouseEvent * event)
         emit zoneChanged(QPoint(m_zoneStart, m_zoneEnd));
         updatePixmap();
 
-    } else {
+    } else if (pos != m_lastSeekPosition && pos != m_cursorFramePosition) {
        m_render->seekToFrame(pos);
        m_lastSeekPosition = pos;
        update();
@@ -159,9 +159,11 @@ void SmallRuler::mouseMoveEvent(QMouseEvent * event)
 {
     const int pos = event->x() / m_scale;
     if (event->buttons() & Qt::LeftButton) {
-       m_render->seekToFrame(pos);
-       m_lastSeekPosition = pos;
-       update();
+       if (pos != m_lastSeekPosition && pos != m_cursorFramePosition) {
+           m_render->seekToFrame(pos);
+           m_lastSeekPosition = pos;
+           update();
+       }
     }
     else {
        if (m_cursorColor == palette().text() && qAbs(pos - m_cursorFramePosition) * m_scale < 7) {