X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fprojectlist.h;h=6b38f01a7b8d02446dd0857e73625f7b9a3278b1;hb=856f46341a3659ec6b5ccc4696b4c0bf358e6b9b;hp=60e283bfa1ac003896309743b05f1a1cc96daa7e;hpb=9acf3acd7946f6ed7946629ad4bc6a8755e05387;p=kdenlive diff --git a/src/projectlist.h b/src/projectlist.h index 60e283bf..6b38f01a 100644 --- a/src/projectlist.h +++ b/src/projectlist.h @@ -26,18 +26,25 @@ #include #include #include -#include +#include #include #include +#include #include #include +#include + +#ifdef NEPOMUK #include #include +#endif #include "definitions.h" #include "timecode.h" #include "kdenlivesettings.h" +#include "folderprojectitem.h" +#include "subprojectitem.h" namespace Mlt { @@ -54,60 +61,68 @@ const int NameRole = Qt::UserRole; const int DurationRole = NameRole + 1; const int UsageRole = NameRole + 2; -class ItemDelegate: public QItemDelegate +class ItemDelegate: public QStyledItemDelegate { public: - ItemDelegate(QAbstractItemView* parent = 0): QItemDelegate(parent) { - } - /* - static_cast( index.internalPointer() ); - - void expand() - { - QWidget *w = new QWidget; - QVBoxLayout *layout = new QVBoxLayout; - layout->addWidget( new KColorButton(w)); - w->setLayout( layout ); - extendItem(w, + ItemDelegate(QAbstractItemView* parent = 0): QStyledItemDelegate(parent) { } - */ + + /*void drawFocus(QPainter *, const QStyleOptionViewItem &, const QRect &) const { + }*/ + void paint(QPainter* painter, const QStyleOptionViewItem& option, const QModelIndex& index) const { - if (index.column() == 1) { + if (index.column() == 0 && !index.data(DurationRole).isNull()) { 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()); + QStyleOptionViewItemV4 opt(option); + QStyle *style = opt.widget ? opt.widget->style() : QApplication::style(); + style->drawPrimitive(QStyle::PE_PanelItemViewItem, &opt, painter, opt.widget); + + if (option.state & QStyle::State_Selected) { + painter->setPen(option.palette.highlightedText().color()); + } + const int textMargin = style->pixelMetric(QStyle::PM_FocusFrameHMargin) + 1; + QPixmap pixmap = qVariantValue(index.data(Qt::DecorationRole)); + if ((index.flags() & (Qt::ItemIsDragEnabled)) == false) { + KIcon icon("dialog-close"); + QPainter p(&pixmap); + p.drawPixmap(1, 1, icon.pixmap(16, 16)); + p.end(); } + + painter->drawPixmap(r1.left() + textMargin, r1.top() + (r1.height() - pixmap.height()) / 2, pixmap); + int decoWidth = pixmap.width() + 2 * textMargin; + QFont font = painter->font(); font.setBold(true); painter->setFont(font); int mid = (int)((r1.height() / 2)); - r1.setBottom(r1.y() + mid); + r1.adjust(decoWidth, 0, 0, -mid); QRect r2 = option.rect; - r2.setTop(r2.y() + mid); + r2.adjust(decoWidth, mid, 0, 0); painter->drawText(r1, Qt::AlignLeft | Qt::AlignBottom , index.data().toString()); - //painter->setPen(Qt::green); font.setBold(false); painter->setFont(font); QString subText = index.data(DurationRole).toString(); int usage = index.data(UsageRole).toInt(); if (usage != 0) subText.append(QString(" (%1)").arg(usage)); - painter->setPen(option.palette.color(QPalette::Mid)); + if (option.state & (QStyle::State_Selected)) painter->setPen(option.palette.color(QPalette::Mid)); painter->drawText(r2, Qt::AlignLeft | Qt::AlignVCenter , subText); painter->restore(); - } else if (index.column() == 3 && KdenliveSettings::activate_nepomuk()) { + } else if (index.column() == 2 && KdenliveSettings::activate_nepomuk()) { if (index.data().toString().isEmpty()) { - QItemDelegate::paint(painter, option, index); + QStyledItemDelegate::paint(painter, option, index); return; } QRect r1 = option.rect; if (option.state & (QStyle::State_Selected)) { painter->fillRect(r1, option.palette.highlight()); } +#ifdef NEPOMUK KRatingPainter::paintRating(painter, r1, Qt::AlignCenter, index.data().toInt()); +#endif } else { - QItemDelegate::paint(painter, option, index); + QStyledItemDelegate::paint(painter, option, index); } } }; @@ -123,28 +138,45 @@ public: QDomElement producersList(); void setRenderer(Render *projectRender); void slotUpdateClipProperties(const QString &id, QMap properties); - void updateAllClips(); QByteArray headerInfo() const; void setHeaderInfo(const QByteArray &state); + void updateProjectFormat(Timecode t); void setupMenu(QMenu *addMenu, QAction *defaultAction); - void setupGeneratorMenu(QMenu *addMenu, QMenu *transcodeMenu); + void setupGeneratorMenu(QMenu *addMenu, QMenu *transcodeMenu, QMenu *inTimelineMenu); QString currentClipUrl() const; + KUrl::List getConditionalUrls(const QString &condition) const; void reloadClipThumbnails(); QDomDocument generateTemplateXml(QString data, const QString &replaceString); + void cleanup(); + void trashUnusedClips(); + QList documentClipList() const; + void addClipCut(const QString &id, int in, int out, const QString desc, bool newItem); + void removeClipCut(const QString &id, int in, int out); + void focusTree() const; + SubProjectItem *getSubItem(ProjectItem *clip, QPoint zone); + void doUpdateClipCut(const QString &id, const QPoint oldzone, const QPoint zone, const QString &comment); + bool hasMissingClips(); + void deleteProjectFolder(QMap map); + void selectItemById(const QString &clipId); public slots: void setDocument(KdenliveDoc *doc); + void updateAllClips(); void slotReplyGetImage(const QString &clipId, const QPixmap &pix); void slotReplyGetFileProperties(const QString &clipId, Mlt::Producer *producer, const QMap < QString, QString > &properties, const QMap < QString, QString > &metadata, bool replace); void slotAddClip(DocClipBase *clip, bool getProperties); void slotDeleteClip(const QString &clipId); void slotUpdateClip(const QString &id); void slotRefreshClipThumbnail(const QString &clipId, bool update = true); - void slotRefreshClipThumbnail(ProjectItem *item, bool update = true); + void slotRefreshClipThumbnail(QTreeWidgetItem *item, bool update = true); void slotRemoveInvalidClip(const QString &id, bool replace); void slotSelectClip(const QString &ix); + /** @brief Prepares removing the selected items. */ void slotRemoveClip(); void slotAddClip(const QList givenList = QList (), const QString &groupName = QString(), const QString &groupId = QString()); + /** @brief Adds, edits or deletes a folder item. + * + * This is triggered by AddFolderCommand and EditFolderCommand. */ void slotAddFolder(const QString foldername, const QString &clipId, bool remove, bool edit = false); void slotResetProjectList(); void slotOpenClip(); @@ -152,6 +184,8 @@ public slots: void slotReloadClip(const QString &id = QString()); void slotAddColorClip(); void regenerateTemplate(const QString &id); + void slotUpdateClipCut(QPoint p); + void slotAddClipCut(const QString &id, int in, int out); private: ProjectListView *m_listView; @@ -162,15 +196,16 @@ private: QTimer m_queueTimer; QMenu *m_menu; QUndoStack *m_commandStack; - void selectItemById(const QString &clipId); ProjectItem *getItemById(const QString &id); - ProjectItem *getFolderItemById(const QString &id); + QTreeWidgetItem *getAnyItemById(const QString &id); + FolderProjectItem *getFolderItemById(const QString &id); QAction *m_editAction; QAction *m_deleteAction; QAction *m_openAction; QAction *m_reloadAction; + QMenu *m_transcodeAction; KdenliveDoc *m_doc; - ProjectItem *m_selectedItem; + ItemDelegate *m_listViewDelegate; bool m_refreshed; QToolButton *m_addButton; QMap m_infoQueue; @@ -178,11 +213,14 @@ private: void requestClipInfo(const QDomElement xml, const QString id); QList m_thumbnailQueue; void requestClipThumbnail(const QString id); - void deleteProjectFolder(QMap map); + /** @brief Creates an EditFolderCommand to change the name of an folder item. */ void editFolder(const QString folderName, const QString oldfolderName, const QString &clipId); QStringList getGroup() const; void regenerateTemplate(ProjectItem *clip); - void regenerateTemplateImage(ProjectItem *clip); + void editClipSelection(QList list); + void adjustTranscodeActions(ProjectItem *clip) const; + /** @brief Sets the buttons enabled/disabled according to selected item. */ + void updateButtons() const; private slots: void slotClipSelected(); @@ -190,25 +228,36 @@ private slots: void slotAddTitleClip(); void slotAddTitleTemplateClip(); void slotContextMenu(const QPoint &pos, QTreeWidgetItem *); + /** @brief Creates an AddFolderCommand. */ void slotAddFolder(); - /** This is triggered when a clip description has been modified */ + /** @brief This is triggered when a clip description has been modified. */ void slotItemEdited(QTreeWidgetItem *item, int column); void slotUpdateClipProperties(ProjectItem *item, QMap properties); void slotProcessNextClipInQueue(); void slotProcessNextThumbnail(); void slotCheckForEmptyQueue(); void slotPauseMonitor(); + /** A clip was modified externally, change icon so that user knows it */ + void slotModifiedClip(const QString &id); + void slotMissingClip(const QString &id); + void slotAvailableClip(const QString &id); //void slotShowMenu(const QPoint &pos); signals: - void clipSelected(DocClipBase *); - void getFileProperties(const QDomElement&, const QString &, bool); + void clipSelected(DocClipBase *, QPoint zone = QPoint()); + void getFileProperties(const QDomElement, const QString &, int pixHeight, bool); void receivedClipDuration(const QString &); void showClipProperties(DocClipBase *); + void showClipProperties(QList , QMap commonproperties); void projectModified(); void loadingIsOver(); + void displayMessage(const QString, int progress); void clipNameChanged(const QString, const QString); + void clipNeedsReload(const QString&, bool); void refreshClip(); + void updateRenderStatus(); + void deleteProjectClips(QStringList ids, QMap folderids); + void findInTimeline(const QString &clipId); }; #endif