X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;ds=sidebyside;f=src%2Fmainwindow.cpp;h=7147d3b8789430e3207c32018f683d3184e331b6;hb=d27942f69d13850d00f249a219107f6983473604;hp=98937a2ad4622a25a5083f364710712058502d6f;hpb=30576fe47b20435915a9782e4e017b6f904e7414;p=kdenlive diff --git a/src/mainwindow.cpp b/src/mainwindow.cpp index 98937a2a..7147d3b8 100644 --- a/src/mainwindow.cpp +++ b/src/mainwindow.cpp @@ -57,6 +57,7 @@ #include "mainwindow.h" +#include "mainwindowadaptor.h" #include "kdenlivesettings.h" #include "kdenlivesettingsdialog.h" #include "initeffects.h" @@ -113,6 +114,12 @@ MainWindow::MainWindow(const QString &MltPath, const KUrl & Url, QWidget *parent m_jogProcess(NULL), #endif /* NO_JOGSHUTTLE */ m_findActivated(false), m_initialized(false) { + + // Create DBus interface + new MainWindowAdaptor(this); + QDBusConnection dbus = QDBusConnection::sessionBus(); + dbus.registerObject("/MainWindow", this); + setlocale(LC_NUMERIC, "POSIX"); setFont(KGlobalSettings::toolBarFont()); parseProfiles(MltPath); @@ -562,9 +569,9 @@ void MainWindow::slotConnectMonitors() { m_projectList->setRenderer(m_projectMonitor->render); connect(m_projectList, SIGNAL(receivedClipDuration(const QString &, int)), this, SLOT(slotSetClipDuration(const QString &, int))); connect(m_projectList, SIGNAL(showClipProperties(DocClipBase *)), this, SLOT(slotShowClipProperties(DocClipBase *))); - connect(m_projectList, SIGNAL(getFileProperties(const QDomElement &, const QString &)), m_projectMonitor->render, SLOT(getFileProperties(const QDomElement &, const QString &))); - connect(m_projectMonitor->render, SIGNAL(replyGetImage(const QString &, int, const QPixmap &, int, int)), m_projectList, SLOT(slotReplyGetImage(const QString &, int, const QPixmap &, int, int))); - connect(m_projectMonitor->render, SIGNAL(replyGetFileProperties(const QString &, Mlt::Producer*, const QMap < QString, QString > &, const QMap < QString, QString > &)), m_projectList, SLOT(slotReplyGetFileProperties(const QString &, Mlt::Producer*, const QMap < QString, QString > &, const QMap < QString, QString > &))); + connect(m_projectList, SIGNAL(getFileProperties(const QDomElement &, const QString &, bool)), m_projectMonitor->render, SLOT(getFileProperties(const QDomElement &, const QString &, bool))); + connect(m_projectMonitor->render, SIGNAL(replyGetImage(const QString &, const QPixmap &)), m_projectList, SLOT(slotReplyGetImage(const QString &, const QPixmap &))); + connect(m_projectMonitor->render, SIGNAL(replyGetFileProperties(const QString &, Mlt::Producer*, const QMap < QString, QString > &, const QMap < QString, QString > &, bool)), m_projectList, SLOT(slotReplyGetFileProperties(const QString &, Mlt::Producer*, const QMap < QString, QString > &, const QMap < QString, QString > &, bool))); connect(m_projectMonitor->render, SIGNAL(removeInvalidClip(const QString &)), m_projectList, SLOT(slotRemoveInvalidClip(const QString &))); @@ -765,11 +772,15 @@ void MainWindow::setupActions() { m_projectSearchNext->setShortcut(Qt::Key_F3); m_projectSearchNext->setEnabled(false); - KAction* profilesAction = new KAction(KIcon("document-new"), i18n("Manage Profiles"), this); + KAction* profilesAction = new KAction(KIcon("document-new"), i18n("Manage Project Profiles"), this); collection->addAction("manage_profiles", profilesAction); connect(profilesAction, SIGNAL(triggered(bool)), this, SLOT(slotEditProfiles())); - KAction* fileGHNS = KNS::standardAction(i18n("Download New Lumas..."), this, SLOT(slotGetNewStuff()), actionCollection(), "get_new_stuff"); + KNS::standardAction(i18n("Download New Lumas..."), this, SLOT(slotGetNewLumaStuff()), actionCollection(), "get_new_lumas"); + + KNS::standardAction(i18n("Download New Render Profiles..."), this, SLOT(slotGetNewRenderStuff()), actionCollection(), "get_new_profiles"); + + KNS::standardAction(i18n("Download New Project Profiles..."), this, SLOT(slotGetNewMltProfileStuff()), actionCollection(), "get_new_mlt_profiles"); KAction* wizAction = new KAction(KIcon("configure"), i18n("Run Config Wizard"), this); collection->addAction("run_wizard", wizAction); @@ -802,6 +813,10 @@ void MainWindow::setupActions() { collection->addAction("monitor_loop_zone", m_loopZone); connect(m_loopZone, SIGNAL(triggered(bool)), m_monitorManager, SLOT(slotLoopZone())); + KAction *dvdWizard = new KAction(KIcon("media-optical"), i18n("Dvd Wizard"), this); + collection->addAction("dvd_wizard", dvdWizard); + connect(dvdWizard, SIGNAL(triggered(bool)), this, SLOT(slotDvdWizard())); + KAction *markIn = collection->addAction("mark_in"); markIn->setText(i18n("Set In Point")); markIn->setShortcut(Qt::Key_I); @@ -879,6 +894,7 @@ void MainWindow::setupActions() { KAction* editTimelineClipSpeed = new KAction(i18n("Change Clip Speed"), this); collection->addAction("change_clip_speed", editTimelineClipSpeed); + editTimelineClipSpeed->setData("change_speed"); connect(editTimelineClipSpeed, SIGNAL(triggered(bool)), this, SLOT(slotChangeClipSpeed())); KAction *stickTransition = collection->addAction("auto_transition"); @@ -947,6 +963,7 @@ void MainWindow::setupActions() { QAction *pasteEffects = new KAction(KIcon("edit-paste"), i18n("Paste Effects"), this); collection->addAction("paste_effects", pasteEffects); + pasteEffects->setData("paste_effects"); connect(pasteEffects , SIGNAL(triggered()), this, SLOT(slotPasteEffects())); m_closeAction = KStandardAction::close(this, SLOT(closeCurrentDocument()), collection); @@ -1003,12 +1020,41 @@ void MainWindow::setupActions() { collection->addAction("add_folder", addFolderButton); connect(addFolderButton , SIGNAL(triggered()), m_projectList, SLOT(slotAddFolder())); + QAction *clipProperties = new KAction(KIcon("document-edit"), i18n("Clip Properties"), this); + collection->addAction("clip_properties", clipProperties); + clipProperties->setData("clip_properties"); + connect(clipProperties , SIGNAL(triggered()), m_projectList, SLOT(slotEditClip())); + clipProperties->setEnabled(false); + + QAction *openClip = new KAction(KIcon("document-open"), i18n("Edit Clip"), this); + collection->addAction("edit_clip", openClip); + openClip->setData("edit_clip"); + connect(openClip , SIGNAL(triggered()), m_projectList, SLOT(slotOpenClip())); + openClip->setEnabled(false); + + QAction *deleteClip = new KAction(KIcon("edit-delete"), i18n("Delete Clip"), this); + collection->addAction("delete_clip", deleteClip); + deleteClip->setData("delete_clip"); + connect(deleteClip , SIGNAL(triggered()), m_projectList, SLOT(slotRemoveClip())); + deleteClip->setEnabled(false); + + QAction *reloadClip = new KAction(KIcon("view-refresh"), i18n("Reload Clip"), this); + collection->addAction("reload_clip", reloadClip); + reloadClip->setData("reload_clip"); + connect(reloadClip , SIGNAL(triggered()), m_projectList, SLOT(slotReloadClip())); + reloadClip->setEnabled(false); + QMenu *addClips = new QMenu(); addClips->addAction(addClip); addClips->addAction(addColorClip); addClips->addAction(addSlideClip); addClips->addAction(addTitleClip); addClips->addAction(addFolderButton); + + addClips->addAction(reloadClip); + addClips->addAction(clipProperties); + addClips->addAction(openClip); + addClips->addAction(deleteClip); m_projectList->setupMenu(addClips, addClip); //connect(collection, SIGNAL( clearStatusText() ), @@ -1192,7 +1238,7 @@ void MainWindow::openFile() { KMimeType::Ptr mime = KMimeType::mimeType(mimetype); if (!mime) mimetype = "*.kdenlive"; - KUrl url = KFileDialog::getOpenUrl(KUrl(), mimetype); + KUrl url = KFileDialog::getOpenUrl(KUrl("kfiledialog:///projectfolder"), mimetype); if (url.isEmpty()) return; m_fileOpenRecent->addUrl(url); openFile(url); @@ -1246,8 +1292,7 @@ void MainWindow::openFile(const KUrl &url) { } void MainWindow::doOpenFile(const KUrl &url, KAutoSaveFile *stale) { - KdenliveDoc *doc; - doc = new KdenliveDoc(url, KUrl(), m_commandStack, QString(), QPoint(3, 2), m_projectMonitor->render, this); + KdenliveDoc *doc = new KdenliveDoc(url, KUrl(), m_commandStack, QString(), QPoint(3, 2), m_projectMonitor->render, this); if (stale == NULL) { stale = new KAutoSaveFile(url, doc); doc->m_autosave = stale; @@ -1355,7 +1400,10 @@ void MainWindow::parseProfiles(const QString &mltPath) { void MainWindow::slotEditProfiles() { ProfilesDialog *w = new ProfilesDialog; - w->exec(); + if (w->exec() == QDialog::Accepted) { + KdenliveSettingsDialog* d = static_cast (KConfigDialog::exists("settings")); + if (d) d->checkProfile(); + } delete w; } @@ -1366,6 +1414,7 @@ void MainWindow::slotEditProjectSettings() { if (w->exec() == QDialog::Accepted) { QString profile = w->selectedProfile(); m_activeDocument->setProjectFolder(w->selectedFolder()); + if (m_renderWidget) m_renderWidget->setDocumentPath(w->selectedFolder().path()); if (m_activeDocument->profilePath() != profile) { // Profile was changed m_activeDocument->setProfilePath(profile); @@ -1386,8 +1435,11 @@ void MainWindow::slotEditProjectSettings() { void MainWindow::slotRenderProject() { if (!m_renderWidget) { - m_renderWidget = new RenderWidget(this); - connect(m_renderWidget, SIGNAL(doRender(const QString&, const QString&, const QStringList &, const QStringList &, bool, bool, double, double, bool)), this, SLOT(slotDoRender(const QString&, const QString&, const QStringList &, const QStringList &, bool, bool, double, double, bool))); + QString projectfolder = m_activeDocument ? m_activeDocument->projectFolder().path() : KdenliveSettings::defaultprojectfolder(); + m_renderWidget = new RenderWidget(projectfolder, this); + connect(m_renderWidget, SIGNAL(doRender(const QString&, const QString&, const QStringList &, const QStringList &, bool, bool, double, double, bool, const QString &)), this, SLOT(slotDoRender(const QString&, const QString&, const QStringList &, const QStringList &, bool, bool, double, double, bool, const QString &))); + connect(m_renderWidget, SIGNAL(abortProcess(const QString &)), this, SIGNAL(abortRenderJob(const QString &))); + connect(m_renderWidget, SIGNAL(openDvdWizard(const QString &, const QString &)), this, SLOT(slotDvdWizard(const QString &, const QString &))); if (m_activeDocument) { m_renderWidget->setProfile(m_activeDocument->mltProfile()); m_renderWidget->setGuides(m_activeDocument->guidesXml(), m_activeDocument->projectDuration()); @@ -1399,7 +1451,8 @@ void MainWindow::slotRenderProject() { m_renderWidget->show(); } -void MainWindow::slotDoRender(const QString &dest, const QString &render, const QStringList &overlay_args, const QStringList &avformat_args, bool zoneOnly, bool playAfter, double guideStart, double guideEnd, bool resizeProfile) { +void MainWindow::slotDoRender(const QString &dest, const QString &render, const QStringList &overlay_args, const QStringList &avformat_args, bool zoneOnly, bool playAfter, double guideStart, double guideEnd, bool resizeProfile, const QString &scriptExport) { + kDebug() << "// SCRIPT EXPORT: " << scriptExport; if (dest.isEmpty()) return; int in; int out; @@ -1411,18 +1464,22 @@ void MainWindow::slotDoRender(const QString &dest, const QString &render, const KTemporaryFile temp; temp.setAutoRemove(false); temp.setSuffix(".westley"); - if (temp.open()) { - + if (!scriptExport.isEmpty() || temp.open()) { if (KdenliveSettings::dropbframes()) { KdenliveSettings::setDropbframes(false); m_activeDocument->clipManager()->updatePreviewSettings(); - m_projectMonitor->saveSceneList(temp.fileName()); + if (!scriptExport.isEmpty()) m_projectMonitor->saveSceneList(scriptExport + ".westley"); + else m_projectMonitor->saveSceneList(temp.fileName()); KdenliveSettings::setDropbframes(true); m_activeDocument->clipManager()->updatePreviewSettings(); - } else m_projectMonitor->saveSceneList(temp.fileName()); + } else { + if (!scriptExport.isEmpty()) m_projectMonitor->saveSceneList(scriptExport + ".westley"); + else m_projectMonitor->saveSceneList(temp.fileName()); + } QStringList args; - args << "-erase"; + if (scriptExport.isEmpty()) args << "-erase"; + if (KdenliveSettings::usekuiserver()) args << "-kuiserver"; if (zoneOnly) args << "in=" + QString::number(in) << "out=" + QString::number(out); else if (guideStart != -1) { args << "in=" + QString::number(GenTime(guideStart).frames(m_activeDocument->fps())) << "out=" + QString::number(GenTime(guideEnd).frames(m_activeDocument->fps())); @@ -1435,6 +1492,7 @@ void MainWindow::slotDoRender(const QString &dest, const QString &render, const } if (!QFile::exists(KdenliveSettings::rendererpath())) { KMessageBox::sorry(this, i18n("Cannot find the inigo program required for rendering (part of Mlt)")); + setRenderingProgress(dest, -3); return; } args << KdenliveSettings::rendererpath() << m_activeDocument->profilePath() << render << videoPlayer; @@ -1448,17 +1506,47 @@ void MainWindow::slotDoRender(const QString &dest, const QString &render, const if (resizeProfile) { // The rendering profile is different from project profile, so use MLT's special producer_consumer - args << "consumer:" + temp.fileName(); - } else args << temp.fileName(); - args << dest << avformat_args; + if (scriptExport.isEmpty()) args << "consumer:" + temp.fileName(); + else args << "consumer:$SOURCE"; + } else { + if (scriptExport.isEmpty()) args << temp.fileName(); + else args << "$SOURCE"; + } + if (scriptExport.isEmpty()) args << dest; + else args << "$TARGET"; + args << avformat_args; QString renderer = QCoreApplication::applicationDirPath() + QString("/kdenlive_render"); if (!QFile::exists(renderer)) renderer = "kdenlive_render"; - QProcess::startDetached(renderer, args); + if (scriptExport.isEmpty()) { + QProcess::startDetached(renderer, args); + KNotification::event("RenderStarted", i18n("Rendering %1 started", dest), QPixmap(), this); + } else { + // Generate script file + QFile file(scriptExport); + if (!file.open(QIODevice::WriteOnly | QIODevice::Text)) { + m_messageLabel->setMessage(i18n("Cannot write to file %1", scriptExport), ErrorMessage); + return; + } - KNotification::event("RenderStarted", i18n("Rendering %1 started", dest), QPixmap(), this); + QTextStream out(&file); + out << "#! /bin/sh" << "\n" << "\n"; + out << "SOURCE=" << "\"" + scriptExport + ".westley\"" << "\n"; + out << "TARGET=" << "\"" + dest + "\"" << "\n"; + out << renderer << " " << args.join(" ") << "\n" << "\n"; + file.close(); + QFile::setPermissions(scriptExport, file.permissions() | QFile::ExeUser); + } } } +void MainWindow::setRenderingProgress(const QString &url, int progress) { + if (m_renderWidget) m_renderWidget->setRenderJob(url, progress); +} + +void MainWindow::setRenderingFinished(const QString &url, int status, const QString &error) { + if (m_renderWidget) m_renderWidget->setRenderStatus(url, status, error); +} + void MainWindow::slotUpdateMousePosition(int pos) { if (m_activeDocument) switch (m_timecodeFormat->currentIndex()) { @@ -1471,6 +1559,7 @@ void MainWindow::slotUpdateMousePosition(int pos) { } void MainWindow::slotUpdateDocumentState(bool modified) { + if (!m_activeDocument) return; setCaption(m_activeDocument->description(), modified); m_saveAction->setEnabled(modified); if (modified) { @@ -1496,7 +1585,6 @@ void MainWindow::connectDocument(TrackView *trackView, KdenliveDoc *doc) { //cha kDebug() << "/////////////////// CONNECTING DOC TO PROJECT VIEW ////////////////"; if (m_activeDocument) { if (m_activeDocument == doc) return; - m_activeDocument->backupMltPlaylist(); if (m_activeTimeline) { disconnect(m_projectMonitor, SIGNAL(renderPosition(int)), m_activeTimeline, SLOT(moveCursorPos(int))); disconnect(m_projectMonitor, SIGNAL(zoneUpdated(QPoint)), m_activeTimeline, SLOT(slotSetZone(QPoint))); @@ -1506,7 +1594,7 @@ void MainWindow::connectDocument(TrackView *trackView, KdenliveDoc *doc) { //cha disconnect(m_activeDocument, SIGNAL(guidesUpdated()), this, SLOT(slotGuidesUpdated())); disconnect(m_activeDocument, SIGNAL(addProjectClip(DocClipBase *, bool)), m_projectList, SLOT(slotAddClip(DocClipBase *, bool))); - disconnect(m_activeDocument, SIGNAL(addProjectFolder(const QString, const QString &, bool, bool)), m_projectList, SLOT(slotAddFolder(const QString, const QString &, bool, bool))); + disconnect(m_activeDocument, SIGNAL(resetProjectList()), m_projectList, SLOT(slotResetProjectList())); disconnect(m_activeDocument, SIGNAL(signalDeleteProjectClip(const QString &)), m_projectList, SLOT(slotDeleteClip(const QString &))); disconnect(m_activeDocument, SIGNAL(updateClipDisplay(const QString &)), m_projectList, SLOT(slotUpdateClip(const QString &))); disconnect(m_activeDocument, SIGNAL(selectLastAddedClip(const QString &)), m_projectList, SLOT(slotSelectClip(const QString &))); @@ -1530,7 +1618,6 @@ void MainWindow::connectDocument(TrackView *trackView, KdenliveDoc *doc) { //cha disconnect(effectStack, SIGNAL(refreshEffectStack(ClipItem*)), m_activeTimeline->projectView(), SLOT(slotRefreshEffects(ClipItem*))); disconnect(effectStack, SIGNAL(reloadEffects()), this, SLOT(slotReloadEffects())); disconnect(transitionConfig, SIGNAL(transitionUpdated(Transition *, QDomElement)), m_activeTimeline->projectView() , SLOT(slotTransitionUpdated(Transition *, QDomElement))); - disconnect(transitionConfig, SIGNAL(transitionTrackUpdated(Transition *, int)), m_activeTimeline->projectView() , SLOT(slotTransitionTrackUpdated(Transition *, int))); disconnect(transitionConfig, SIGNAL(seekTimeline(int)), m_activeTimeline->projectView() , SLOT(setCursorPos(int))); disconnect(m_activeTimeline->projectView(), SIGNAL(activateDocumentMonitor()), m_projectMonitor, SLOT(activateMonitor())); disconnect(m_activeTimeline, SIGNAL(zoneMoved(int, int)), this, SLOT(slotZoneMoved(int, int))); @@ -1549,6 +1636,9 @@ void MainWindow::connectDocument(TrackView *trackView, KdenliveDoc *doc) { //cha effectStack->updateProjectFormat(doc->mltProfile(), doc->timecode()); connect(m_projectList, SIGNAL(clipSelected(DocClipBase *)), m_clipMonitor, SLOT(slotSetXml(DocClipBase *))); connect(m_projectList, SIGNAL(projectModified()), doc, SLOT(setModified())); + connect(m_projectList, SIGNAL(clipNameChanged(const QString, const QString)), trackView->projectView(), SLOT(clipNameChanged(const QString, const QString))); + + connect(trackView, SIGNAL(cursorMoved()), m_projectMonitor, SLOT(activateMonitor())); connect(trackView, SIGNAL(insertTrack(int)), this, SLOT(slotInsertTrack(int))); connect(trackView, SIGNAL(deleteTrack(int)), this, SLOT(slotDeleteTrack(int))); @@ -1558,7 +1648,7 @@ void MainWindow::connectDocument(TrackView *trackView, KdenliveDoc *doc) { //cha connect(m_projectMonitor, SIGNAL(zoneUpdated(QPoint)), trackView, SLOT(slotSetZone(QPoint))); connect(m_projectMonitor, SIGNAL(durationChanged(int)), trackView, SLOT(setDuration(int))); connect(doc, SIGNAL(addProjectClip(DocClipBase *, bool)), m_projectList, SLOT(slotAddClip(DocClipBase *, bool))); - connect(doc, SIGNAL(addProjectFolder(const QString, const QString &, bool, bool)), m_projectList, SLOT(slotAddFolder(const QString, const QString &, bool, bool))); + connect(doc, SIGNAL(resetProjectList()), m_projectList, SLOT(slotResetProjectList())); connect(doc, SIGNAL(signalDeleteProjectClip(const QString &)), m_projectList, SLOT(slotDeleteClip(const QString &))); connect(doc, SIGNAL(updateClipDisplay(const QString &)), m_projectList, SLOT(slotUpdateClip(const QString &))); connect(doc, SIGNAL(selectLastAddedClip(const QString &)), m_projectList, SLOT(slotSelectClip(const QString &))); @@ -1587,7 +1677,6 @@ void MainWindow::connectDocument(TrackView *trackView, KdenliveDoc *doc) { //cha connect(effectStack, SIGNAL(changeEffectPosition(ClipItem*, int, int)), trackView->projectView(), SLOT(slotChangeEffectPosition(ClipItem*, int, int))); connect(effectStack, SIGNAL(refreshEffectStack(ClipItem*)), trackView->projectView(), SLOT(slotRefreshEffects(ClipItem*))); connect(transitionConfig, SIGNAL(transitionUpdated(Transition *, QDomElement)), trackView->projectView() , SLOT(slotTransitionUpdated(Transition *, QDomElement))); - connect(transitionConfig, SIGNAL(transitionTrackUpdated(Transition *, int)), trackView->projectView() , SLOT(slotTransitionTrackUpdated(Transition *, int))); connect(transitionConfig, SIGNAL(seekTimeline(int)), trackView->projectView() , SLOT(setCursorPos(int))); connect(effectStack, SIGNAL(reloadEffects()), this, SLOT(slotReloadEffects())); @@ -1597,7 +1686,10 @@ void MainWindow::connectDocument(TrackView *trackView, KdenliveDoc *doc) { //cha trackView->projectView()->setContextMenu(m_timelineContextMenu, m_timelineContextClipMenu, m_timelineContextTransitionMenu); m_activeTimeline = trackView; - if (m_renderWidget) m_renderWidget->setProfile(doc->mltProfile()); + if (m_renderWidget) { + m_renderWidget->setProfile(doc->mltProfile()); + m_renderWidget->setDocumentPath(doc->projectFolder().path()); + } //doc->setRenderer(m_projectMonitor->render); m_commandStack->setActiveStack(doc->commandStack()); KdenliveSettings::setProject_display_ratio(doc->dar()); @@ -1633,7 +1725,6 @@ void MainWindow::slotPreferences(int page, int option) { if (KConfigDialog::showDialog("settings")) { KdenliveSettingsDialog* d = static_cast (KConfigDialog::exists("settings")); if (page != -1) d->showPage(page, option); - d->checkProfile(); return; } @@ -1675,7 +1766,7 @@ void MainWindow::updateConfiguration() { void MainWindow::slotSwitchVideoThumbs() { KdenliveSettings::setVideothumbnails(!KdenliveSettings::videothumbnails()); if (m_activeTimeline) { - m_activeTimeline->refresh(); + m_activeTimeline->projectView()->slotUpdateAllThumbs(); } m_buttonVideoThumbs->setChecked(KdenliveSettings::videothumbnails()); } @@ -1962,7 +2053,7 @@ void MainWindow::slotShowClipProperties(DocClipBase *clip) { doc.setContent(clip->getProperty("xmldata")); dia_ui->setXml(doc); if (dia_ui->exec() == QDialog::Accepted) { - QPixmap pix = dia_ui->renderedPixmap(); + QImage pix = dia_ui->renderedPixmap(); pix.save(path); //slotAddClipFile(KUrl("/tmp/kdenlivetitle.png"), QString(), -1); //m_clipManager->slotEditTextClipFile(id, dia_ui->xml().toString()); @@ -2194,7 +2285,7 @@ void MainWindow::slotSetOutPoint() { } else m_activeTimeline->projectView()->setOutPoint(); } -void MainWindow::slotGetNewStuff() { +void MainWindow::slotGetNewLumaStuff() { //KNS::Entry::List download(); KNS::Entry::List entries = KNS::Engine::download(); int numberInstalled = 0; @@ -2212,8 +2303,59 @@ void MainWindow::slotGetNewStuff() { initEffects::refreshLumas(); } +void MainWindow::slotGetNewRenderStuff() { + //KNS::Entry::List download(); + + KNS::Engine engine(0); + if (engine.init("kdenlive_render.knsrc")) { + KNS::Entry::List entries = engine.downloadDialogModal(this); + + if (entries.size() > 0) { + foreach(KNS::Entry* entry, entries) { + // care only about installed ones + if (entry->status() == KNS::Entry::Installed) { + foreach(const QString &file, entry->installedFiles()) { + kDebug() << "// CURRENTLY INSTALLED: " << file; + } + } + } + } + if (m_renderWidget) m_renderWidget->reloadProfiles(); + } +} + +void MainWindow::slotGetNewMltProfileStuff() { + //KNS::Entry::List download(); + + KNS::Engine engine(0); + if (engine.init("kdenlive_mltprofiles.knsrc")) { + KNS::Entry::List entries = engine.downloadDialogModal(this); + + if (entries.size() > 0) { + foreach(KNS::Entry* entry, entries) { + // care only about installed ones + if (entry->status() == KNS::Entry::Installed) { + foreach(const QString &file, entry->installedFiles()) { + kDebug() << "// CURRENTLY INSTALLED: " << file; + } + } + } + + // update the list of profiles in settings dialog + KdenliveSettingsDialog* d = static_cast (KConfigDialog::exists("settings")); + if (d) d->checkProfile(); + } + } +} + void MainWindow::slotAutoTransition() { m_activeTimeline->projectView()->autoTransition(); } +void MainWindow::slotDvdWizard(const QString &url, const QString &profile) { + DvdWizard *w = new DvdWizard(url, profile, this); + w->exec(); +} + + #include "mainwindow.moc"