X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Frenderwidget.h;h=11e9e08eae77e278d3f8d4f71b54ce36d0ce6970;hb=3577376c5e5b6cc533af0edc9d4f03d0b3770f9e;hp=55324e782c134c9ff1165676f3183f2f2d73bb88;hpb=59373ab56bb7d2c669d816bb377aaf53faa2ea20;p=kdenlive diff --git a/src/renderwidget.h b/src/renderwidget.h index 55324e78..11e9e08e 100644 --- a/src/renderwidget.h +++ b/src/renderwidget.h @@ -21,26 +21,182 @@ #ifndef RENDERWIDGET_H #define RENDERWIDGET_H -#include #include +#include +#include +#include "definitions.h" #include "ui_renderwidget_ui.h" -class RenderWidget : public QDialog { +class QDomElement; + + +// RenderViewDelegate is used to draw the progress bars. +class RenderViewDelegate : public QStyledItemDelegate +{ + Q_OBJECT +public: + RenderViewDelegate(QWidget *parent) : QStyledItemDelegate(parent) {} + + void paint(QPainter *painter, const QStyleOptionViewItem &option, + const QModelIndex &index) const { + if (index.column() == 1) { + painter->save(); + 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); + QRect r1 = option.rect; + r1.adjust(0, textMargin, 0, - textMargin); + int mid = (int)((r1.height() / factor)); + r1.setBottom(r1.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->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; + int mid = rect.height() / 2; + rect.setTop(rect.top() + mid / 2); + rect.setHeight(mid); + progressBarOption.rect = rect; + progressBarOption.fontMetrics = QApplication::fontMetrics(); + progressBarOption.minimum = 0; + progressBarOption.maximum = 100; + progressBarOption.textAlignment = Qt::AlignCenter; + progressBarOption.textVisible = true; + + // Set the progress and text values of the style option. + int progress = index.data(Qt::UserRole).toInt(); + progressBarOption.progress = progress < 0 ? 0 : progress; + progressBarOption.text = QString().sprintf("%d%%", progressBarOption.progress); + + // Draw the progress bar onto the view. + QApplication::style()->drawControl(QStyle::CE_ProgressBar, &progressBarOption, painter); + } else QStyledItemDelegate::paint(painter, option, index); + } +}; + + +class RenderWidget : public QDialog +{ Q_OBJECT public: - RenderWidget(QWidget * parent = 0); + explicit RenderWidget(const QString &projectfolder, bool enableProxy, QWidget * parent = 0); + virtual ~RenderWidget(); + void setGuides(QDomElement guidesxml, double duration); + void focusFirstVisibleItem(); + void setProfile(MltVideoProfile profile); + void setRenderJob(const QString &dest, int progress = 0); + void setRenderStatus(const QString &dest, int status, const QString &error); + void setDocumentPath(const QString path); + void reloadProfiles(); + 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; + /** @brief Show / hide proxy settings. */ + void updateProxyConfig(bool enable); + /** @brief Should we render using proxy clips. */ + bool proxyRendering(); + +public slots: + 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 slotExport(); + void refreshView(); + void refreshCategory(); + + /** @brief Updates available options when a new format has been selected. */ + void refreshParams(); + void slotSaveProfile(); + void slotEditProfile(); + void slotDeleteProfile(bool refresh = true); + void slotUpdateGuideBox(); + void slotCheckStartGuidePosition(); + void slotCheckEndGuidePosition(); + void showInfoPanel(); + void slotAbortCurrentJob(); + void slotStartScript(); + void slotDeleteScript(); + void slotGenerateScript(); + void parseScriptFiles(); + void slotCheckScript(); + void slotCheckJob(); + void slotEditItem(QListWidgetItem *item); + void slotCLeanUpJobs(); + void slotHideLog(); + void slotPrepareExport(bool scriptExport = false); + void slotPlayRendering(QTreeWidgetItem *item, int); + void slotStartCurrentJob(); + void slotCopyToFavorites(); + void slotUpdateEncodeThreads(int); + 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 QString&, const QStringList &, bool, bool); + void abortProcess(const QString &url); + void openDvdWizard(const QString &url, const QString &profile); + /** 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(); };