]> git.sesse.net Git - kdenlive/blobdiff - src/projectlist.h
- Fix split audio with locked audio tracks
[kdenlive] / src / projectlist.h
index 35a69d4e1c7f5ff30e03b6afd8149c09e652f561..376c9c60c5183108e756ae749dc8cfb29a117543 100644 (file)
  ***************************************************************************/
 
 
-#ifndef PRJECTLIST_H
-#define PRJECTLIST_H
+#ifndef PROJECTLIST_H
+#define PROJECTLIST_H
 
 #include <QDomNodeList>
 #include <QToolBar>
+#include <QToolButton>
 #include <QTreeWidget>
 #include <QPainter>
+#include <QStyledItemDelegate>
+#include <QUndoStack>
+#include <QTimer>
+#include <QApplication>
 
-#include <KUndoStack>
 #include <KTreeWidgetSearchLine>
-#include "kextendableitemdelegate.h"
+#include <KUrl>
+#include <KIcon>
+
+#ifdef NEPOMUK
+#include <nepomuk/kratingpainter.h>
+#include <nepomuk/resource.h>
+#endif
 
 #include "definitions.h"
-#include "kdenlivedoc.h"
-#include "renderer.h"
 #include "timecode.h"
-#include "projectlistview.h"
+#include "kdenlivesettings.h"
+#include "folderprojectitem.h"
+#include "subprojectitem.h"
+
+namespace Mlt
+{
+class Producer;
+};
 
 class ProjectItem;
+class ProjectListView;
+class Render;
+class KdenliveDoc;
+class DocClipBase;
 
-  const int NameRole = Qt::UserRole;
-  const int DurationRole = NameRole + 1;
-  const int UsageRole = NameRole + 2;
+const int NameRole = Qt::UserRole;
+const int DurationRole = NameRole + 1;
+const int UsageRole = NameRole + 2;
 
-class ItemDelegate: public KExtendableItemDelegate
+class ItemDelegate: public QStyledItemDelegate
 {
-  public:
-    ItemDelegate(QAbstractItemView* parent = 0): KExtendableItemDelegate(parent)
-    {
+public:
+    ItemDelegate(QAbstractItemView* parent = 0): QStyledItemDelegate(parent) {
     }
-/*
-void expand()
-{
-  QWidget *w = new QWidget;
-  QVBoxLayout *layout = new QVBoxLayout;
-  layout->addWidget( new KColorButton(w)); 
-  w->setLayout( layout );
-  extendItem(w, 
-}
-*/
-
-void paint(QPainter* painter, const QStyleOptionViewItem& option, const QModelIndex& index) const
-{
-  if (index.column() == 1)
-  {
-    const bool hover = option.state & (QStyle::State_Selected|QStyle::State_MouseOver|QStyle::State_HasFocus);
-    QRect r1 = option.rect;
-    painter->save();
-    if (hover) {
-        painter->setPen(option.palette.color(QPalette::HighlightedText));
-        QColor backgroundColor = option.palette.color(QPalette::Highlight);
-        painter->setBrush(QBrush(backgroundColor));
-       painter->fillRect(r1, QBrush(backgroundColor));
+
+    /*void drawFocus(QPainter *, const QStyleOptionViewItem &, const QRect &) const {
+    }*/
+
+    void paint(QPainter* painter, const QStyleOptionViewItem& option, const QModelIndex& index) const {
+        if (index.column() == 0 && !index.data(DurationRole).isNull()) {
+            QRect r1 = option.rect;
+            painter->save();
+            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<QPixmap>(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.adjust(decoWidth, 0, 0, -mid);
+            QRect r2 = option.rect;
+            r2.adjust(decoWidth, mid, 0, 0);
+            painter->drawText(r1, Qt::AlignLeft | Qt::AlignBottom , index.data().toString());
+            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));
+            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() == 2 && KdenliveSettings::activate_nepomuk()) {
+            if (index.data().toString().isEmpty()) {
+                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 {
+            QStyledItemDelegate::paint(painter, option, index);
+        }
     }
-    QFont font = painter->font();
-    font.setPointSize(font.pointSize() - 1 );
-    font.setBold(true);
-    painter->setFont(font);
-    int mid = (int) ((r1.height() / 2 ));
-    r1.setBottom(r1.y() + mid);
-    QRect r2 = option.rect;
-    r2.setTop(r2.y() + mid);
-    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->drawText(r2, Qt::AlignLeft | Qt::AlignVCenter , subText);
-    painter->restore();
-  }
-  else
-  {
-    KExtendableItemDelegate::paint(painter, option, index);
-  }
-}
 };
 
 class ProjectList : public QWidget
 {
-  Q_OBJECT
-  
-  public:
-    ProjectList(QWidget *parent=0);
+    Q_OBJECT
+
+public:
+    ProjectList(QWidget *parent = 0);
     virtual ~ProjectList();
 
     QDomElement producersList();
     void setRenderer(Render *projectRender);
+    void slotUpdateClipProperties(const QString &id, QMap <QString, QString> properties);
+    QByteArray headerInfo() const;
+    void setHeaderInfo(const QByteArray &state);
+    void updateProjectFormat(Timecode t);
+    void setupMenu(QMenu *addMenu, QAction *defaultAction);
+    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 <DocClipBase*> 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 <QString, QString> map);
+    void selectItemById(const QString &clipId);
 
-    void addClip(const QStringList &name, const QDomElement &elem, const int clipId, const KUrl &url = KUrl(), const QString &group = QString::null, int parentId = -1);
-
-  public slots:
+public slots:
     void setDocument(KdenliveDoc *doc);
-    void addProducer(QDomElement producer, int parentId = -1);
-    void slotReplyGetImage(int clipId, int pos, const QPixmap &pix, int w, int h);
-    void slotReplyGetFileProperties(int clipId, const QMap < QString, QString > &properties, const QMap < QString, QString > &metadata);
-    void slotAddClip(DocClipBase *clip);
-    void slotDeleteClip(int clipId);
-    void slotUpdateClip(int id);
+    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(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 <QUrl> givenList = QList <QUrl> (), 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();
+    void slotEditClip();
+    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 *listView;
-    KTreeWidgetSearchLine *searchView;
+private:
+    ProjectListView *m_listView;
     Render *m_render;
     Timecode m_timecode;
     double m_fps;
     QToolBar *m_toolbar;
+    QTimer m_queueTimer;
     QMenu *m_menu;
-    KUndoStack *m_commandStack;
-    int m_clipIdCounter;
-    void selectItemById(const int clipId);
-    ProjectItem *getItemById(int id);
+    QUndoStack *m_commandStack;
+    ProjectItem *getItemById(const QString &id);
+    QTreeWidgetItem *getAnyItemById(const QString &id);
+    FolderProjectItem *getFolderItemById(const QString &id);
     QAction *m_editAction;
     QAction *m_deleteAction;
-    ItemDelegate *m_listViewDelegate;
+    QAction *m_openAction;
+    QAction *m_reloadAction;
+    QMenu *m_transcodeAction;
     KdenliveDoc *m_doc;
+    ItemDelegate *m_listViewDelegate;
+    bool m_refreshed;
+    QToolButton *m_addButton;
+    QMap <QString, QDomElement> m_infoQueue;
+    QMap <QString, QDomElement> m_producerQueue;
+    void requestClipInfo(const QDomElement xml, const QString id);
+    QList <QString> m_thumbnailQueue;
+    void requestClipThumbnail(const QString id);
+    /** @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 editClipSelection(QList<QTreeWidgetItem *> list);
+    /** @brief Enables and disables transcode actions based on the selected clip's type. */
+    void adjustTranscodeActions(ProjectItem *clip) const;
+    /** @brief Sets the buttons enabled/disabled according to selected item. */
+    void updateButtons() const;
 
-  private slots:
-    void slotAddClip(QUrl givenUrl = QUrl(), const QString &group = QString::null);
-    void slotRemoveClip();
-    void slotEditClip();
+private slots:
     void slotClipSelected();
-    void slotAddColorClip();
+    void slotAddSlideshowClip();
     void slotAddTitleClip();
-    void slotEditClip(QTreeWidgetItem *, int);
-    void slotContextMenu( const QPoint &pos, QTreeWidgetItem * );
+    void slotAddTitleTemplateClip();
+
+    /** @brief Shows the context menu after enabling and disabling actions based on the item's type.
+    * @param pos The position where the menu should pop up
+    * @param item The item for which the checks should be done */
+    void slotContextMenu(const QPoint &pos, QTreeWidgetItem *item);
+    /** @brief Creates an AddFolderCommand. */
     void slotAddFolder();
-    /** This is triggered when a clip description has been modified */
-    void slotUpdateItemDescription(QTreeWidgetItem *item, int column);
+    /** @brief This is triggered when a clip description has been modified. */
+    void slotItemEdited(QTreeWidgetItem *item, int column);
+    void slotUpdateClipProperties(ProjectItem *item, QMap <QString, QString> 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(const QDomElement &);
-    void getFileProperties(const QDomElement&, int);
-    void receivedClipDuration(int, int);
+signals:
+    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 <DocClipBase *>, QMap<QString, QString> 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 <QString, QString> folderids);
+    void findInTimeline(const QString &clipId);
 };
 
 #endif