X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Frenderwidget.h;h=388a3835ab6f8f8dc985e8f0cd9a3beb410da75e;hb=f4462e7ecb75f64e524746e3bb7c62a5e973d965;hp=e3aed4bd20034c10d014076139b3a8006bbd7544;hpb=18f3e786ec0f6be2309361d26fb2d66c2204d88d;p=kdenlive diff --git a/src/renderwidget.h b/src/renderwidget.h index e3aed4bd..388a3835 100644 --- a/src/renderwidget.h +++ b/src/renderwidget.h @@ -21,39 +21,200 @@ #ifndef RENDERWIDGET_H #define RENDERWIDGET_H -#include +#include +#if KDE_IS_VERSION(4,7,0) +#include +#endif + #include +#include +#include +#include "definitions.h" #include "ui_renderwidget_ui.h" -class RenderWidget : public QDialog { +class QDomElement; +class QKeyEvent; + + +// 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(); + 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 bounding; + painter->drawText(r1, Qt::AlignLeft | Qt::AlignTop ,index.data().toString(), &bounding); + r1.moveTop(r1.bottom() - textMargin); + font.setBold(false); + painter->setFont(font); + painter->drawText(r1, Qt::AlignLeft | Qt::AlignTop , index.data(Qt::UserRole).toString()); + int progress = index.data(Qt::UserRole + 3).toInt(); + if (progress > 0 && progress < 100) { + // draw progress bar + QColor color = option.palette.alternateBase().color(); + QColor fgColor = option.palette.text().color(); + color.setAlpha(150); + fgColor.setAlpha(150); + painter->setBrush(QBrush(color)); + painter->setPen(QPen(fgColor)); + int width = qMin(200, r1.width() - 4); + QRect bgrect(r1.left() + 2, option.rect.bottom() - 6 - textMargin, width, 6); + painter->drawRoundedRect(bgrect, 3, 3); + painter->setBrush(QBrush(fgColor)); + bgrect.adjust(2, 2, 0, -1); + painter->setPen(Qt::NoPen); + bgrect.setWidth((width - 2) * progress / 100); + painter->drawRect(bgrect); + } else { + r1.setBottom(opt.rect.bottom()); + r1.setTop(r1.bottom() - mid); + painter->drawText(r1, Qt::AlignLeft | Qt::AlignBottom , index.data(Qt::UserRole + 5).toString()); + } + painter->restore(); + } else QStyledItemDelegate::paint(painter, option, index); + } +}; + + +class RenderJobItem: public QTreeWidgetItem +{ +public: + explicit RenderJobItem(QTreeWidget * parent, const QStringList & strings, int type = QTreeWidgetItem::Type); + void setStatus(int status); + int status() const; + void setMetadata(const QString &data); + const QString metadata() const; + void render(); + +private: + int m_status; + QString m_data; +}; + +class RenderWidget : public QDialog +{ Q_OBJECT public: - RenderWidget(QWidget * parent = 0); - void setDocumentStandard(QString std); + explicit RenderWidget(const QString &projectfolder, bool enableProxy, const MltVideoProfile &profile, QWidget * parent = 0); + virtual ~RenderWidget(); void setGuides(QDomElement guidesxml, double duration); + void focusFirstVisibleItem(const QString &profile = QString()); + void setProfile(const 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(const QMap & props); + int waitingJobsCount() const; + QString getFreeScriptName(const KUrl &projectName = KUrl(), 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(); + +protected: + virtual QSize sizeHint() const; + virtual void keyPressEvent(QKeyEvent *e); + +public slots: + void slotExport(bool scriptExport, int zoneIn, int zoneOut, const QMap &metadata, const QString &playlistPath, const QString &scriptPath, bool exportAudio); private slots: + void slotUpdateButtons(const KUrl &url); void slotUpdateButtons(); - void slotExport(); - void refreshView(); + void refreshView(const QString &profile = QString()); + void refreshCategory(const QString &group = QString(), const QString &profile = QString()); + + /** @brief Updates available options when a new format has been selected. */ void refreshParams(); void slotSaveProfile(); void slotEditProfile(); - void slotDeleteProfile(); + 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); + /** @brief Enable / disable the rescale options. */ + void setRescaleEnabled(bool enable); private: Ui::RenderWidget_UI m_view; - void parseProfiles(QString group = QString(), QString profile = QString()); - void parseFile(QString exportFile, bool editable); + QString m_projectFolder; + MltVideoProfile m_profile; + RenderViewDelegate *m_scriptsDelegate; + RenderViewDelegate *m_jobsDelegate; + bool m_blockProcessing; + QString m_renderer; + +#if KDE_IS_VERSION(4,7,0) + KMessageWidget *m_infoMessage; +#endif + + void parseProfiles(const QString &meta = QString(), const QString &group = QString(), const QString &profile = QString()); + void parseFile(const QString &exportFile, bool editable); + void updateButtons(); + KUrl filenameWithExtension(KUrl url, const QString &extension); + /** @brief Check if a job needs to be started. */ + void checkRenderStatus(); + void startRendering(RenderJobItem *item); + void saveProfile(const QDomElement &newprofile); + QList m_renderItems; + QList m_renderCategory; + void errorMessage(const QString &message); signals: - void doRender(const QString&, const QString&, const QStringList &, const QStringList &, bool, bool, double, double); + void abortProcess(const QString &url); + void openDvdWizard(const QString &url); + /** Send the infos about rendering that will be saved in the document: + (profile destination, profile name and url of rendered file */ + void selectedRenderProfile(const QMap &renderProps); + void prepareRenderingData(bool scriptExport, bool zoneOnly, const QString &chapterFile); + void shutdown(); };