]> git.sesse.net Git - kdenlive/blobdiff - src/profilesdialog.cpp
Ask to change profile if first clip does not match project profile:
[kdenlive] / src / profilesdialog.cpp
index d86ee605db75aad7ac27b99adf43608269d8cb20..2f5a029d8dce5522b4cfa74be01cd9f5653ac4d3 100644 (file)
@@ -29,9 +29,9 @@
 #include <QCloseEvent>
 
 ProfilesDialog::ProfilesDialog(QWidget * parent) :
-        QDialog(parent),
-        m_profileIsModified(false),
-        m_isCustomProfile(false)
+    QDialog(parent),
+    m_profileIsModified(false),
+    m_isCustomProfile(false)
 {
     m_view.setupUi(this);
 
@@ -72,36 +72,36 @@ void ProfilesDialog::slotProfileEdited()
 
 void ProfilesDialog::fillList(const QString selectedProfile)
 {
-    // List the Mlt profiles
+    // List the Mlt profiles
     m_view.profiles_list->clear();
     QMap <QString, QString> profilesInfo = ProfilesDialog::getProfilesInfo();
     QMapIterator<QString, QString> i(profilesInfo);
-    while (i.hasNext()) {
+    while(i.hasNext()) {
         i.next();
         m_view.profiles_list->addItem(i.key(), i.value());
     }
 
-    if (!KdenliveSettings::default_profile().isEmpty()) {
-        for (int i = 0; i < m_view.profiles_list->count(); i++) {
-            if (m_view.profiles_list->itemData(i).toString() == KdenliveSettings::default_profile()) {
+    if(!KdenliveSettings::default_profile().isEmpty()) {
+        for(int i = 0; i < m_view.profiles_list->count(); i++) {
+            if(m_view.profiles_list->itemData(i).toString() == KdenliveSettings::default_profile()) {
                 m_view.profiles_list->setCurrentIndex(i);
                 break;
             }
         }
     }
     int ix = m_view.profiles_list->findText(selectedProfile);
-    if (ix != -1) m_view.profiles_list->setCurrentIndex(ix);
+    if(ix != -1) m_view.profiles_list->setCurrentIndex(ix);
     m_selectedProfileIndex = m_view.profiles_list->currentIndex();
 }
 
 void ProfilesDialog::accept()
 {
-    if (askForSave()) QDialog::accept();
+    if(askForSave()) QDialog::accept();
 }
 
 void ProfilesDialog::closeEvent(QCloseEvent *event)
 {
-    if (askForSave()) {
+    if(askForSave()) {
         event->accept();
     } else {
         event->ignore();
@@ -110,8 +110,8 @@ void ProfilesDialog::closeEvent(QCloseEvent *event)
 
 bool ProfilesDialog::askForSave()
 {
-    if (!m_profileIsModified) return true;
-    if (KMessageBox::questionYesNo(this, i18n("The custom profile was modified, do you want to save it?")) != KMessageBox::Yes) return true;
+    if(!m_profileIsModified) return true;
+    if(KMessageBox::questionYesNo(this, i18n("The custom profile was modified, do you want to save it?")) != KMessageBox::Yes) return true;
     return slotSaveProfile();
 }
 
@@ -127,17 +127,17 @@ void ProfilesDialog::slotSetDefaultProfile()
 {
     int ix = m_view.profiles_list->currentIndex();
     QString path = m_view.profiles_list->itemData(ix).toString();
-    if (!path.isEmpty()) KdenliveSettings::setDefault_profile(path);
+    if(!path.isEmpty()) KdenliveSettings::setDefault_profile(path);
 }
 
 bool ProfilesDialog::slotSaveProfile()
 {
     const QString profileDesc = m_view.description->text();
     int ix = m_view.profiles_list->findText(profileDesc);
-    if (ix != -1) {
+    if(ix != -1) {
         // this profile name already exists
         const QString path = m_view.profiles_list->itemData(ix).toString();
-        if (!path.contains('/')) {
+        if(!path.contains('/')) {
             KMessageBox::sorry(this, i18n("A profile with same name already exists in MLT's default profiles, please choose another description for your custom profile."));
             return false;
         }
@@ -147,7 +147,7 @@ bool ProfilesDialog::slotSaveProfile()
         QString customName = "profiles/customprofile";
         QString profilePath = KStandardDirs::locateLocal("appdata", customName + QString::number(i));
         kDebug() << " TYING PROFILE FILE: " << profilePath;
-        while (KIO::NetAccess::exists(KUrl(profilePath), KIO::NetAccess::SourceSide, this)) {
+        while(KIO::NetAccess::exists(KUrl(profilePath), KIO::NetAccess::SourceSide, this)) {
             i++;
             profilePath = KStandardDirs::locateLocal("appdata", customName + QString::number(i));
         }
@@ -162,13 +162,13 @@ bool ProfilesDialog::slotSaveProfile()
 void ProfilesDialog::saveProfile(const QString path)
 {
     QFile file(path);
-    if (!file.open(QIODevice::WriteOnly)) {
+    if(!file.open(QIODevice::WriteOnly)) {
         KMessageBox::sorry(this, i18n("Cannot write to file %1", path));
         return;
     }
     QTextStream out(&file);
     out << "description=" << m_view.description->text() << "\n" << "frame_rate_num=" << m_view.frame_num->value() << "\n" << "frame_rate_den=" << m_view.frame_den->value() << "\n" << "width=" << m_view.size_w->value() << "\n" << "height=" << m_view.size_h->value() << "\n" << "progressive=" << m_view.progressive->isChecked() << "\n" << "sample_aspect_num=" << m_view.aspect_num->value() << "\n" << "sample_aspect_den=" << m_view.aspect_den->value() << "\n" << "display_aspect_num=" << m_view.display_num->value() << "\n" << "display_aspect_den=" << m_view.display_den->value() << "\n";
-    if (file.error() != QFile::NoError) {
+    if(file.error() != QFile::NoError) {
         KMessageBox::error(this, i18n("Cannot write to file %1", path));
     }
     file.close();
@@ -177,7 +177,7 @@ void ProfilesDialog::saveProfile(const QString path)
 void ProfilesDialog::slotDeleteProfile()
 {
     const QString path = m_view.profiles_list->itemData(m_view.profiles_list->currentIndex()).toString();
-    if (path.contains('/')) {
+    if(path.contains('/')) {
         KIO::NetAccess::del(KUrl(path), this);
         fillList();
     } else kDebug() << "//// Cannot delete profile " << path << ", does not seem to be custom one";
@@ -193,23 +193,23 @@ MltVideoProfile ProfilesDialog::getVideoProfile(QString name)
     profilesFilter << "*";
     QString path;
     bool isCustom = false;
-    if (name.contains('/')) isCustom = true;
+    if(name.contains('/')) isCustom = true;
 
-    if (!isCustom) {
-        // List the Mlt profiles
+    if(!isCustom) {
+        // List the Mlt profiles
         profilesFiles = QDir(KdenliveSettings::mltpath()).entryList(profilesFilter, QDir::Files);
-        if (profilesFiles.contains(name)) path = KdenliveSettings::mltpath() + name;
+        if(profilesFiles.contains(name)) path = KdenliveSettings::mltpath() + name;
     }
-    if (isCustom || path.isEmpty()) {
+    if(isCustom || path.isEmpty()) {
         path = name;
     }
 
-    if (path.isEmpty() || !QFile::exists(path)) {
-        if (name == "dv_pal") {
-            kDebug() << "!!! WARNING, COULD NOT FIND DEFAULT MLT PROFILE";
+    if(path.isEmpty() || !QFile::exists(path)) {
+        if(name == "dv_pal") {
+            kDebug() << "!!! WARNING, COULD NOT FIND DEFAULT MLT PROFILE";
             return result;
         }
-        if (name == KdenliveSettings::default_profile()) KdenliveSettings::setDefault_profile("dv_pal");
+        if(name == KdenliveSettings::default_profile()) KdenliveSettings::setDefault_profile("dv_pal");
         kDebug() << "// WARNING, COULD NOT FIND PROFILE " << name;
         return result;
     }
@@ -228,6 +228,20 @@ MltVideoProfile ProfilesDialog::getVideoProfile(QString name)
     return result;
 }
 
+// static
+double ProfilesDialog::getStringEval(const MltVideoProfile &profile, QString eval)
+{
+    double result;
+    eval.replace("%width", QString::number(profile.width));
+    eval.replace("%height", QString::number(profile.height));
+    if(eval.contains('/')) result = (double) eval.section('/', 0, 0).toInt() / eval.section('/', 1, 1).toInt();
+    else if(eval.contains('*')) result = (double) eval.section('*', 0, 0).toInt() * eval.section('*', 1, 1).toInt();
+    else if(eval.contains('+')) result = (double) eval.section('+', 0, 0).toInt() + eval.section('+', 1, 1).toInt();
+    else if(eval.contains('-')) result = (double) eval.section('-', 0, 0).toInt() - eval.section('-', 1, 1).toInt();
+    else result = eval.toDouble();
+    return result;
+}
+
 
 // static
 bool ProfilesDialog::existingProfileDescription(const QString &desc)
@@ -235,20 +249,20 @@ bool ProfilesDialog::existingProfileDescription(const QString &desc)
     QStringList profilesFilter;
     profilesFilter << "*";
 
-    // List the Mlt profiles
+    // List the Mlt profiles
     QStringList profilesFiles = QDir(KdenliveSettings::mltpath()).entryList(profilesFilter, QDir::Files);
-    for (int i = 0; i < profilesFiles.size(); ++i) {
+    for(int i = 0; i < profilesFiles.size(); ++i) {
         KConfig confFile(KdenliveSettings::mltpath() + profilesFiles.at(i), KConfig::SimpleConfig);
-        if (desc == confFile.entryMap().value("description")) return true;
+        if(desc == confFile.entryMap().value("description")) return true;
     }
 
     // List custom profiles
     QStringList customProfiles = KGlobal::dirs()->findDirs("appdata", "profiles");
-    for (int i = 0; i < customProfiles.size(); ++i) {
+    for(int i = 0; i < customProfiles.size(); ++i) {
         profilesFiles = QDir(customProfiles.at(i)).entryList(profilesFilter, QDir::Files);
-        for (int j = 0; j < profilesFiles.size(); ++j) {
+        for(int j = 0; j < profilesFiles.size(); ++j) {
             KConfig confFile(customProfiles.at(i) + profilesFiles.at(j), KConfig::SimpleConfig);
-            if (desc == confFile.entryMap().value("description")) return true;
+            if(desc == confFile.entryMap().value("description")) return true;
         }
     }
     return false;
@@ -261,37 +275,37 @@ QString ProfilesDialog::existingProfile(MltVideoProfile profile)
     QStringList profilesFilter;
     profilesFilter << "*";
 
-    // Check the Mlt profiles
+    // Check the Mlt profiles
     QStringList profilesFiles = QDir(KdenliveSettings::mltpath()).entryList(profilesFilter, QDir::Files);
-    for (int i = 0; i < profilesFiles.size(); ++i) {
+    for(int i = 0; i < profilesFiles.size(); ++i) {
         KConfig confFile(KdenliveSettings::mltpath() + profilesFiles.at(i), KConfig::SimpleConfig);
-        if (profile.display_aspect_den != confFile.entryMap().value("display_aspect_den").toInt()) continue;
-        if (profile.display_aspect_num != confFile.entryMap().value("display_aspect_num").toInt()) continue;
-        if (profile.sample_aspect_den != confFile.entryMap().value("sample_aspect_den").toInt()) continue;
-        if (profile.sample_aspect_num != confFile.entryMap().value("sample_aspect_num").toInt()) continue;
-        if (profile.width != confFile.entryMap().value("width").toInt()) continue;
-        if (profile.height != confFile.entryMap().value("height").toInt()) continue;
-        if (profile.frame_rate_den != confFile.entryMap().value("frame_rate_den").toInt()) continue;
-        if (profile.frame_rate_num != confFile.entryMap().value("frame_rate_num").toInt()) continue;
-        if (profile.progressive != confFile.entryMap().value("progressive").toInt()) continue;
+        if(profile.display_aspect_den != confFile.entryMap().value("display_aspect_den").toInt()) continue;
+        if(profile.display_aspect_num != confFile.entryMap().value("display_aspect_num").toInt()) continue;
+        if(profile.sample_aspect_den != confFile.entryMap().value("sample_aspect_den").toInt()) continue;
+        if(profile.sample_aspect_num != confFile.entryMap().value("sample_aspect_num").toInt()) continue;
+        if(profile.width != confFile.entryMap().value("width").toInt()) continue;
+        if(profile.height != confFile.entryMap().value("height").toInt()) continue;
+        if(profile.frame_rate_den != confFile.entryMap().value("frame_rate_den").toInt()) continue;
+        if(profile.frame_rate_num != confFile.entryMap().value("frame_rate_num").toInt()) continue;
+        if(profile.progressive != confFile.entryMap().value("progressive").toInt()) continue;
         return profilesFiles.at(i);
     }
 
     // Check custom profiles
     QStringList customProfiles = KGlobal::dirs()->findDirs("appdata", "profiles");
-    for (int i = 0; i < customProfiles.size(); ++i) {
+    for(int i = 0; i < customProfiles.size(); ++i) {
         profilesFiles = QDir(customProfiles.at(i)).entryList(profilesFilter, QDir::Files);
-        for (int j = 0; j < profilesFiles.size(); ++j) {
+        for(int j = 0; j < profilesFiles.size(); ++j) {
             KConfig confFile(customProfiles.at(i) + profilesFiles.at(j), KConfig::SimpleConfig);
-            if (profile.display_aspect_den != confFile.entryMap().value("display_aspect_den").toInt()) continue;
-            if (profile.display_aspect_num != confFile.entryMap().value("display_aspect_num").toInt()) continue;
-            if (profile.sample_aspect_den != confFile.entryMap().value("sample_aspect_den").toInt()) continue;
-            if (profile.sample_aspect_num != confFile.entryMap().value("sample_aspect_num").toInt()) continue;
-            if (profile.width != confFile.entryMap().value("width").toInt()) continue;
-            if (profile.height != confFile.entryMap().value("height").toInt()) continue;
-            if (profile.frame_rate_den != confFile.entryMap().value("frame_rate_den").toInt()) continue;
-            if (profile.frame_rate_num != confFile.entryMap().value("frame_rate_num").toInt()) continue;
-            if (profile.progressive != confFile.entryMap().value("progressive").toInt()) continue;
+            if(profile.display_aspect_den != confFile.entryMap().value("display_aspect_den").toInt()) continue;
+            if(profile.display_aspect_num != confFile.entryMap().value("display_aspect_num").toInt()) continue;
+            if(profile.sample_aspect_den != confFile.entryMap().value("sample_aspect_den").toInt()) continue;
+            if(profile.sample_aspect_num != confFile.entryMap().value("sample_aspect_num").toInt()) continue;
+            if(profile.width != confFile.entryMap().value("width").toInt()) continue;
+            if(profile.height != confFile.entryMap().value("height").toInt()) continue;
+            if(profile.frame_rate_den != confFile.entryMap().value("frame_rate_den").toInt()) continue;
+            if(profile.frame_rate_num != confFile.entryMap().value("frame_rate_num").toInt()) continue;
+            if(profile.progressive != confFile.entryMap().value("progressive").toInt()) continue;
             return customProfiles.at(i) + profilesFiles.at(j);
         }
     }
@@ -305,22 +319,22 @@ QMap <QString, QString> ProfilesDialog::getProfilesInfo()
     QStringList profilesFilter;
     profilesFilter << "*";
 
-    // List the Mlt profiles
+    // List the Mlt profiles
     QStringList profilesFiles = QDir(KdenliveSettings::mltpath()).entryList(profilesFilter, QDir::Files);
-    for (int i = 0; i < profilesFiles.size(); ++i) {
+    for(int i = 0; i < profilesFiles.size(); ++i) {
         KConfig confFile(KdenliveSettings::mltpath() + profilesFiles.at(i), KConfig::SimpleConfig);
         QString desc = confFile.entryMap().value("description");
-        if (!desc.isEmpty()) result.insert(desc, profilesFiles.at(i));
+        if(!desc.isEmpty()) result.insert(desc, profilesFiles.at(i));
     }
 
     // List custom profiles
     QStringList customProfiles = KGlobal::dirs()->findDirs("appdata", "profiles");
-    for (int i = 0; i < customProfiles.size(); ++i) {
+    for(int i = 0; i < customProfiles.size(); ++i) {
         profilesFiles = QDir(customProfiles.at(i)).entryList(profilesFilter, QDir::Files);
-        for (int j = 0; j < profilesFiles.size(); ++j) {
+        for(int j = 0; j < profilesFiles.size(); ++j) {
             KConfig confFile(customProfiles.at(i) + profilesFiles.at(j), KConfig::SimpleConfig);
             QString desc = confFile.entryMap().value("description");
-            if (!desc.isEmpty()) result.insert(desc, customProfiles.at(i) + profilesFiles.at(j));
+            if(!desc.isEmpty()) result.insert(desc, customProfiles.at(i) + profilesFiles.at(j));
         }
     }
     return result;
@@ -334,7 +348,7 @@ QMap< QString, QString > ProfilesDialog::getSettingsFromFile(const QString path)
     QStringList profilesFilter;
     profilesFilter << "*";
 
-    if (!path.contains('/')) {
+    if(!path.contains('/')) {
         // This is an MLT profile
         KConfig confFile(KdenliveSettings::mltpath() + path, KConfig::SimpleConfig);
         return confFile.entryMap();
@@ -353,12 +367,12 @@ QMap< QString, QString > ProfilesDialog::getSettingsForProfile(const QString pro
     QStringList profilesFilter;
     profilesFilter << "*";
 
-    // List the Mlt profiles
+    // List the Mlt profiles
     profilesFiles = QDir(KdenliveSettings::mltpath()).entryList(profilesFilter, QDir::Files);
-    for (int i = 0; i < profilesFiles.size(); ++i) {
+    for(int i = 0; i < profilesFiles.size(); ++i) {
         KConfig confFile(KdenliveSettings::mltpath() + profilesFiles.at(i), KConfig::SimpleConfig);
         QMap< QString, QString > values = confFile.entryMap();
-        if (values.value("description") == profileName) {
+        if(values.value("description") == profileName) {
             values.insert("path", profilesFiles.at(i));
             return values;
         }
@@ -366,13 +380,13 @@ QMap< QString, QString > ProfilesDialog::getSettingsForProfile(const QString pro
 
     // List custom profiles
     QStringList customProfiles = KGlobal::dirs()->findDirs("appdata", "profiles");
-    for (int i = 0; i < customProfiles.size(); ++i) {
+    for(int i = 0; i < customProfiles.size(); ++i) {
         QStringList profiles = QDir(customProfiles.at(i)).entryList(profilesFilter, QDir::Files);
-        for (int i = 0; i < profiles.size(); ++i) {
-            KConfig confFile(customProfiles.at(i) + profiles.at(i), KConfig::SimpleConfig);
+        for(int j = 0; j < profiles.size(); ++j) {
+            KConfig confFile(customProfiles.at(i) + profiles.at(j), KConfig::SimpleConfig);
             QMap< QString, QString > values = confFile.entryMap();
-            if (values.value("description") == profileName) {
-                values.insert("path", customProfiles.at(i) + profiles.at(i));
+            if(values.value("description") == profileName) {
+                values.insert("path", customProfiles.at(i) + profiles.at(j));
                 return values;
             }
         }
@@ -380,6 +394,42 @@ QMap< QString, QString > ProfilesDialog::getSettingsForProfile(const QString pro
     return QMap< QString, QString >();
 }
 
+// static
+QString ProfilesDialog::getPathFromProperties(int width, int height, double fps, double par, double dar)
+{
+    QStringList profilesNames;
+    QStringList profilesFiles;
+    QStringList profilesFilter;
+    profilesFilter << "*";
+    // List the Mlt profiles
+    profilesFiles = QDir(KdenliveSettings::mltpath()).entryList(profilesFilter, QDir::Files);
+    for(int i = 0; i < profilesFiles.size(); ++i) {
+        KConfig confFile(KdenliveSettings::mltpath() + profilesFiles.at(i), KConfig::SimpleConfig);
+        QMap< QString, QString > values = confFile.entryMap();
+        if(values.value("width").toInt() == width && values.value("height").toInt() == height) {
+            double profile_fps = values.value("frame_rate_num").toDouble() / values.value("frame_rate_den").toDouble();
+            if(qAbs(profile_fps - fps) < 0.5)
+                return profilesFiles.at(i);
+        }
+    }
+
+    // List custom profiles
+    QStringList customProfiles = KGlobal::dirs()->findDirs("appdata", "profiles");
+    for(int i = 0; i < customProfiles.size(); ++i) {
+        QStringList profiles = QDir(customProfiles.at(i)).entryList(profilesFilter, QDir::Files);
+        for(int j = 0; j < profiles.size(); ++i) {
+            KConfig confFile(customProfiles.at(i) + profiles.at(j), KConfig::SimpleConfig);
+            QMap< QString, QString > values = confFile.entryMap();
+            if(values.value("width").toInt() == width && values.value("height").toInt() == height) {
+                double profile_fps = values.value("frame_rate_num").toDouble() / values.value("frame_rate_den").toDouble();
+                if(qAbs(profile_fps - fps) < 0.5)
+                    return customProfiles.at(i) + profiles.at(j);
+            }
+        }
+    }
+    return QString();
+}
+
 // static
 QString ProfilesDialog::getPathFromDescription(const QString profileDesc)
 {
@@ -388,22 +438,22 @@ QString ProfilesDialog::getPathFromDescription(const QString profileDesc)
     QStringList profilesFilter;
     profilesFilter << "*";
 
-    // List the Mlt profiles
+    // List the Mlt profiles
     profilesFiles = QDir(KdenliveSettings::mltpath()).entryList(profilesFilter, QDir::Files);
-    for (int i = 0; i < profilesFiles.size(); ++i) {
+    for(int i = 0; i < profilesFiles.size(); ++i) {
         KConfig confFile(KdenliveSettings::mltpath() + profilesFiles.at(i), KConfig::SimpleConfig);
         QMap< QString, QString > values = confFile.entryMap();
-        if (values.value("description") == profileDesc) return profilesFiles.at(i);
+        if(values.value("description") == profileDesc) return profilesFiles.at(i);
     }
 
     // List custom profiles
     QStringList customProfiles = KGlobal::dirs()->findDirs("appdata", "profiles");
-    for (int i = 0; i < customProfiles.size(); ++i) {
+    for(int i = 0; i < customProfiles.size(); ++i) {
         QStringList profiles = QDir(customProfiles.at(i)).entryList(profilesFilter, QDir::Files);
-        for (int i = 0; i < profiles.size(); ++i) {
-            KConfig confFile(customProfiles.at(i) + profiles.at(i), KConfig::SimpleConfig);
+        for(int j = 0; j < profiles.size(); ++j) {
+            KConfig confFile(customProfiles.at(i) + profiles.at(j), KConfig::SimpleConfig);
             QMap< QString, QString > values = confFile.entryMap();
-            if (values.value("description") == profileDesc) return customProfiles.at(i) + profiles.at(i);
+            if(values.value("description") == profileDesc) return customProfiles.at(i) + profiles.at(j);
         }
     }
     return QString();
@@ -416,18 +466,18 @@ void ProfilesDialog::saveProfile(MltVideoProfile &profile)
     QString customName = "profiles/customprofile";
     QString profilePath = KStandardDirs::locateLocal("appdata", customName + QString::number(i));
     kDebug() << " TYING PROFILE FILE: " << profilePath;
-    while (KIO::NetAccess::exists(KUrl(profilePath), KIO::NetAccess::SourceSide, 0)) {
+    while(KIO::NetAccess::exists(KUrl(profilePath), KIO::NetAccess::SourceSide, 0)) {
         i++;
         profilePath = KStandardDirs::locateLocal("appdata", customName + QString::number(i));
     }
     QFile file(profilePath);
-    if (!file.open(QIODevice::WriteOnly)) {
+    if(!file.open(QIODevice::WriteOnly)) {
         KMessageBox::sorry(0, i18n("Cannot write to file %1", profilePath));
         return;
     }
     QTextStream out(&file);
     out << "description=" << profile.description << "\n" << "frame_rate_num=" << profile.frame_rate_num << "\n" << "frame_rate_den=" << profile.frame_rate_den << "\n" << "width=" << profile.width << "\n" << "height=" << profile.height << "\n" << "progressive=" << profile.progressive << "\n" << "sample_aspect_num=" << profile.sample_aspect_num << "\n" << "sample_aspect_den=" << profile.sample_aspect_den << "\n" << "display_aspect_num=" << profile.display_aspect_num << "\n" << "display_aspect_den=" << profile.display_aspect_den << "\n";
-    if (file.error() != QFile::NoError) {
+    if(file.error() != QFile::NoError) {
         KMessageBox::error(0, i18n("Cannot write to file %1", profilePath));
     }
     file.close();
@@ -437,7 +487,7 @@ void ProfilesDialog::saveProfile(MltVideoProfile &profile)
 
 void ProfilesDialog::slotUpdateDisplay()
 {
-    if (askForSave() == false) {
+    if(askForSave() == false) {
         m_view.profiles_list->blockSignals(true);
         m_view.profiles_list->setCurrentIndex(m_selectedProfileIndex);
         m_view.profiles_list->blockSignals(false);
@@ -447,6 +497,7 @@ void ProfilesDialog::slotUpdateDisplay()
     m_selectedProfileIndex = m_view.profiles_list->currentIndex();
     QString currentProfile = m_view.profiles_list->itemData(m_view.profiles_list->currentIndex()).toString();
     m_isCustomProfile = currentProfile.contains('/');
+    m_view.button_create->setEnabled(true);
     m_view.button_delete->setEnabled(m_isCustomProfile);
     m_view.properties->setEnabled(m_isCustomProfile);
     m_view.button_save->setEnabled(m_isCustomProfile);
@@ -461,6 +512,11 @@ void ProfilesDialog::slotUpdateDisplay()
     m_view.frame_num->setValue(values.value("frame_rate_num").toInt());
     m_view.frame_den->setValue(values.value("frame_rate_den").toInt());
     m_view.progressive->setChecked(values.value("progressive").toInt());
+    if(values.value("progressive").toInt()) {
+        m_view.fields->setText(QString::number((double)values.value("frame_rate_num").toInt() / values.value("frame_rate_den").toInt(), 'f', 2));
+    } else {
+        m_view.fields->setText(QString::number((double)2 * values.value("frame_rate_num").toInt() / values.value("frame_rate_den").toInt(), 'f', 2));
+    }
     m_profileIsModified = false;
 }