#include <KFileDialog>
-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 {
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());
}
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");
// read the entries
QMap< QString, QString > profiles = transConfig.entryMap();
QMapIterator<QString, QString> 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()));
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()
if (m_transcodeProcess.state() != QProcess::NotRunning) {
return;
}
+ m_duration = 0;
QStringList parameters;
QString destination;
QString params = ffmpeg_params->toPlainText().simplified();
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: "<<progress<<", "<<m_duration;
+ job_progress->setValue((int) (100.0 * progress / m_duration));
+ }
//kDebug() << "//LOG: " << log;
log_text->setPlainText(log);
}
{
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() + "<br><b>" + i18n("Transcoding finished."));
+ log_text->setHtml(log_text->toPlainText() + "<br /><b>" + i18n("Transcoding finished."));
if (auto_add->isChecked()) {
KUrl url;
if (urls_list->count() > 0) {
return;
} else if (auto_close->isChecked()) accept();
} else {
- log_text->setHtml(log_text->toPlainText() + "<br><b>" + i18n("Transcoding FAILED!"));
+ log_text->setHtml(log_text->toPlainText() + "<br /><b>" + i18n("Transcoding FAILED!"));
}
m_transcodeProcess.close();
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);