]> git.sesse.net Git - kdenlive/blobdiff - src/clipstabilize.cpp
const'ref
[kdenlive] / src / clipstabilize.cpp
index 6e0122ced3a761d613b9d38f89ec0e634b878e92..ba6590156e0efd6e3b32b0dfd1f14c2d4481325b 100644 (file)
 #include <QSlider>
 #include <KFileDialog>
 
-ClipStabilize::ClipStabilize(KUrl::List urls, const QString &params, Mlt::Filter* filter,QWidget * parent) :
-        QDialog(parent), m_profile(NULL),m_consumer(NULL),m_playlist(NULL),m_urls(urls),m_duration(0),m_filter(filter),vbox(NULL)
+ClipStabilize::ClipStabilize(const QStringList &urls, const QString &filterName,QWidget * parent) :
+        QDialog(parent), 
+        m_filtername(filterName),
+        m_urls(urls),
+        vbox(NULL)
 {
     setFont(KGlobalSettings::toolBarFont());
     setupUi(this);
-    if (filter) setAttribute(Qt::WA_DeleteOnClose);
-    log_text->setHidden(true);
     setWindowTitle(i18n("Stabilize Clip"));
-    auto_add->setText(i18np("Add clip to project", "Add clips to project", m_urls.count()));
-    m_profile = new Mlt::Profile(KdenliveSettings::current_profile().toUtf8().constData());
-    filtername = params;
-
+    auto_add->setText(i18np("Add clip to project", "Add clips to project", urls.count()));
+    auto_add->setChecked(KdenliveSettings::add_new_clip());
 
     QPalette p = palette();
     KColorScheme scheme(p.currentColorGroup(), KColorScheme::View, KSharedConfig::openConfig(KdenliveSettings::colortheme()));
@@ -63,63 +62,47 @@ ClipStabilize::ClipStabilize(KUrl::List urls, const QString &params, Mlt::Filter
     setStyleSheet(stylesheet);
 
     if (m_urls.count() == 1) {
-        QString fileName = m_urls.at(0).path(); //.section('.', 0, -1);
-        QString newFile = fileName.append(".mlt");
+        QString newFile = m_urls.first();
+        newFile.append(".mlt");
         KUrl dest(newFile);
-        source_url->setUrl(m_urls.at(0));
         dest_url->setMode(KFile::File);
-        dest_url->setUrl(dest);
+        dest_url->setUrl(KUrl(newFile));
         dest_url->fileDialog()->setOperationMode(KFileDialog::Saving);
-        urls_list->setHidden(true);
-        connect(source_url, SIGNAL(textChanged(const QString &)), this, SLOT(slotUpdateParams()));
     } else {
-        label_source->setHidden(true);
-        source_url->setHidden(true);
         label_dest->setText(i18n("Destination folder"));
         dest_url->setMode(KFile::Directory);
-        dest_url->setUrl(KUrl(m_urls.at(0).directory()));
+        dest_url->setUrl(KUrl(KUrl(m_urls.first()).directory()));
         dest_url->fileDialog()->setOperationMode(KFileDialog::Saving);
-        for (int i = 0; i < m_urls.count(); i++)
-            urls_list->addItem(m_urls.at(i).path());
     }
-    if (!params.isEmpty()) {
-        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);*/
-    } 
 
-    if (filtername=="videostab"){
+    if (m_filtername=="videostab"){
         QStringList ls;
-        ls << "shutterangle,type,int,value,0,min,0,max,100,tooltip,Angle that Images could be maximum rotated";
+        ls << "shutterangle,type,int,value,0,min,0,max,180,tooltip,Angle that Images could be maximum rotated";
         fillParameters(ls);
-    }else if (filtername=="videostab2"){
+    }else if (m_filtername=="videostab2"){
+       // Some default params have to be set:
+       m_fixedParams << "algo=1" << "relative=1";
         QStringList ls;
-        ls << "accuracy,type,int,value,4,min,1,max,10,tooltip,Accuracy of Shakiness detection";
+        ls << "accuracy,type,int,value,8,min,1,max,10,tooltip,Accuracy of Shakiness detection";
         ls << "shakiness,type,int,value,4,min,1,max,10,tooltip,How shaky is the Video";
         ls << "stepsize,type,int,value,6,min,0,max,100,tooltip,Stepsize of Detection process minimum around";
-        ls << "algo,type,bool,value,1,min,0,max,1,tooltip,0 = Bruteforce 1 = small measurement fields";
+        //ls << "algo,type,bool,value,1,min,0,max,1,tooltip,0 = Bruteforce 1 = small measurement fields";
         ls << "mincontrast,type,double,value,0.3,min,0,max,1,factor,1,decimals,2,tooltip,Below this Contrast Field is discarded";
-        ls << "show,type,int,value,0,min,0,max,2,tooltip,0 = draw nothing. 1 or 2 show fields and transforms";
+        //ls << "show,type,int,value,0,min,0,max,2,tooltip,0 = draw nothing. 1 or 2 show fields and transforms";
         ls << "smoothing,type,int,value,10,min,0,max,100,tooltip,number of frames for lowpass filtering";
         ls << "maxshift,type,int,value,-1,min,-1,max,1000,tooltip,max number of pixels to shift";
-        ls << "maxangle,type,int,value,-1,min,-1,max,1000,tooltip,max anglen to rotate (in rad)";
+        ls << "maxangle,type,double,value,-1,min,-1,max,3.14,decimals,2,tooltip,max angle to rotate (in rad)";
         ls << "crop,type,bool,value,0,min,0,max,1,tooltip,0 = keep border  1 = black background";
-        ls << "invert,type,bool,value,0,min,0,max,1,tooltip,invert transform";
-        ls << "realtive,type,bool,value,1,min,0,max,1,tooltip,0 = absolute transform  1= relative";
+        //ls << "invert,type,bool,value,0,min,0,max,1,tooltip,invert transform";
+        //ls << "relative,type,bool,value,1,min,0,max,1,tooltip,0 = absolute transform  1= relative";
         ls << "zoom,type,int,value,0,min,-500,max,500,tooltip,additional zoom during transform";
         ls << "optzoom,type,bool,value,1,min,0,max,1,tooltip,use optimal zoom (calulated from transforms)";
         ls << "sharpen,type,double,value,0.8,min,0,max,1,decimals,1,tooltip,sharpen transformed image";
         fillParameters(ls);
 
     }
-    connect(button_start, SIGNAL(clicked()), this, SLOT(slotStartStabilize()));
-    connect(buttonBox,SIGNAL(rejected()), this, SLOT(slotAbortStabilize()));
 
-    m_timer=new QTimer(this);
-    connect(m_timer, SIGNAL(timeout()), this, SLOT(slotShowStabilizeInfo()));
+    connect(buttonBox->button(QDialogButtonBox::Ok),SIGNAL(clicked()), this, SLOT(slotValidate()));
 
     vbox=new QVBoxLayout(optionsbox);
     QHashIterator<QString,QHash<QString,QString> > hi(m_ui_params);
@@ -152,19 +135,50 @@ ClipStabilize::~ClipStabilize()
     /*if (m_stabilizeProcess.state() != QProcess::NotRunning) {
         m_stabilizeProcess.close();
     }*/
-    if (m_stabilizeRun.isRunning()){
-        if (m_consumer){
-            m_consumer->stop();
-        }
-        m_stabilizeRun.waitForFinished();
+    KdenliveSettings::setAdd_new_clip(auto_add->isChecked());
+}
+
+QStringList ClipStabilize::params()
+{
+    //we must return a stringlist with:
+    // producerparams << filtername << filterparams << consumer << consumerparams
+    QStringList params;
+    // producer params
+    params << QString();
+    // filter
+    params << m_filtername;
+    QStringList filterparamsList = m_fixedParams;
+    QHashIterator <QString,QHash<QString,QString> > it(m_ui_params);
+    while (it.hasNext()){
+        it.next();
+        filterparamsList << it.key() + '=' + it.value().value("value");
     }
-    if (m_profile) free (m_profile);
-    if (m_consumer) free (m_consumer);
-    if (m_playlist) free (m_playlist);
+    params << filterparamsList.join(" ");
+    
+    // consumer
+    params << "xml";
+    // consumer params
+    QString title = i18n("Stabilised");
+    params << QString("all=1 title=\"%1\"").arg(title);
+    return params;
+}
+
+QString ClipStabilize::destination() const
+{
+    if (m_urls.count() == 1)
+        return dest_url->url().path();
+    else
+        return dest_url->url().path(KUrl::AddTrailingSlash);
+}
+
+QString ClipStabilize::desc() const
+{
+    return i18n("Stabilize clip");
 }
 
 void ClipStabilize::slotStartStabilize()
 {
+    /*
     if (m_consumer && !m_consumer->is_stopped()) {
         return;
     }
@@ -213,83 +227,17 @@ void ClipStabilize::slotStartStabilize()
             button_start->setEnabled(false);
         }
     }
-
+*/
 }
 
-void ClipStabilize::slotRunStabilize()
-{
-    if (m_consumer)
-    {
-        m_consumer->run();
-    }
-}
 
-void ClipStabilize::slotAbortStabilize()
-{
-    if (m_consumer)
-    {
-        m_timer->stop();
-        m_consumer->stop();
-        slotStabilizeFinished(false);
-    }
-}
-
-void ClipStabilize::slotShowStabilizeInfo()
-{
-    if (m_playlist){
-        job_progress->setValue((int) (100.0 * m_consumer->position()/m_playlist->get_out() ));
-        if (m_consumer->position()==m_playlist->get_out()){
-            m_timer->stop();
-            slotStabilizeFinished(true);
-        }
-    }
-}
-
-void ClipStabilize::slotStabilizeFinished(bool success)
-{
-    buttonBox->button(QDialogButtonBox::Abort)->setText(i18n("Close"));
-    button_start->setEnabled(true);
-    m_duration = 0;
-    if (m_stabilizeRun.isRunning()){
-        if (m_consumer){
-            m_consumer->stop();
-        }
-        m_stabilizeRun.waitForFinished();
-    }
-
-    if (success) {
-        log_text->setHtml(log_text->toPlainText() + "<br /><b>" + i18n("Stabilize finished."));
-        if (auto_add->isChecked()) {
-            KUrl url;
-            if (urls_list->count() > 0) {
-                url = KUrl(dest_url->url().path(KUrl::AddTrailingSlash) + source_url->url().fileName()+".mlt");
-            } else url = dest_url->url();
-            emit addClip(url);
-        }
-        if (urls_list->count() > 0 && m_urls.count() > 0) {
-            slotStartStabilize();
-            return;
-        } else if (auto_close->isChecked()) accept();
-    } else {
-        log_text->setHtml(log_text->toPlainText() + "<br /><b>" + i18n("Stabilizing FAILED!"));
-    }
-    if (m_playlist){
-        free(m_playlist);
-        m_playlist=NULL;
-    }
-    if (m_consumer){
-        free(m_consumer);
-        m_consumer=NULL;
-    }
-
-}
 
 void ClipStabilize::slotUpdateParams()
 {
-    for (int i=0;i<vbox->count();i++){
+    for (int i=0;i<vbox->count();++i){
         QWidget* w=vbox->itemAt(i)->widget();
         QString name=w->objectName();
-        if (name !="" && m_ui_params.contains(name)){
+        if (!name.isEmpty() && m_ui_params.contains(name)){
             if (m_ui_params[name]["type"]=="int" || m_ui_params[name]["type"]=="double"){
                 DoubleParameterWidget *dbl=(DoubleParameterWidget*)w;
                 m_ui_params[name]["value"]=QString::number((double)(dbl->getValue()));
@@ -312,7 +260,7 @@ void ClipStabilize::fillParameters(QStringList lst)
     m_ui_params.clear();
     while (!lst.isEmpty()){
         QString vallist=lst.takeFirst();
-        QStringList cont=vallist.split(",");
+        QStringList cont=vallist.split(',');
         QString name=cont.takeFirst();
         while (!cont.isEmpty()){
             QString valname=cont.takeFirst();
@@ -326,6 +274,27 @@ void ClipStabilize::fillParameters(QStringList lst)
 
 }
 
+void ClipStabilize::slotValidate()
+{
+    if (m_urls.count() == 1) {
+       if (QFile::exists(dest_url->url().path())) {
+           if (KMessageBox::questionYesNo(this, i18n("File %1 already exists.\nDo you want to overwrite it?", dest_url->url().path() )) == KMessageBox::No) return;
+       }
+    }
+    else {
+       KUrl folder(dest_url->url());
+       QStringList existingFiles;
+       foreach(const QString &path, m_urls) {
+           KUrl dest = folder;
+           dest.addPath(KUrl(path).fileName());
+           if (QFile::exists(dest.path() + ".mlt")) existingFiles.append(dest.path() + ".mlt");
+       }
+       if (!existingFiles.isEmpty()) {
+           if (KMessageBox::warningContinueCancelList(this, i18n("The stabilize job will overwrite the following files:"), existingFiles) ==  KMessageBox::Cancel) return;
+       }
+    }
+    accept();
+}
 
 #include "clipstabilize.moc"