X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Frenderwidget.h;h=f8958a670f50e28b5ea108e48c43c80cbc3ffa31;hb=4b2e4a4d9e38e705cce25243d768d081e01c5e67;hp=bc9beaf5886ad1a77bdadcd255ef0c691fe874be;hpb=fcec7a99634aaefd4022ec6755f1ec511211a06a;p=kdenlive diff --git a/src/renderwidget.h b/src/renderwidget.h index bc9beaf5..f8958a67 100644 --- a/src/renderwidget.h +++ b/src/renderwidget.h @@ -23,7 +23,7 @@ #include #include -#include +#include #include "definitions.h" #include "ui_renderwidget_ui.h" @@ -32,46 +32,56 @@ class QDomElement; // RenderViewDelegate is used to draw the progress bars. -class RenderViewDelegate : public QItemDelegate +class RenderViewDelegate : public QStyledItemDelegate { Q_OBJECT public: - RenderViewDelegate(QWidget *parent) : QItemDelegate(parent) {} + RenderViewDelegate(QWidget *parent) : QStyledItemDelegate(parent) {} void paint(QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) const { if (index.column() == 1) { - QRect r1 = option.rect; painter->save(); - if (option.state & (QStyle::State_Selected)) { - painter->setPen(option.palette.color(QPalette::HighlightedText)); - painter->fillRect(r1, option.palette.highlight()); - } else painter->setPen(option.palette.color(QPalette::Text)); + int factor = 2; + 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); + + if (option.state & QStyle::State_Selected) { + painter->setPen(option.palette.highlightedText().color()); + factor = 3; + }// else painter->setPen(option.palette.color(QPalette::Text)); QFont font = painter->font(); font.setBold(true); painter->setFont(font); - int mid = (int)((r1.height() / 2)); + QRect r1 = option.rect; + r1.adjust(0, textMargin, 0, - textMargin); + int mid = (int)((r1.height() / factor)); r1.setBottom(r1.y() + mid); - QRect r2 = option.rect; - r2.setTop(r2.y() + mid); painter->drawText(r1, Qt::AlignLeft | Qt::AlignBottom , index.data().toString()); + r1.setBottom(r1.bottom() + mid); + r1.setTop(r1.bottom() - mid); font.setBold(false); painter->setFont(font); - painter->setPen(option.palette.color(QPalette::Mid)); - painter->drawText(r2, Qt::AlignLeft | Qt::AlignVCenter , index.data(Qt::UserRole).toString()); + painter->drawText(r1, Qt::AlignLeft | Qt::AlignVCenter , index.data(Qt::UserRole).toString()); + if (factor > 2) { + r1.setBottom(r1.bottom() + mid); + r1.setTop(r1.bottom() - mid); + painter->drawText(r1, Qt::AlignLeft | Qt::AlignVCenter , index.data(Qt::UserRole + 5).toString()); + } painter->restore(); } else if (index.column() == 2) { // Set up a QStyleOptionProgressBar to precisely mimic the // environment of a progress bar. + QStyleOptionViewItemV4 opt(option); + QStyle *style = opt.widget ? opt.widget->style() : QApplication::style(); + style->drawPrimitive(QStyle::PE_PanelItemViewItem, &opt, painter, opt.widget); + QStyleOptionProgressBar progressBarOption; progressBarOption.state = option.state; progressBarOption.direction = QApplication::layoutDirection(); QRect rect = option.rect; - if (option.state & (QStyle::State_Selected)) { - painter->setPen(option.palette.color(QPalette::HighlightedText)); - painter->fillRect(rect, option.palette.highlight()); - } - int mid = rect.height() / 2; rect.setTop(rect.top() + mid / 2); rect.setHeight(mid); @@ -89,7 +99,7 @@ public: // Draw the progress bar onto the view. QApplication::style()->drawControl(QStyle::CE_ProgressBar, &progressBarOption, painter); - } else QItemDelegate::paint(painter, option, index); + } else QStyledItemDelegate::paint(painter, option, index); } }; @@ -100,6 +110,7 @@ class RenderWidget : public QDialog public: explicit RenderWidget(const QString &projectfolder, QWidget * parent = 0); + virtual ~RenderWidget(); void setGuides(QDomElement guidesxml, double duration); void focusFirstVisibleItem(); void setProfile(MltVideoProfile profile); @@ -107,18 +118,26 @@ public: void setRenderStatus(const QString &dest, int status, const QString &error); void setDocumentPath(const QString path); void reloadProfiles(); - void setRenderProfile(const QString &dest, const QString &name); + void setRenderProfile(QMap props); int waitingJobsCount() const; QString getFreeScriptName(const QString &prefix = QString()); bool startWaitingRenderJobs(); + void missingClips(bool hasMissing); + /** @brief Returns true if the export audio checkbox is set to automatic. */ + bool automaticAudioExport() const; + /** @brief Returns true if user wants audio export. */ + bool selectedAudioExport() const; public slots: - void slotExport(bool scriptExport, int zoneIn, int zoneOut, const QString &playlistPath, const QString &scriptPath); + void slotExport(bool scriptExport, int zoneIn, int zoneOut, const QString &playlistPath, const QString &scriptPath, bool exportAudio); private slots: void slotUpdateButtons(KUrl url); void slotUpdateButtons(); void refreshView(); + void refreshCategory(); + + /** @brief Updates available options when a new format has been selected. */ void refreshParams(); void slotSaveProfile(); void slotEditProfile(); @@ -139,24 +158,40 @@ private slots: void slotHideLog(); void slotPrepareExport(bool scriptExport = false); void slotPlayRendering(QTreeWidgetItem *item, int); + void slotStartCurrentJob(); + void slotCopyToFavorites(); + void slotUpdateRescaleHeight(int); + void slotUpdateRescaleWidth(int); + void slotSwitchAspectRatio(); + /** @brief Update export audio label depending on current settings. */ + void slotUpdateAudioLabel(int ix); private: Ui::RenderWidget_UI m_view; MltVideoProfile m_profile; QString m_projectFolder; + RenderViewDelegate *m_scriptsDelegate; + RenderViewDelegate *m_jobsDelegate; bool m_blockProcessing; + QString m_renderer; void parseProfiles(QString meta = QString(), QString group = QString(), QString profile = QString()); void parseFile(QString exportFile, bool editable); void updateButtons(); KUrl filenameWithExtension(KUrl url, QString extension); void checkRenderStatus(); + void startRendering(QTreeWidgetItem *item); + void saveProfile(QDomElement newprofile); + QList m_renderItems; + QList m_renderCategory; signals: - void doRender(const QStringList&, const QStringList&); void abortProcess(const QString &url); void openDvdWizard(const QString &url, const QString &profile); - void selectedRenderProfile(const QString &category, const QString &name); + /** Send the infos about rendering that will be saved in the document: + (profile destination, profile name and url of rendered file */ + void selectedRenderProfile(QMap renderProps); void prepareRenderingData(bool scriptExport, bool zoneOnly, const QString &chapterFile); + void shutdown(); };