]> git.sesse.net Git - kdenlive/commitdiff
Make timeline's ruler time labels obey to frame <-> timecode setting
authorTill Theato <root@ttill.de>
Sat, 22 May 2010 22:08:56 +0000 (22:08 +0000)
committerTill Theato <root@ttill.de>
Sat, 22 May 2010 22:08:56 +0000 (22:08 +0000)
svn path=/trunk/kdenlive/; revision=4474

src/customruler.cpp
src/customruler.h
src/mainwindow.cpp
src/mainwindow.h
src/trackview.cpp
src/trackview.h

index 6606b77024bc8b666351fe24a767d29b63db194c..8a9526931ae3517c81c02d8a61d9984e53c20e81 100644 (file)
@@ -335,7 +335,8 @@ void CustomRuler::paintEvent(QPaintEvent *e)
     const int value  = m_view->cursorPos() * m_factor - m_offset;
     int minval = (e->rect().left() + m_offset) / FRAME_SIZE - 1;
     const int maxval = (e->rect().right() + m_offset) / FRAME_SIZE + 1;
-    if (minval < 0) minval = 0;
+    if (minval < 0)
+        minval = 0;
 
     double f, fend;
     const int offsetmax = maxval * FRAME_SIZE;
@@ -346,7 +347,11 @@ void CustomRuler::paintEvent(QPaintEvent *e)
     int offsetmin = (e->rect().left() + m_offset) / m_textSpacing;
     offsetmin = offsetmin * m_textSpacing;
     for (f = offsetmin; f < offsetmax; f += m_textSpacing) {
-        QString lab = m_timecode.getTimecodeFromFrames((int)(f / m_factor + 0.5));
+        QString lab;
+        if (KdenliveSettings::frametimecode())
+            lab = QString::number((int)(f / m_factor + 0.5));
+        else
+            lab = m_timecode.getTimecodeFromFrames((int)(f / m_factor + 0.5));
         p.drawText(f - m_offset + 2, LABEL_SIZE, lab);
     }
 
@@ -354,22 +359,28 @@ void CustomRuler::paintEvent(QPaintEvent *e)
     offsetmin = offsetmin * littleMarkDistance;
     // draw the little marks
     fend = m_scale * littleMarkDistance;
-    if (fend > 5) for (f = offsetmin - m_offset; f < offsetmax - m_offset; f += fend)
+    if (fend > 5) {
+        for (f = offsetmin - m_offset; f < offsetmax - m_offset; f += fend)
             p.drawLine((int)f, LITTLE_MARK_X1, (int)f, LITTLE_MARK_X2);
+    }
 
     offsetmin = (e->rect().left() + m_offset) / mediumMarkDistance;
     offsetmin = offsetmin * mediumMarkDistance;
     // draw medium marks
     fend = m_scale * mediumMarkDistance;
-    if (fend > 5) for (f = offsetmin - m_offset - fend; f < offsetmax - m_offset + fend; f += fend)
+    if (fend > 5) {
+        for (f = offsetmin - m_offset - fend; f < offsetmax - m_offset + fend; f += fend)
             p.drawLine((int)f, MIDDLE_MARK_X1, (int)f, MIDDLE_MARK_X2);
+    }
 
     offsetmin = (e->rect().left() + m_offset) / bigMarkDistance;
     offsetmin = offsetmin * bigMarkDistance;
     // draw big marks
     fend = m_scale * bigMarkDistance;
-    if (fend > 5) for (f = offsetmin - m_offset; f < offsetmax - m_offset; f += fend)
+    if (fend > 5) {
+        for (f = offsetmin - m_offset; f < offsetmax - m_offset; f += fend)
             p.drawLine((int)f, BIG_MARK_X1, (int)f, BIG_MARK_X2);
+    }
 
     // draw zone cursors
     int off = offset();
index eb6ec3f4bc463b9385bb5f27f4b5c8bfb79c5323..3ebcd1079b9a3c56aa2bc3de6837217ddaccd6d4 100644 (file)
  *   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
 
index e9a896760c55ab966d5b53ee2cf17cada2e0922a..ce4d1d2c5e10e4f09840748f8142320b4a80ca28 100644 (file)
@@ -3315,6 +3315,7 @@ void MainWindow::slotUpdateTimecodeFormat(int ix)
     m_clipMonitor->updateTimecodeFormat();
     m_projectMonitor->updateTimecodeFormat();
     m_activeTimeline->projectView()->clearSelection();
+    m_activeTimeline->updateRuler();
 }
 
 void MainWindow::slotRemoveFocus()
index 136de76b2d5871f10978118ea7e6a793f7191452..2fea45c014c77432b10b865b997239be8034777c 100644 (file)
@@ -388,6 +388,8 @@ private slots:
     void slotTranscodeClip();
     void slotSetDocumentRenderProfile(const QString &dest, const QString &group, const QString &name, const QString &file);
     void slotPrepareRendering(bool scriptExport, bool zoneOnly, const QString &chapterFile);
+    /** @brief Switches between displaying frames or timecode.
+    * @param ix 0 = display timecode, 1 = display frames. */
     void slotUpdateTimecodeFormat(int ix);
     /** @brief Removes the focus of anything. */
     void slotRemoveFocus();
index 969d5aec4782a0096e04a379db1a5b64688b3fa9..db91031c709d5844c13c32146c006e7fb2b50978 100644 (file)
@@ -951,4 +951,9 @@ void TrackView::slotUpdateVerticalScroll(int /*min*/, int max)
     headers_container->layout()->setContentsMargins(0, m_trackview->frameWidth(), 0, height);
 }
 
+void TrackView::updateRuler()
+{
+    m_ruler->update();
+}
+
 #include "trackview.moc"
index ea4cf277658c115b99728d84c21553053cf05e87..efa5a230118c84e9f079c40625e41d4b55ff0f6f 100644 (file)
@@ -63,6 +63,10 @@ public:
     int outPoint() const;
     int inPoint() const;
     int fitZoom() const;
+    /** @brief Updates (redraws) the ruler.
+    *
+    * Used to change from displaying frames to timecode or vice versa. */
+    void updateRuler();
 
 protected:
     virtual void keyPressEvent(QKeyEvent * event);