X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Frenderwidget.h;h=53b50ef812eb6ed1e60d09a06c7c0564dd11d04d;hb=e74ed82c3ebc6b5b86106632f5dabdc524ac695a;hp=11e9e08eae77e278d3f8d4f71b54ce36d0ce6970;hpb=3577376c5e5b6cc533af0edc9d4f03d0b3770f9e;p=kdenlive diff --git a/src/renderwidget.h b/src/renderwidget.h index 11e9e08e..53b50ef8 100644 --- a/src/renderwidget.h +++ b/src/renderwidget.h @@ -21,6 +21,11 @@ #ifndef RENDERWIDGET_H #define RENDERWIDGET_H +#include +#if KDE_IS_VERSION(4,7,0) +#include +#endif + #include #include #include @@ -42,33 +47,44 @@ public: 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)); + int mid = (int)((r1.height() / 2)); 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); + 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::AlignVCenter , index.data(Qt::UserRole).toString()); - if (factor > 2) { - r1.setBottom(r1.bottom() + mid); + 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) { + 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->drawRect(bgrect); + 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::AlignVCenter , index.data(Qt::UserRole + 5).toString()); + painter->drawText(r1, Qt::AlignLeft | Qt::AlignBottom , index.data(Qt::UserRole + 5).toString()); } painter->restore(); } else if (index.column() == 2) { @@ -104,19 +120,34 @@ public: }; +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: - explicit RenderWidget(const QString &projectfolder, bool enableProxy, QWidget * parent = 0); + explicit RenderWidget(const QString &projectfolder, bool enableProxy, MltVideoProfile profile, 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 setDocumentPath(const QString &path); void reloadProfiles(); void setRenderProfile(QMap props); int waitingJobsCount() const; @@ -132,6 +163,9 @@ public: /** @brief Should we render using proxy clips. */ bool proxyRendering(); +protected: + virtual QSize sizeHint() const; + public slots: void slotExport(bool scriptExport, int zoneIn, int zoneOut, const QString &playlistPath, const QString &scriptPath, bool exportAudio); @@ -170,24 +204,33 @@ private slots: 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; - MltVideoProfile m_profile; 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(QString meta = QString(), QString group = QString(), QString profile = QString()); void parseFile(QString exportFile, bool editable); void updateButtons(); KUrl filenameWithExtension(KUrl url, QString extension); + /** @brief Check if a job needs to be started. */ void checkRenderStatus(); - void startRendering(QTreeWidgetItem *item); + void startRendering(RenderJobItem *item); void saveProfile(QDomElement newprofile); QList m_renderItems; QList m_renderCategory; + void errorMessage(const QString &message); signals: void abortProcess(const QString &url);