else if (path.endsWith("bmp")) m_view.image_type->setCurrentIndex(TYPE_BMP);
else if (path.endsWith("gif")) m_view.image_type->setCurrentIndex(TYPE_GIF);
m_view.slide_duration->setText(tc.getTimecodeFromFrames(props.value("ttl").toInt()));
+
+ m_view.slide_duration_format->addItem(i18n("hh:mm:ss::ff"));
+ m_view.slide_duration_format->addItem(i18n("Frames"));
+ connect(m_view.slide_duration_format, SIGNAL(activated(int)), this, SLOT(slotUpdateDurationFormat(int)));
+ m_view.slide_duration_frames->setHidden(true);
+ m_view.luma_duration_frames->setHidden(true);
+
parseFolder();
m_view.luma_duration->setText(tc.getTimecodeFromFrames(props.value("luma_duration").toInt()));
bool enable = false;
if (state == Qt::Checked) enable = true;
m_view.luma_duration->setEnabled(enable);
+ m_view.luma_duration_frames->setEnabled(enable);
m_view.slide_luma->setEnabled(enable);
if (enable) {
m_view.luma_file->setEnabled(m_view.slide_luma->isChecked());
props["resource"] = new_path;
kDebug() << "//// SLIDE EDIT, NEW:" << new_path << ", OLD; " << old_props.value("resource");
}
- int duration = m_tc.getFrameCount(m_view.slide_duration->text(), m_fps);
+ int duration;
+ if (m_view.slide_duration_format->currentIndex() == 1) {
+ // we are in frames mode
+ duration = m_view.slide_duration_frames->value();
+ } else duration = m_tc.getFrameCount(m_view.slide_duration->text(), m_fps);
if (duration != old_props.value("ttl").toInt()) {
m_clipNeedsRefresh = true;
props["ttl"] = QString::number(duration);
props["out"] = QString::number(duration * m_count);
}
if (m_view.slide_fade->isChecked()) {
- int luma_duration = m_tc.getFrameCount(m_view.luma_duration->text(), m_fps);
+ int luma_duration;
+ if (m_view.slide_duration_format->currentIndex() == 1) {
+ // we are in frames mode
+ luma_duration = m_view.luma_duration_frames->value();
+ } else luma_duration = m_tc.getFrameCount(m_view.luma_duration->text(), m_fps);
if (luma_duration != old_props.value("luma_duration").toInt()) {
m_clipNeedsRefresh = true;
props["luma_duration"] = QString::number(luma_duration);
}
}
+void ClipProperties::slotUpdateDurationFormat(int ix)
+{
+ bool framesFormat = ix == 1;
+ if (framesFormat) {
+ // switching to frames count, update widget
+ m_view.slide_duration_frames->setValue(m_tc.getFrameCount(m_view.slide_duration->text(), m_tc.fps()));
+ m_view.luma_duration_frames->setValue(m_tc.getFrameCount(m_view.luma_duration->text(), m_tc.fps()));
+ m_view.slide_duration->setHidden(true);
+ m_view.luma_duration->setHidden(true);
+ m_view.slide_duration_frames->setHidden(false);
+ m_view.luma_duration_frames->setHidden(false);
+ } else {
+ // switching to timecode format
+ m_view.slide_duration->setText(m_tc.getTimecodeFromFrames(m_view.slide_duration_frames->value()));
+ m_view.luma_duration->setText(m_tc.getTimecodeFromFrames(m_view.luma_duration_frames->value()));
+ m_view.slide_duration_frames->setHidden(true);
+ m_view.luma_duration_frames->setHidden(true);
+ m_view.slide_duration->setHidden(false);
+ m_view.luma_duration->setHidden(false);
+ }
+}
+
#include "clipproperties.moc"
void slotCheckMaxLength();
void slotEnableLuma(int state);
void slotEnableLumaFile(int state);
+ void slotUpdateDurationFormat(int ix);
private:
Ui::ClipProperties_UI m_view;
void ProjectList::slotAddSlideshowClip()
{
if (!m_commandStack) kDebug() << "!!!!!!!!!!!!!!!! NO CMD STK";
- SlideshowClip *dia = new SlideshowClip(this);
+ SlideshowClip *dia = new SlideshowClip(m_timecode, this);
if (dia->exec() == QDialog::Accepted) {
#include <QDir>
-SlideshowClip::SlideshowClip(QWidget * parent) :
+SlideshowClip::SlideshowClip(Timecode tc, QWidget * parent) :
QDialog(parent),
- m_count(0)
+ m_count(0),
+ m_timecode(tc)
{
setFont(KGlobalSettings::toolBarFont());
setWindowTitle(i18n("Add Slideshow Clip"));
m_view.luma_duration->setText("00:00:00:24");
m_view.folder_url->setUrl(QDir::homePath());
+ m_view.clip_duration_format->addItem(i18n("hh:mm:ss::ff"));
+ m_view.clip_duration_format->addItem(i18n("Frames"));
+ connect(m_view.clip_duration_format, SIGNAL(activated(int)), this, SLOT(slotUpdateDurationFormat(int)));
+ m_view.clip_duration_frames->setHidden(true);
+ m_view.luma_duration_frames->setHidden(true);
// Check for Kdenlive installed luma files
QStringList filters;
bool enable = false;
if (state == Qt::Checked) enable = true;
m_view.luma_duration->setEnabled(enable);
+ m_view.luma_duration_frames->setEnabled(enable);
m_view.luma_fade->setEnabled(enable);
if (enable) {
m_view.luma_file->setEnabled(m_view.luma_fade->isChecked());
QString SlideshowClip::clipDuration() const
{
+ if (m_view.clip_duration_format->currentIndex() == 1) {
+ // we are in frames mode
+ return m_timecode.getTimecodeFromFrames(m_view.clip_duration_frames->value());
+ }
return m_view.clip_duration->text();
}
QString SlideshowClip::lumaDuration() const
{
+ if (m_view.clip_duration_format->currentIndex() == 1) {
+ // we are in frames mode
+ return m_timecode.getTimecodeFromFrames(m_view.luma_duration_frames->value());
+ }
return m_view.luma_duration->text();
}
return m_view.luma_file->itemData(m_view.luma_file->currentIndex()).toString();
}
+void SlideshowClip::slotUpdateDurationFormat(int ix)
+{
+ bool framesFormat = ix == 1;
+ if (framesFormat) {
+ // switching to frames count, update widget
+ m_view.clip_duration_frames->setValue(m_timecode.getFrameCount(m_view.clip_duration->text(), m_timecode.fps()));
+ m_view.luma_duration_frames->setValue(m_timecode.getFrameCount(m_view.luma_duration->text(), m_timecode.fps()));
+ } else {
+ // switching to timecode format
+ m_view.clip_duration->setText(m_timecode.getTimecodeFromFrames(m_view.clip_duration_frames->value()));
+ m_view.luma_duration->setText(m_timecode.getTimecodeFromFrames(m_view.luma_duration_frames->value()));
+ }
+ m_view.clip_duration_frames->setHidden(!framesFormat);
+ m_view.clip_duration->setHidden(framesFormat);
+ m_view.luma_duration_frames->setHidden(!framesFormat);
+ m_view.luma_duration->setHidden(framesFormat);
+}
+
#include "slideshowclip.moc"
Q_OBJECT
public:
- SlideshowClip(QWidget * parent = 0);
+ SlideshowClip(Timecode tc, QWidget * parent = 0);
/** return selected path for slideshow in MLT format */
QString selectedPath() const;
QString clipName() const;
void slotEnableLuma(int state);
void slotEnableLumaFile(int state);
void slotSetItemIcon(int row);
+ void slotUpdateDurationFormat(int ix);
private:
Ui::SlideshowClip_UI m_view;
int m_count;
+ Timecode m_timecode;
};
}
}
-QString Timecode::getTimecodeFromFrames(int frames)
+QString Timecode::getTimecodeFromFrames(int frames) const
{
return getTimecodeHH_MM_SS_FF(frames);
}
int getFrameCount(const QString duration, double fps) const;
static QString getEasyTimecode(const GenTime & time, const double &fps);
static QString getStringTimecode(int frames, const double &fps);
- QString getTimecodeFromFrames(int frames);
+ QString getTimecodeFromFrames(int frames) const;
int fps() const;
private: