X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fwizard.h;h=de0fce1f3944df29d51aabb19fac137d6dc0c877;hb=c3302003093710ee247ad84c0fe2ef3c579d417f;hp=3f742aa6f20905aae3d4d79a6e48083001e816b9;hpb=bb5aa137893d15aca179e51241ca6a16dd6b8000;p=kdenlive diff --git a/src/wizard.h b/src/wizard.h index 3f742aa6..de0fce1f 100644 --- a/src/wizard.h +++ b/src/wizard.h @@ -26,31 +26,35 @@ #include #include +#include #include #include "ui_wizardstandard_ui.h" #include "ui_wizardextra_ui.h" #include "ui_wizardcheck_ui.h" #include "ui_wizardmltcheck_ui.h" +#include "ui_wizardcapture_ui.h" -class WizardDelegate: public QItemDelegate { +class WizardDelegate: public QItemDelegate +{ public: - WizardDelegate(QAbstractItemView* parent = 0): QItemDelegate(parent) { + explicit WizardDelegate(QAbstractItemView* parent = 0) + : QItemDelegate(parent) + { } void paint(QPainter* painter, const QStyleOptionViewItem& option, const QModelIndex& index) const { if (index.column() == 1) { - const bool hover = option.state & (QStyle::State_Selected); - QRect r1 = option.rect; painter->save(); - if (hover) { - painter->setPen(option.palette.color(QPalette::HighlightedText)); - QColor backgroundColor = option.palette.color(QPalette::Highlight); - painter->setBrush(QBrush(backgroundColor)); - painter->fillRect(r1, QBrush(backgroundColor)); - } + QStyleOptionViewItemV4 opt(option); + QStyle *style = opt.widget ? opt.widget->style() : QApplication::style(); + const int textMargin = style->pixelMetric(QStyle::PM_FocusFrameHMargin) + 1; + style->drawPrimitive(QStyle::PE_PanelItemViewItem, &opt, painter, opt.widget); + QFont font = painter->font(); font.setBold(true); painter->setFont(font); + QRect r1 = option.rect; + r1.adjust(0, textMargin, 0, - textMargin); int mid = (int)((r1.height() / 2)); r1.setBottom(r1.y() + mid); QRect r2 = option.rect; @@ -59,7 +63,6 @@ public: font.setBold(false); painter->setFont(font); QString subText = index.data(Qt::UserRole).toString(); - painter->setPen(option.palette.color(QPalette::Mid)); painter->drawText(r2, Qt::AlignLeft | Qt::AlignVCenter , subText); painter->restore(); } else { @@ -69,11 +72,12 @@ public: }; -class Wizard : public QWizard { +class Wizard : public QWizard +{ Q_OBJECT public: - Wizard(QWidget * parent = 0); - void installExtraMimes(QString baseName, QStringList globs); + explicit Wizard(bool upgrade, QWidget * parent = 0); + void installExtraMimes(const QString &baseName, const QStringList &globs); void runUpdateMimeDatabase(); void adjustSettings(); bool isOk() const; @@ -82,21 +86,31 @@ private: Ui::WizardStandard_UI m_standard; Ui::WizardExtra_UI m_extra; Ui::WizardMltCheck_UI m_mltCheck; + Ui::WizardCapture_UI m_capture; Ui::WizardCheck_UI m_check; QVBoxLayout *m_startLayout; bool m_systemCheckIsOk; - QStringList m_dvProfiles; - QStringList m_hdvProfiles; - QStringList m_otherProfiles; - QMap m_profilesInfo; + QLabel *m_welcomeLabel; + QMap m_dvProfiles; + QMap m_hdvProfiles; + QMap m_otherProfiles; void slotCheckPrograms(); void checkMltComponents(); + void checkMissingCodecs(); + KIcon m_okIcon; + KIcon m_badIcon; private slots: void slotCheckThumbs(); void slotCheckStandard(); void slotCheckSelectedItem(); void slotCheckMlt(); + void slotShowWebInfos(); + void slotDetectWebcam(); + void slotUpdateCaptureParameters(); + void slotSaveCaptureFormat(); + void slotUpdateDecklinkDevice(int captureCard); + void slotOpenManual(); }; #endif