ClipTranscode::ClipTranscode(KUrl::List urls, const QString ¶ms, const QString &description, QWidget * parent) :
- QDialog(parent), m_urls(urls)
+ 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()));
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."));
<rect>
<x>0</x>
<y>0</y>
- <width>316</width>
- <height>399</height>
+ <width>291</width>
+ <height>450</height>
</rect>
</property>
<property name="windowTitle">
</property>
</widget>
</item>
+ <item row="7" column="1" colspan="2">
+ <widget class="QProgressBar" name="job_progress">
+ <property name="value">
+ <number>0</number>
+ </property>
+ </widget>
+ </item>
</layout>
</widget>
<customwidgets>
- <customwidget>
- <class>KUrlRequester</class>
- <extends>QFrame</extends>
- <header>kurlrequester.h</header>
- </customwidget>
<customwidget>
<class>KComboBox</class>
<extends>QComboBox</extends>
<header>kcombobox.h</header>
</customwidget>
+ <customwidget>
+ <class>KUrlRequester</class>
+ <extends>QFrame</extends>
+ <header>kurlrequester.h</header>
+ </customwidget>
</customwidgets>
<resources/>
<connections>