X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fcliptranscode.cpp;h=8dbf6df4430c436500464390dbf4ca5c24ed450c;hb=40af4d58e9d4bfd095ad8a9d5dd621a15b630356;hp=e81b4b5479f417e90bf6d12c94633d927332cd37;hpb=3d6860cb1c05c50a462a82ca7fbfa163ec295b66;p=kdenlive diff --git a/src/cliptranscode.cpp b/src/cliptranscode.cpp index e81b4b54..8dbf6df4 100644 --- a/src/cliptranscode.cpp +++ b/src/cliptranscode.cpp @@ -26,22 +26,24 @@ #include -ClipTranscode::ClipTranscode(KUrl::List urls, const QString ¶ms, QWidget * parent) : - QDialog(parent), m_urls(urls) +ClipTranscode::ClipTranscode(KUrl::List urls, const QString ¶ms, const QString &description, QWidget * parent) : + QDialog(parent), m_urls(urls), m_duration(0) { setFont(KGlobalSettings::toolBarFont()); setupUi(this); setAttribute(Qt::WA_DeleteOnClose); + log_text->setHidden(true); setWindowTitle(i18n("Transcode Clip")); auto_add->setText(i18np("Add clip to project", "Add clips to project", m_urls.count())); - dest_url->fileDialog()->setOperationMode(KFileDialog::Saving); if (m_urls.count() == 1) { QString fileName = m_urls.at(0).path(); //.section('.', 0, -1); QString newFile = params.section(' ', -1).replace("%1", fileName); KUrl dest(newFile); source_url->setUrl(m_urls.at(0)); + dest_url->setMode(KFile::File); dest_url->setUrl(dest); + dest_url->fileDialog()->setOperationMode(KFileDialog::Saving); urls_list->setHidden(true); connect(source_url, SIGNAL(textChanged(const QString &)), this, SLOT(slotUpdateParams())); } else { @@ -50,6 +52,7 @@ ClipTranscode::ClipTranscode(KUrl::List urls, const QString ¶ms, QWidget * p label_dest->setText(i18n("Destination folder")); dest_url->setMode(KFile::Directory); dest_url->setUrl(KUrl(m_urls.at(0).directory())); + dest_url->fileDialog()->setOperationMode(KFileDialog::Saving); for (int i = 0; i < m_urls.count(); i++) urls_list->addItem(m_urls.at(i).path()); } @@ -57,6 +60,9 @@ ClipTranscode::ClipTranscode(KUrl::List urls, const QString ¶ms, QWidget * p label_profile->setHidden(true); profile_list->setHidden(true); ffmpeg_params->setPlainText(params.simplified()); + if (!description.isEmpty()) { + transcode_info->setText(description); + } else transcode_info->setHidden(true); } else { // load Profiles KSharedConfigPtr config = KSharedConfig::openConfig("kdenlivetranscodingrc"); @@ -64,11 +70,14 @@ ClipTranscode::ClipTranscode(KUrl::List urls, const QString ¶ms, QWidget * p // read the entries QMap< QString, QString > profiles = transConfig.entryMap(); QMapIterator i(profiles); - connect(profile_list, SIGNAL(currentIndexChanged(int)), this, SLOT(slotUpdateParams(int))); while (i.hasNext()) { i.next(); - profile_list->addItem(i.key(), i.value()); + QStringList data = i.value().split(";", QString::SkipEmptyParts); + profile_list->addItem(i.key(), data.at(0)); + if (data.count() > 1) profile_list->setItemData(profile_list->count() - 1, data.at(1), Qt::UserRole + 1); } + connect(profile_list, SIGNAL(currentIndexChanged(int)), this, SLOT(slotUpdateParams(int))); + slotUpdateParams(0); } connect(button_start, SIGNAL(clicked()), this, SLOT(slotStartTransCode())); @@ -77,7 +86,7 @@ ClipTranscode::ClipTranscode(KUrl::List urls, const QString ¶ms, QWidget * p connect(&m_transcodeProcess, SIGNAL(readyReadStandardOutput()), this, SLOT(slotShowTranscodeInfo())); connect(&m_transcodeProcess, SIGNAL(finished(int, QProcess::ExitStatus)), this, SLOT(slotTranscodeFinished(int, QProcess::ExitStatus))); - //adjustSize(); + adjustSize(); } ClipTranscode::~ClipTranscode() @@ -92,6 +101,7 @@ void ClipTranscode::slotStartTransCode() if (m_transcodeProcess.state() != QProcess::NotRunning) { return; } + m_duration = 0; QStringList parameters; QString destination; QString params = ffmpeg_params->toPlainText().simplified(); @@ -128,6 +138,30 @@ void ClipTranscode::slotStartTransCode() void ClipTranscode::slotShowTranscodeInfo() { QString log = QString(m_transcodeProcess.readAll()); + int progress; + if (m_duration == 0) { + if (log.contains("Duration:")) { + QString data = log.section("Duration:", 1, 1).section(',', 0, 0).simplified(); + QStringList numbers = data.split(':'); + m_duration = numbers.at(0).toInt() * 3600 + numbers.at(1).toInt() * 60 + numbers.at(2).toDouble(); + log_text->setHidden(true); + job_progress->setHidden(false); + } + else { + log_text->setHidden(false); + job_progress->setHidden(true); + } + } + else if (log.contains("time=")) { + QString time = log.section("time=", 1, 1).simplified().section(' ', 0, 0); + if (time.contains(':')) { + QStringList numbers = time.split(':'); + progress = numbers.at(0).toInt() * 3600 + numbers.at(1).toInt() * 60 + numbers.at(2).toDouble(); + } + else progress = (int) time.toDouble(); + kDebug()<<"// PROGRESS: "<setValue((int) (100.0 * progress / m_duration)); + } //kDebug() << "//LOG: " << log; log_text->setPlainText(log); } @@ -136,9 +170,10 @@ void ClipTranscode::slotTranscodeFinished(int exitCode, QProcess::ExitStatus exi { buttonBox->button(QDialogButtonBox::Abort)->setText(i18n("Close")); button_start->setEnabled(true); + m_duration = 0; if (exitCode == 0 && exitStatus == QProcess::NormalExit) { - log_text->setHtml(log_text->toPlainText() + "
" + i18n("Transcoding finished.")); + log_text->setHtml(log_text->toPlainText() + "
" + i18n("Transcoding finished.")); if (auto_add->isChecked()) { KUrl url; if (urls_list->count() > 0) { @@ -154,7 +189,7 @@ void ClipTranscode::slotTranscodeFinished(int exitCode, QProcess::ExitStatus exi return; } else if (auto_close->isChecked()) accept(); } else { - log_text->setHtml(log_text->toPlainText() + "
" + i18n("Transcoding FAILED!")); + log_text->setHtml(log_text->toPlainText() + "
" + i18n("Transcoding FAILED!")); } m_transcodeProcess.close(); @@ -166,6 +201,11 @@ void ClipTranscode::slotUpdateParams(int ix) if (ix != -1) { QString params = profile_list->itemData(ix).toString(); ffmpeg_params->setPlainText(params.simplified()); + QString desc = profile_list->itemData(ix, Qt::UserRole + 1).toString(); + if (!desc.isEmpty()) { + transcode_info->setText(desc); + transcode_info->setHidden(false); + } else transcode_info->setHidden(true); } if (urls_list->count() == 0) { QString newFile = ffmpeg_params->toPlainText().simplified().section(' ', -1).replace("%1", fileName);