X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Frenderwidget.h;h=388a3835ab6f8f8dc985e8f0cd9a3beb410da75e;hb=c3302003093710ee247ad84c0fe2ef3c579d417f;hp=53b50ef812eb6ed1e60d09a06c7c0564dd11d04d;hpb=e74ed82c3ebc6b5b86106632f5dabdc524ac695a;p=kdenlive diff --git a/src/renderwidget.h b/src/renderwidget.h index 53b50ef8..388a3835 100644 --- a/src/renderwidget.h +++ b/src/renderwidget.h @@ -34,6 +34,7 @@ #include "ui_renderwidget_ui.h" class QDomElement; +class QKeyEvent; // RenderViewDelegate is used to draw the progress bars. @@ -67,6 +68,7 @@ public: 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); @@ -75,7 +77,7 @@ public: painter->setPen(QPen(fgColor)); int width = qMin(200, r1.width() - 4); QRect bgrect(r1.left() + 2, option.rect.bottom() - 6 - textMargin, width, 6); - painter->drawRect(bgrect); + painter->drawRoundedRect(bgrect, 3, 3); painter->setBrush(QBrush(fgColor)); bgrect.adjust(2, 2, 0, -1); painter->setPen(Qt::NoPen); @@ -87,34 +89,6 @@ public: painter->drawText(r1, Qt::AlignLeft | Qt::AlignBottom , 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); } }; @@ -140,18 +114,18 @@ class RenderWidget : public QDialog Q_OBJECT public: - explicit RenderWidget(const QString &projectfolder, bool enableProxy, MltVideoProfile profile, QWidget * parent = 0); + explicit RenderWidget(const QString &projectfolder, bool enableProxy, const MltVideoProfile &profile, QWidget * parent = 0); virtual ~RenderWidget(); void setGuides(QDomElement guidesxml, double duration); - void focusFirstVisibleItem(); - void setProfile(MltVideoProfile profile); + 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(QMap props); + void setRenderProfile(const QMap & props); int waitingJobsCount() const; - QString getFreeScriptName(const QString &prefix = QString()); + 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. */ @@ -165,15 +139,16 @@ public: protected: virtual QSize sizeHint() const; + virtual void keyPressEvent(QKeyEvent *e); public slots: - void slotExport(bool scriptExport, int zoneIn, int zoneOut, const QString &playlistPath, const QString &scriptPath, bool exportAudio); + void slotExport(bool scriptExport, int zoneIn, int zoneOut, const QMap &metadata, const QString &playlistPath, const QString &scriptPath, bool exportAudio); private slots: - void slotUpdateButtons(KUrl url); + void slotUpdateButtons(const KUrl &url); void slotUpdateButtons(); - void refreshView(); - void refreshCategory(); + 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(); @@ -220,24 +195,24 @@ private: KMessageWidget *m_infoMessage; #endif - void parseProfiles(QString meta = QString(), QString group = QString(), QString profile = QString()); - void parseFile(QString exportFile, bool editable); + 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, QString extension); + KUrl filenameWithExtension(KUrl url, const QString &extension); /** @brief Check if a job needs to be started. */ void checkRenderStatus(); void startRendering(RenderJobItem *item); - void saveProfile(QDomElement newprofile); + void saveProfile(const QDomElement &newprofile); QList m_renderItems; QList m_renderCategory; void errorMessage(const QString &message); signals: void abortProcess(const QString &url); - void openDvdWizard(const QString &url, const QString &profile); + 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(QMap renderProps); + void selectedRenderProfile(const QMap &renderProps); void prepareRenderingData(bool scriptExport, bool zoneOnly, const QString &chapterFile); void shutdown(); };