#include <KColorScheme>
#include <KNotification>
#include <KStartupInfo>
-// #include <knewstuff2/engine.h>
#include <QDomDocument>
#include <QItemDelegate>
m_view.format_list->setAlternatingRowColors(true);
m_view.size_list->setAlternatingRowColors(true);
- KColorScheme scheme(palette().currentColorGroup(), KColorScheme::Window);
+ KColorScheme scheme(palette().currentColorGroup(), KColorScheme::Window, KSharedConfig::openConfig(KdenliveSettings::colortheme()));
QPalette p = m_view.errorLabel->palette();
p.setColor(QPalette::Background, scheme.background(KColorScheme::NegativeBackground).color());
m_view.errorLabel->setAutoFillBackground(true);
m_view.errorLabel->setPalette(p);
m_view.errorLabel->setHidden(true);
+ connect(m_view.export_audio, SIGNAL(stateChanged(int)), this, SLOT(slotUpdateAudioLabel(int)));
+ m_view.export_audio->setCheckState(Qt::PartiallyChecked);
+
parseProfiles();
parseScriptFiles();
-
+ m_view.running_jobs->setUniformRowHeights(false);
+ m_view.scripts_list->setUniformRowHeights(false);
connect(m_view.start_script, SIGNAL(clicked()), this, SLOT(slotStartScript()));
connect(m_view.delete_script, SIGNAL(clicked()), this, SLOT(slotDeleteScript()));
connect(m_view.scripts_list, SIGNAL(itemSelectionChanged()), this, SLOT(slotCheckScript()));
KMessageBox::sorry(this, i18n("Cannot find the melt program required for rendering (part of Mlt)"));
return;
}
- if (m_view.play_after->isChecked() && KdenliveSettings::defaultplayerapp().isEmpty())
+ if (m_view.play_after->isChecked() && KdenliveSettings::defaultplayerapp().isEmpty()) {
KMessageBox::sorry(this, i18n("Cannot play video after rendering because the default video player application is not set.\nPlease define it in Kdenlive settings dialog."));
+ }
QString chapterFile;
if (m_view.create_chapter->isChecked()) chapterFile = m_view.out_file->url().path() + ".dvdchapter";
}
-void RenderWidget::slotExport(bool scriptExport, int zoneIn, int zoneOut, const QString &playlistPath, const QString &scriptPath)
+void RenderWidget::slotExport(bool scriptExport, int zoneIn, int zoneOut, const QString &playlistPath, const QString &scriptPath, bool exportAudio)
{
QListWidgetItem *item = m_view.size_list->currentItem();
if (!item) return;
else if (m_view.scanning_list->currentIndex() == 2) renderArgs.append(" progressive=0");
// disable audio if requested
- if (!m_view.export_audio->isChecked())
- renderArgs.append(" an=1 ");
+ if (!exportAudio) renderArgs.append(" an=1 ");
// Check if the rendering profile is different from project profile,
// in which case we need to use the producer_comsumer from MLT
QString subsize = currentSize;
if (std.startsWith("s=")) {
subsize = std.section(' ', 0, 0).toLower();
- subsize = subsize.section("=", 1, 1);
+ subsize = subsize.section('=', 1, 1);
} else if (std.contains(" s=")) {
subsize = std.section(" s=", 1, 1);
subsize = subsize.section(' ', 0, 0).toLower();
return;
}
renderParameters << scriptName;
- m_view.tabWidget->setCurrentIndex(1);
// Save rendering profile to document
- emit selectedRenderProfile(m_view.size_list->currentItem()->data(MetaGroupRole).toString(), m_view.size_list->currentItem()->data(GroupRole).toString(), m_view.size_list->currentItem()->text(), dest);
+ QMap <QString, QString> renderProps;
+ renderProps.insert("renderdestination", m_view.size_list->currentItem()->data(MetaGroupRole).toString());
+ renderProps.insert("rendercategory", m_view.size_list->currentItem()->data(GroupRole).toString());
+ renderProps.insert("renderprofile", m_view.size_list->currentItem()->text());
+ renderProps.insert("renderurl", dest);
+ renderProps.insert("renderzone", QString::number(m_view.render_zone->isChecked()));
+ renderProps.insert("renderguide", QString::number(m_view.render_guide->isChecked()));
+ renderProps.insert("renderstartguide", QString::number(m_view.guide_start->currentIndex()));
+ renderProps.insert("renderendguide", QString::number(m_view.guide_end->currentIndex()));
+ renderProps.insert("renderendguide", QString::number(m_view.guide_end->currentIndex()));
+ renderProps.insert("renderscanning", QString::number(m_view.scanning_list->currentIndex()));
+ int export_audio = 0;
+ if (m_view.export_audio->checkState() == Qt::Checked) export_audio = 2;
+ else if (m_view.export_audio->checkState() == Qt::Unchecked) export_audio = 1;
+ renderProps.insert("renderexportaudio", QString::number(export_audio));
+ renderProps.insert("renderrescale", QString::number(m_view.rescale->isChecked()));
+ renderProps.insert("renderrescalewidth", QString::number(m_view.rescale_width->value()));
+ renderProps.insert("renderrescaleheight", QString::number(m_view.rescale_height->value()));
+ renderProps.insert("rendertcoverlay", QString::number(m_view.tc_overlay->isChecked()));
+ renderProps.insert("renderratio", QString::number(m_view.rescale_keep->isChecked()));
+ renderProps.insert("renderplay", QString::number(m_view.play_after->isChecked()));
+
+ emit selectedRenderProfile(renderProps);
// insert item in running jobs list
QTreeWidgetItem *renderItem;
}
}
renderItem->setData(1, Qt::UserRole + 3, render_process_args);
+ if (exportAudio == false) renderItem->setData(1, Qt::UserRole + 5, i18n("Video without audio track"));
+ else renderItem->setData(1, Qt::UserRole + 5, QString());
+ m_view.running_jobs->setCurrentItem(renderItem);
+ m_view.tabWidget->setCurrentIndex(1);
checkRenderStatus();
}
activate = true;
}
m_view.abort_job->setEnabled(activate);
+ for (int i = 0; i < m_view.running_jobs->topLevelItemCount(); i++) {
+ current = m_view.running_jobs->topLevelItem(i);
+ if (current == m_view.running_jobs->currentItem()) {
+ current->setSizeHint(1, QSize(m_view.running_jobs->columnWidth(1), fontMetrics().height() * 3));
+ } else current->setSizeHint(1, QSize(m_view.running_jobs->columnWidth(1), fontMetrics().height() * 2));
+ }
}
void RenderWidget::slotCLeanUpJobs()
void RenderWidget::slotCheckScript()
{
- QTreeWidgetItem *item = m_view.scripts_list->currentItem();
- if (item == NULL) return;
- m_view.start_script->setEnabled(item->data(0, Qt::UserRole).toString().isEmpty());
+ QTreeWidgetItem *current = m_view.scripts_list->currentItem();
+ if (current == NULL) return;
+ m_view.start_script->setEnabled(current->data(0, Qt::UserRole).toString().isEmpty());
m_view.delete_script->setEnabled(true);
+ for (int i = 0; i < m_view.scripts_list->topLevelItemCount(); i++) {
+ current = m_view.scripts_list->topLevelItem(i);
+ if (current == m_view.scripts_list->currentItem()) {
+ current->setSizeHint(1, QSize(m_view.scripts_list->columnWidth(1), fontMetrics().height() * 3));
+ } else current->setSizeHint(1, QSize(m_view.scripts_list->columnWidth(1), fontMetrics().height() * 2));
+ }
}
void RenderWidget::slotStartScript()
m_view.error_box->setVisible(false);
}
-void RenderWidget::setRenderProfile(const QString &dest, const QString &group, const QString &name, const QString &url)
+void RenderWidget::setRenderProfile(QMap <QString, QString> props)
{
m_view.destination_list->blockSignals(true);
m_view.format_list->blockSignals(true);
-
+ m_view.scanning_list->setCurrentIndex(props.value("renderscanning").toInt());
+ int exportAudio = props.value("renderexportaudio").toInt();
+ switch (exportAudio) {
+ case 1:
+ m_view.export_audio->setCheckState(Qt::Unchecked);
+ break;
+ case 2:
+ m_view.export_audio->setCheckState(Qt::Checked);
+ break;
+ default:
+ m_view.export_audio->setCheckState(Qt::PartiallyChecked);
+ }
+ if (props.contains("renderrescale")) m_view.rescale->setChecked(props.value("renderrescale").toInt());
+ if (props.contains("renderrescalewidth")) m_view.rescale_width->setValue(props.value("renderrescalewidth").toInt());
+ if (props.contains("renderrescaleheight")) m_view.rescale_height->setValue(props.value("renderrescaleheight").toInt());
+ if (props.contains("rendertcoverlay")) m_view.tc_overlay->setChecked(props.value("rendertcoverlay").toInt());
+ if (props.contains("renderratio")) m_view.rescale_keep->setChecked(props.value("renderratio").toInt());
+ if (props.contains("renderplay")) m_view.play_after->setChecked(props.value("renderplay").toInt());
+
+ if (props.value("renderzone") == "1") m_view.render_zone->setChecked(true);
+ else if (props.value("renderguide") == "1") {
+ m_view.render_guide->setChecked(true);
+ m_view.guide_start->setCurrentIndex(props.value("renderstartguide").toInt());
+ m_view.guide_end->setCurrentIndex(props.value("renderendguide").toInt());
+ } else m_view.render_full->setChecked(true);
+ slotUpdateGuideBox();
+
+ QString url = props.value("renderurl");
if (!url.isEmpty()) m_view.out_file->setUrl(KUrl(url));
// set destination
for (int i = 0; i < m_view.destination_list->count(); i++) {
- if (m_view.destination_list->itemData(i, Qt::UserRole) == dest) {
+ if (m_view.destination_list->itemData(i, Qt::UserRole) == props.value("renderdestination")) {
m_view.destination_list->setCurrentIndex(i);
break;
}
refreshCategory();
// set category
+ QString group = props.value("rendercategory");
if (!group.isEmpty()) {
QList<QListWidgetItem *> childs = m_view.format_list->findItems(group, Qt::MatchExactly);
if (!childs.isEmpty()) {
}
// set profile
- QList<QListWidgetItem *> childs = m_view.size_list->findItems(name, Qt::MatchExactly);
+ QList<QListWidgetItem *> childs = m_view.size_list->findItems(props.value("renderprofile"), Qt::MatchExactly);
if (!childs.isEmpty()) {
m_view.size_list->setCurrentItem(childs.at(0));
m_view.size_list->scrollToItem(childs.at(0));
if (m_view.rescale_keep->isChecked()) slotUpdateRescaleWidth(m_view.rescale_width->value());
}
+void RenderWidget::slotUpdateAudioLabel(int ix)
+{
+ if (ix == Qt::PartiallyChecked)
+ m_view.export_audio->setText(i18n("Export audio (automatic)"));
+ else
+ m_view.export_audio->setText(i18n("Export audio"));
+}
+
+bool RenderWidget::automaticAudioExport() const
+{
+ return (m_view.export_audio->checkState() == Qt::PartiallyChecked);
+}
+
+bool RenderWidget::selectedAudioExport() const
+{
+ return (m_view.export_audio->checkState() != Qt::Unchecked);
+}
+