X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fwizard.cpp;h=4b79d072050fafb0e03279f1cfaa5e1bbe5b8736;hb=ba471399b55c3b761ccc7aa5008c25bd43cfe90b;hp=41509337d92daf024eeb5a4ffb13e38f8f9bf23d;hpb=a9295ac42ebb309a9a71f6cb0ce7fd4125c864ab;p=kdenlive diff --git a/src/wizard.cpp b/src/wizard.cpp index 41509337..4b79d072 100644 --- a/src/wizard.cpp +++ b/src/wizard.cpp @@ -20,10 +20,11 @@ #include "wizard.h" #include "kdenlivesettings.h" #include "profilesdialog.h" -#if !defined(Q_OS_FREEBSD) && !defined(Q_OS_KFREEBSD) +#include "renderer.h" +#ifdef USE_V4L #include "v4l/v4lcapture.h" #endif -#include "kdenlive-config.h" +#include "config-kdenlive.h" #include #include @@ -41,10 +42,10 @@ #include #include -// Recommanded MLT version +// Recommended MLT version const int mltVersionMajor = 0; -const int mltVersionMinor = 7; -const int mltVersionRevision = 2; +const int mltVersionMinor = 8; +const int mltVersionRevision = 0; static const char kdenlive_version[] = VERSION; @@ -135,8 +136,13 @@ Wizard::Wizard(bool upgrade, QWidget *parent) : #ifndef Q_WS_MAC QWizardPage *page6 = new QWizardPage; - page6->setTitle(i18n("Webcam")); + page6->setTitle(i18n("Capture device")); m_capture.setupUi(page6); + bool found_decklink = Render::getBlackMagicDeviceList(m_capture.decklink_devices); + KdenliveSettings::setDecklink_device_found(found_decklink); + if (found_decklink) m_capture.decklink_status->setText(i18n("Default Blackmagic Decklink card:")); + else m_capture.decklink_status->setText(i18n("No Blackmagic Decklink device found")); + connect(m_capture.decklink_devices, SIGNAL(currentIndexChanged(int)), this, SLOT(slotUpdateDecklinkDevice(int))); connect(m_capture.button_reload, SIGNAL(clicked()), this, SLOT(slotDetectWebcam())); connect(m_capture.v4l_devices, SIGNAL(currentIndexChanged(int)), this, SLOT(slotUpdateCaptureParameters())); connect(m_capture.v4l_formats, SIGNAL(currentIndexChanged(int)), this, SLOT(slotSaveCaptureFormat())); @@ -158,7 +164,7 @@ Wizard::Wizard(bool upgrade, QWidget *parent) : void Wizard::slotDetectWebcam() { -#if !defined(Q_WS_MAC) && !defined(Q_OS_FREEBSD) && !defined(Q_OS_KFREEBSD) +#ifdef USE_V4L m_capture.v4l_devices->blockSignals(true); m_capture.v4l_devices->clear(); @@ -174,7 +180,7 @@ void Wizard::slotDetectWebcam() } } if (m_capture.v4l_devices->count() > 0) { - m_capture.v4l_status->setText(i18n("Select your default video4linux device")); + m_capture.v4l_status->setText(i18n("Default video4linux device:")); // select default device bool found = false; for (int i = 0; i < m_capture.v4l_devices->count(); i++) { @@ -189,7 +195,7 @@ void Wizard::slotDetectWebcam() if (!found) m_capture.v4l_devices->setCurrentIndex(0); } else m_capture.v4l_status->setText(i18n("No device found, plug your webcam and refresh.")); m_capture.v4l_devices->blockSignals(false); -#endif +#endif /* USE_V4L */ } void Wizard::slotUpdateCaptureParameters() @@ -207,19 +213,21 @@ void Wizard::slotUpdateCaptureParameters() MltVideoProfile profileInfo = ProfilesDialog::getVideoProfile(vl4ProfilePath); m_capture.v4l_formats->addItem(i18n("Current settings (%1x%2, %3/%4fps)", profileInfo.width, profileInfo.height, profileInfo.frame_rate_num, profileInfo.frame_rate_den), QStringList() << QString("unknown") <", QString::SkipEmptyParts); + QStringList pixelformats = formats.split('>', QString::SkipEmptyParts); QString itemSize; QString pixelFormat; QStringList itemRates; for (int i = 0; i < pixelformats.count(); i++) { QString format = pixelformats.at(i).section(':', 0, 0); - QStringList sizes = pixelformats.at(i).split(":", QString::SkipEmptyParts); + QStringList sizes = pixelformats.at(i).split(':', QString::SkipEmptyParts); pixelFormat = sizes.takeFirst(); for (int j = 0; j < sizes.count(); j++) { - itemSize = sizes.at(j).section("=", 0, 0); - itemRates = sizes.at(j).section("=", 1, 1).split(",", QString::SkipEmptyParts); + itemSize = sizes.at(j).section('=', 0, 0); + itemRates = sizes.at(j).section('=', 1, 1).split(',', QString::SkipEmptyParts); for (int k = 0; k < itemRates.count(); k++) { - m_capture.v4l_formats->addItem("[" + format + "] " + itemSize + " (" + itemRates.at(k) + ")", QStringList() << format << itemSize.section('x', 0, 0) << itemSize.section('x', 1, 1) << itemRates.at(k).section('/', 0, 0) << itemRates.at(k).section('/', 1, 1)); + QString formatDescription = '[' + format + "] " + itemSize + " (" + itemRates.at(k) + ')'; + if (m_capture.v4l_formats->findText(formatDescription) == -1) + m_capture.v4l_formats->addItem(formatDescription, QStringList() << format << itemSize.section('x', 0, 0) << itemSize.section('x', 1, 1) << itemRates.at(k).section('/', 0, 0) << itemRates.at(k).section('/', 1, 1)); } } } @@ -336,16 +344,19 @@ void Wizard::checkMltComponents() for (int i = 0; i < vcodecs.count(); i++) result << QString(vcodecs.get(i)); m_mltCheck.vcodecs_list->addItems(result); + KdenliveSettings::setVideocodecs(result); result.clear(); Mlt::Properties acodecs((mlt_properties) consumer->get_data("acodec")); for (int i = 0; i < acodecs.count(); i++) result << QString(acodecs.get(i)); m_mltCheck.acodecs_list->addItems(result); + KdenliveSettings::setAudiocodecs(result); result.clear(); Mlt::Properties formats((mlt_properties) consumer->get_data("f")); for (int i = 0; i < formats.count(); i++) result << QString(formats.get(i)); m_mltCheck.formats_list->addItems(result); + KdenliveSettings::setSupportedformats(result); delete consumer; } @@ -404,9 +415,20 @@ void Wizard::slotCheckPrograms() item->setData(1, Qt::UserRole, i18n("Required for webcam capture")); item->setSizeHint(0, itemSize); QString exepath = KStandardDirs::findExe("ffmpeg"); - if (exepath.isEmpty()) item->setIcon(0, m_badIcon); - else if (KStandardDirs::findExe("ffplay").isEmpty()) item->setIcon(0, m_badIcon); - else item->setIcon(0, m_okIcon); + QString playpath = KStandardDirs::findExe("ffplay"); + item->setIcon(0, m_okIcon); + if (exepath.isEmpty()) { + // Check for libav version + exepath = KStandardDirs::findExe("avconv"); + if (exepath.isEmpty()) item->setIcon(0, m_badIcon); + } + if (playpath.isEmpty()) { + // Check for libav version + playpath = KStandardDirs::findExe("avplay"); + if (playpath.isEmpty()) item->setIcon(0, m_badIcon); + } + if (!exepath.isEmpty()) KdenliveSettings::setFfmpegpath(exepath); + if (!playpath.isEmpty()) KdenliveSettings::setFfplaypath(playpath); #ifndef Q_WS_MAC item = new QTreeWidgetItem(m_check.programList, QStringList() << QString() << i18n("recordmydesktop")); @@ -442,7 +464,13 @@ void Wizard::slotCheckPrograms() item = new QTreeWidgetItem(m_check.programList, QStringList() << QString() << i18n("xine")); item->setData(1, Qt::UserRole, i18n("Required to preview your DVD")); item->setSizeHint(0, itemSize); - if (KStandardDirs::findExe("xine").isEmpty()) item->setIcon(0, m_badIcon); + if (KStandardDirs::findExe("xine").isEmpty()) { + if (!KStandardDirs::findExe("vlc").isEmpty()) { + item->setText(1, i18n("vlc")); + item->setIcon(0, m_okIcon); + } + else item->setIcon(0, m_badIcon); + } else item->setIcon(0, m_okIcon); // set up some default applications @@ -469,12 +497,19 @@ void Wizard::installExtraMimes(QString baseName, QStringList globs) QString mimefile = baseName; mimefile.replace('/', '-'); KMimeType::Ptr mime = KMimeType::mimeType(baseName); + QStringList missingGlobs; + foreach(const QString & glob, globs) { + KMimeType::Ptr type = KMimeType::findByPath(glob, 0, true); + QString mimeName = type->name(); + if (!mimeName.contains("audio") && !mimeName.contains("video")) missingGlobs << glob; + } + if (missingGlobs.isEmpty()) return; if (!mime) { kDebug() << "KMimeTypeTrader: mimeType " << baseName << " not found"; } else { QStringList extensions = mime->patterns(); QString comment = mime->comment(); - foreach(const QString & glob, globs) { + foreach(const QString & glob, missingGlobs) { if (!extensions.contains(glob)) extensions << glob; } kDebug() << "EXTS: " << extensions; @@ -595,7 +630,8 @@ void Wizard::adjustSettings() { if (m_extra.installmimes->isChecked()) { QStringList globs; - globs << "*.mts" << "*.m2t" << "*.mod" << "*.ts" << "*.m2ts"; + + globs << "*.mts" << "*.m2t" << "*.mod" << "*.ts" << "*.m2ts" << "*.m2v"; installExtraMimes("video/mpeg", globs); globs.clear(); globs << "*.dv"; @@ -671,4 +707,9 @@ void Wizard::slotSaveCaptureFormat() ProfilesDialog::saveProfile(profile, vl4ProfilePath); } +void Wizard::slotUpdateDecklinkDevice(int captureCard) +{ + KdenliveSettings::setDecklink_capturedevice(captureCard); +} + #include "wizard.moc"