+void RenderWidget::slotGenerateScript()
+{
+ slotPrepareExport(true);
+}
+
+void RenderWidget::slotHideLog()
+{
+ m_view.error_box->setVisible(false);
+}
+
+void RenderWidget::setRenderProfile(const QMap<QString, QString> &props)
+{
+ 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("rendertctype")) m_view.tc_type->setCurrentIndex(props.value("rendertctype").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.contains("rendertwopass")) m_view.checkTwoPass->setChecked(props.value("rendertwopass").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
+ int categoryIndex = m_view.destination_list->findData(props.value("renderdestination"));
+ if (categoryIndex == -1) categoryIndex = 0;
+ m_view.destination_list->blockSignals(true);
+ m_view.destination_list->setCurrentIndex(categoryIndex);
+ m_view.destination_list->blockSignals(false);
+
+ // Clear previous error messages
+ refreshCategory(props.value("rendercategory"), props.value("renderprofile"));
+}
+
+bool RenderWidget::startWaitingRenderJobs()
+{
+ m_blockProcessing = true;
+ QString autoscriptFile = getFreeScriptName(KUrl(), "auto");
+ QFile file(autoscriptFile);
+ if (!file.open(QIODevice::WriteOnly | QIODevice::Text)) {
+ kWarning() << "////// ERROR writing to file: " << autoscriptFile;
+ KMessageBox::error(0, i18n("Cannot write to file %1", autoscriptFile));
+ return false;
+ }
+
+ QTextStream outStream(&file);
+ outStream << "#! /bin/sh" << "\n" << "\n";
+ RenderJobItem *item = static_cast<RenderJobItem*> (m_view.running_jobs->topLevelItem(0));
+ while (item) {
+ if (item->status() == WAITINGJOB) {
+ if (item->type() == DirectRenderType) {
+ // Add render process for item
+ const QString params = item->data(1, ParametersRole).toStringList().join(" ");
+ outStream << m_renderer << " " << params << "\n";
+ } else if (item->type() == ScriptRenderType){
+ // Script item
+ outStream << item->data(1, ParametersRole).toString() << "\n";
+ }
+ }
+ item = static_cast<RenderJobItem*>(m_view.running_jobs->itemBelow(item));
+ }
+ // erase itself when rendering is finished
+ outStream << "rm " << autoscriptFile << "\n" << "\n";
+ if (file.error() != QFile::NoError) {
+ KMessageBox::error(0, i18n("Cannot write to file %1", autoscriptFile));
+ file.close();
+ m_blockProcessing = false;
+ return false;
+ }
+ file.close();
+ QFile::setPermissions(autoscriptFile, file.permissions() | QFile::ExeUser);
+ QProcess::startDetached(autoscriptFile, QStringList());
+ return true;
+}
+
+QString RenderWidget::getFreeScriptName(const KUrl &projectName, const QString &prefix)
+{
+ int ix = 0;
+ QString scriptsFolder = m_projectFolder + "scripts/";
+ KStandardDirs::makeDir(scriptsFolder);
+ QString path;
+ QString fileName;
+ if (projectName.isEmpty()) fileName = i18n("script");
+ else fileName = projectName.fileName().section('.', 0, -2) + "_";
+ while (path.isEmpty() || QFile::exists(path)) {
+ ++ix;
+ path = scriptsFolder + prefix + fileName + QString::number(ix).rightJustified(3, '0', false) + ".sh";
+ }
+ return path;
+}
+
+void RenderWidget::slotPlayRendering(QTreeWidgetItem *item, int)
+{
+ RenderJobItem *renderItem = static_cast<RenderJobItem*> (item);
+ if (KdenliveSettings::defaultplayerapp().isEmpty() || renderItem->status() != FINISHEDJOB) return;
+ KUrl::List urls;
+ urls.append(KUrl(item->text(1)));
+ KRun::run(KdenliveSettings::defaultplayerapp(), urls, this);
+}
+
+void RenderWidget::missingClips(bool hasMissing)
+{
+ if (hasMissing) {
+ m_view.errorLabel->setText(i18n("Check missing clips"));
+ m_view.errorBox->setHidden(false);
+ } else m_view.errorBox->setHidden(true);