]> git.sesse.net Git - kdenlive/blobdiff - src/clipdurationdialog.cpp
Const'ref
[kdenlive] / src / clipdurationdialog.cpp
index 58243e9122c07e3a517e826b2c3296b8b807673c..853339380b4f5d4b08dd1cb804ebd0a3d8ec0b29 100644 (file)
 
 #include "clipdurationdialog.h"
 #include "clipitem.h"
-#include "kdenlivesettings.h"
 
 #include <KDebug>
 #include <KMessageBox>
+#include <KGlobalSettings>
 
 #include <QWheelEvent>
 
-ClipDurationDialog::ClipDurationDialog(AbstractClipItem *clip, Timecode tc, GenTime min, GenTime max, QWidget * parent):
+ClipDurationDialog::ClipDurationDialog(AbstractClipItem *clip, const Timecode &tc, const GenTime &min, const GenTime &max, QWidget * parent):
         QDialog(parent),
         m_clip(clip),
-        m_tc(tc),
         m_min(min),
         m_max(max)
 {
     setFont(KGlobalSettings::toolBarFont());
-    m_fps = m_tc.fps();
-    m_view.setupUi(this);
+    setupUi(this);
+
+    m_pos = new TimecodeDisplay(tc);
+    m_cropStart = new TimecodeDisplay(tc);
+    m_dur = new TimecodeDisplay(tc);
+    m_cropEnd = new TimecodeDisplay(tc);
+    
+    clip_position_box->addWidget(m_pos);
+    crop_start_box->addWidget(m_cropStart);
+    clip_duration_box->addWidget(m_dur);
+    crop_end_box->addWidget(m_cropEnd);
 
     bool allowCrop = true;
     if (clip->type() == AVWIDGET) {
         ClipItem *item = static_cast <ClipItem *>(clip);
-        int t = item->clipType();
-        if (t == COLOR || t == IMAGE || t == TEXT) allowCrop = false;
+        const int t = item->clipType();
+        if (t == COLOR || t == IMAGE || t == TEXT)
+            allowCrop = false;
     }
 
     if (!allowCrop || clip->type() == TRANSITIONWIDGET) {
-        m_view.crop_up->hide();
-        m_view.crop_down->hide();
-        m_view.crop_position->hide();
-        m_view.crop_label->hide();
+        m_cropStart->setHidden(true);
+        crop_label->hide();
+        m_cropEnd->setHidden(true),
+        end_label->hide();
     }
 
-    m_crop = m_clip->cropStart().frames(m_fps);
-    m_view.clip_position->setText(tc.getTimecode(m_clip->startPos()));
-    m_view.crop_position->setText(tc.getTimecode(m_clip->cropStart()));
-    m_view.clip_duration->setText(tc.getTimecode(m_clip->cropDuration()));
-    connect(m_view.position_up, SIGNAL(clicked()), this, SLOT(slotPosUp()));
-    connect(m_view.position_down, SIGNAL(clicked()), this, SLOT(slotPosDown()));
-    connect(m_view.crop_up, SIGNAL(clicked()), this, SLOT(slotCropUp()));
-    connect(m_view.crop_down, SIGNAL(clicked()), this, SLOT(slotCropDown()));
-    connect(m_view.duration_up, SIGNAL(clicked()), this, SLOT(slotDurUp()));
-    connect(m_view.duration_down, SIGNAL(clicked()), this, SLOT(slotDurDown()));
-    connect(m_view.crop_position, SIGNAL(textChanged(const QString &)), this, SLOT(slotCheckCrop()));
-    connect(m_view.clip_duration, SIGNAL(textChanged(const QString &)), this, SLOT(slotCheckDuration()));
-    connect(m_view.clip_position, SIGNAL(textChanged(const QString &)), this, SLOT(slotCheckStart()));
+    m_crop = m_clip->cropStart();
+
+    m_pos->setValue(m_clip->startPos());
+    m_dur->setValue(m_clip->cropDuration());
+    m_cropStart->setValue(m_clip->cropStart());
+    m_cropEnd->setValue(m_clip->maxDuration() - m_clip->cropDuration() - m_clip->cropStart());
+
+    connect(m_pos,       SIGNAL(timeCodeEditingFinished()), this, SLOT(slotCheckStart()));
+    connect(m_dur,       SIGNAL(timeCodeEditingFinished()), this, SLOT(slotCheckDuration()));
+    connect(m_cropStart, SIGNAL(timeCodeEditingFinished()), this, SLOT(slotCheckCrop()));
+    connect(m_cropEnd,   SIGNAL(timeCodeEditingFinished()), this, SLOT(slotCheckEnd()));
+
     adjustSize();
 }
 
 ClipDurationDialog::~ClipDurationDialog()
 {
+    delete m_pos;
+    delete m_dur;
+    delete m_cropStart;
+    delete m_cropEnd;
 }
 
 void ClipDurationDialog::slotCheckStart()
 {
-    int pos = m_tc.getFrameCount(m_view.clip_position->text());
-    int dur = m_tc.getFrameCount(m_view.clip_duration->text());
-    GenTime start(pos, m_fps);
-    GenTime duration(dur, m_fps);
-    if (m_min != GenTime() && start < m_min) {
-        m_view.clip_position->setText(m_tc.getTimecode(m_min));
-    } else if (m_max != GenTime() && start + duration > m_max) {
-        m_view.clip_position->setText(m_tc.getTimecode(m_max - duration));
-    }
+    GenTime start = m_pos->gentime();
+    GenTime duration = m_dur->gentime();
+    if (m_min != GenTime() && start < m_min)
+        m_pos->setValue(m_min);
+    else if (m_max != GenTime() && start + duration > m_max)
+        m_pos->setValue(m_max - duration);
 }
 
 void ClipDurationDialog::slotCheckDuration()
 {
-    int pos = m_tc.getFrameCount(m_view.clip_position->text());
-    int dur = m_tc.getFrameCount(m_view.clip_duration->text());
-    int crop = m_tc.getFrameCount(m_view.crop_position->text());
-    GenTime start(pos, m_fps);
-    GenTime duration(dur, m_fps);
-    GenTime cropStart(crop, m_fps);
+    GenTime start = m_pos->gentime();
+    GenTime duration = m_dur->gentime();
+    GenTime cropStart = m_cropStart->gentime();
     GenTime maxDuration;
-    if (m_clip->maxDuration() == GenTime()) maxDuration = m_max;
-    else maxDuration = m_max == GenTime() ? start + m_clip->maxDuration() - cropStart : qMin(m_max, start + m_clip->maxDuration() - cropStart);
+
+    if (m_clip->maxDuration() == GenTime())
+        maxDuration = m_max;
+    else
+        maxDuration = m_max == GenTime() ? start + m_clip->maxDuration() - cropStart : qMin(m_max, start + m_clip->maxDuration() - cropStart);
+
     if (maxDuration != GenTime() && start + duration > maxDuration) {
-        m_view.clip_duration->blockSignals(true);
-        m_view.clip_duration->setText(m_tc.getTimecode(maxDuration - start));
-        m_view.clip_duration->blockSignals(false);
+        m_dur->blockSignals(true);
+        m_dur->setValue(maxDuration - start);
+        m_dur->blockSignals(false);
     }
+
+    m_cropEnd->blockSignals(true);
+    m_cropEnd->setValue(m_clip->maxDuration() - m_dur->gentime() - cropStart);
+    m_cropEnd->blockSignals(false);
 }
 
 void ClipDurationDialog::slotCheckCrop()
 {
-    int dur = m_tc.getFrameCount(m_view.clip_duration->text());
-    int crop = m_tc.getFrameCount(m_view.crop_position->text());
-    int diff = crop - m_crop;
-    if ((diff > 0 && diff < dur) || diff < 0) {
-        dur -= diff;
+    GenTime duration = m_dur->gentime();
+    GenTime cropStart = m_cropStart->gentime();
+    GenTime maxDuration = m_clip->maxDuration();
+
+    GenTime diff = cropStart - m_crop;
+    if ((diff > GenTime() && diff < duration) || diff < GenTime()) {
+        duration -= diff;
     } else {
-        m_view.crop_position->setText(m_tc.getTimecode(GenTime(m_crop, m_fps)));
+        m_cropStart->setValue(m_crop);
         return;
     }
-    GenTime duration(dur, m_fps);
-    GenTime cropStart(crop, m_fps);
-    GenTime maxDuration = m_clip->maxDuration();
+
     if (maxDuration != GenTime() && cropStart + duration > maxDuration) {
-        m_view.crop_position->setText(m_tc.getTimecode(GenTime(m_crop, m_fps)));
+        m_cropStart->setValue(m_crop);
     } else {
-        m_crop = crop;
-        m_view.clip_duration->blockSignals(true);
-        m_view.clip_duration->setText(m_tc.getTimecode(duration));
-        m_view.clip_duration->blockSignals(false);
+        m_crop = cropStart;
+        m_dur->blockSignals(true);
+        m_dur->setValue(duration);
+        m_dur->blockSignals(false);
     }
 }
 
-void ClipDurationDialog::slotPosUp()
-{
-    int position = m_tc.getFrameCount(m_view.clip_position->text());
-    //if (duration >= m_clip->duration().frames(m_fps)) return;
-    position ++;
-    m_view.clip_position->setText(m_tc.getTimecode(GenTime(position, m_fps)));
-}
-
-void ClipDurationDialog::slotPosDown()
+void ClipDurationDialog::slotCheckEnd()
 {
-    int position = m_tc.getFrameCount(m_view.clip_position->text());
-    //if (duration >= m_clip->duration().frames(m_fps)) return;
-    position --;
-    m_view.clip_position->setText(m_tc.getTimecode(GenTime(position, m_fps)));
-}
+    GenTime cropStart = m_cropStart->gentime();
+    GenTime cropEnd = m_cropEnd->gentime();
+    GenTime duration = m_clip->maxDuration() - cropEnd - cropStart;
 
-void ClipDurationDialog::slotDurUp()
-{
-    int duration = m_tc.getFrameCount(m_view.clip_duration->text());
-    int crop = m_tc.getFrameCount(m_view.crop_position->text());
-    if (m_clip->maxDuration() != GenTime() && duration + crop > m_clip->maxDuration().frames(m_fps)) return;
-    duration ++;
-    m_view.clip_duration->setText(m_tc.getTimecode(GenTime(duration, m_fps)));
-}
-
-void ClipDurationDialog::slotDurDown()
-{
-    int duration = m_tc.getFrameCount(m_view.clip_duration->text());
-    if (duration <= 0) return;
-    duration --;
-    m_view.clip_duration->setText(m_tc.getTimecode(GenTime(duration, m_fps)));
-}
-
-void ClipDurationDialog::slotCropUp()
-{
-    int crop = m_tc.getFrameCount(m_view.crop_position->text());
-    int duration = m_tc.getFrameCount(m_view.clip_duration->text());
-    if (m_clip->maxDuration() != GenTime() && duration + crop > m_clip->maxDuration().frames(m_fps)) return;
-    crop ++;
-    m_view.crop_position->setText(m_tc.getTimecode(GenTime(crop, m_fps)));
-}
-
-void ClipDurationDialog::slotCropDown()
-{
-    int crop = m_tc.getFrameCount(m_view.crop_position->text());
-    if (crop <= 0) return;
-    crop --;
-    m_view.crop_position->setText(m_tc.getTimecode(GenTime(crop, m_fps)));
+    if (duration >= GenTime()) {
+        m_dur->setValue(duration);
+        slotCheckDuration();
+    } else {
+        m_cropEnd->blockSignals(true);
+        m_cropEnd->setValue(m_clip->maxDuration() - m_dur->gentime() - cropStart);
+        m_cropEnd->blockSignals(false);
+    }
 }
 
 GenTime ClipDurationDialog::startPos() const
 {
-    int pos = m_tc.getFrameCount(m_view.clip_position->text());
-    return GenTime(pos, m_fps);
+    return m_pos->gentime();
 }
 
 GenTime ClipDurationDialog::cropStart() const
 {
-    int pos = m_tc.getFrameCount(m_view.crop_position->text());
-    return GenTime(pos, m_fps);
+    return m_cropStart->gentime();
 }
 
 GenTime ClipDurationDialog::duration() const
 {
-    int pos = m_tc.getFrameCount(m_view.clip_duration->text());
-    return GenTime(pos, m_fps);
-}
-
-void ClipDurationDialog::wheelEvent(QWheelEvent * event)
-{
-    if (m_view.clip_position->underMouse()) {
-        if (event->delta() > 0)
-            slotPosUp();
-        else
-            slotPosDown();
-    } else if (m_view.clip_duration->underMouse()) {
-        if (event->delta() > 0)
-            slotDurUp();
-        else
-            slotDurDown();
-    } else if (m_view.crop_position->underMouse()) {
-        if (event->delta() > 0)
-            slotCropUp();
-        else
-            slotCropDown();
-    }
+    return m_dur->gentime();
 }
 
 #include "clipdurationdialog.moc"