X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fcustomruler.h;h=3ebcd1079b9a3c56aa2bc3de6837217ddaccd6d4;hb=5aa1fc29e8870b49734af730895cd92a50a29a72;hp=b7ac39782f7b61913efa6d47ec278dc256708f10;hpb=e6f3dd3d92bb9f0196245645d584ecfe02171ac0;p=kdenlive diff --git a/src/customruler.h b/src/customruler.h index b7ac3978..3ebcd107 100644 --- a/src/customruler.h +++ b/src/customruler.h @@ -17,6 +17,12 @@ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * ***************************************************************************/ +/** + * @class CustomRuler + * @author Jean-Baptiste Mardelle + * @brief Manages the timeline ruler. + */ + #ifndef CUSTOMRULER_H #define CUSTOMRULER_H @@ -26,6 +32,7 @@ #include "timecode.h" enum RULER_MOVE { RULER_CURSOR = 0, RULER_START = 1, RULER_MIDDLE = 2, RULER_END = 3 }; +enum MOUSE_MOVE { NO_MOVE = 0, HORIZONTAL_MOVE = 1, VERTICAL_MOVE = 2 }; class CustomRuler : public QWidget { @@ -33,7 +40,7 @@ class CustomRuler : public QWidget public: CustomRuler(Timecode tc, CustomTrackView *parent); - void setPixelPerMark(double rate); + void setPixelPerMark(int rate); static const int comboScale[]; int outPoint() const; int inPoint() const; @@ -46,6 +53,7 @@ protected: virtual void paintEvent(QPaintEvent * /*e*/); virtual void wheelEvent(QWheelEvent * e); virtual void mousePressEvent(QMouseEvent * event); + virtual void mouseReleaseEvent(QMouseEvent * event); virtual void mouseMoveEvent(QMouseEvent * event); private: @@ -66,6 +74,13 @@ private: QAction *m_editGuide; QAction *m_deleteGuide; int m_clickedGuide; + /** Used for zooming through vertical move */ + QPoint m_clickPoint; + int m_rate; + int m_startRate; + MOUSE_MOVE m_mouseMove; + QMenu *m_goMenu; + public slots: void slotMoveRuler(int newPos); @@ -74,9 +89,11 @@ public slots: private slots: void slotEditGuide(); void slotDeleteGuide(); + void slotGoToGuide(QAction *act); signals: void zoneMoved(int, int); + void adjustZoom(int); }; #endif