X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fwizard.h;h=769bf766ad5452019e935aff6a7de4ed52d9193d;hb=58c5d98d7ea0cbe8745a52a0d55414cf56938d97;hp=c76b9b9a6fdfd768dcdd268ec1a635a8750cccea;hpb=6a67414cb9f5b8da5a653fa50c6c61240c97ef2f;p=kdenlive diff --git a/src/wizard.h b/src/wizard.h index c76b9b9a..769bf766 100644 --- a/src/wizard.h +++ b/src/wizard.h @@ -26,31 +26,33 @@ #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) { } 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 +61,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,10 +70,11 @@ public: }; -class Wizard : public QWizard { +class Wizard : public QWizard +{ Q_OBJECT public: - Wizard(QWidget * parent = 0); + explicit Wizard(bool upgrade, QWidget * parent = 0); void installExtraMimes(QString baseName, QStringList globs); void runUpdateMimeDatabase(); void adjustSettings(); @@ -81,20 +83,32 @@ public: 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