X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fcustomtrackview.h;h=cc75ed8f51d87f6c341c83d11a303751c6b9a984;hb=c95a41b4c6dcdeb07f17661cb4a2ce3154cc0f67;hp=a6a452ed64fd2dad8340c24ae1348e359d0991b1;hpb=f35687ff26abd4307e7e8dd4ea7a8aa5dd9a7752;p=kdenlive diff --git a/src/customtrackview.h b/src/customtrackview.h index a6a452ed..cc75ed8f 100644 --- a/src/customtrackview.h +++ b/src/customtrackview.h @@ -38,7 +38,8 @@ class AbstractGroupItem; class Transition; class CustomTrackScene; -class CustomTrackView : public QGraphicsView { +class CustomTrackView : public QGraphicsView +{ Q_OBJECT public: @@ -66,6 +67,7 @@ public: void setScale(double scaleFactor); void deleteClip(const QString &clipId); void slotAddEffect(QDomElement effect, GenTime pos, int track); + void slotAddGroupEffect(QDomElement effect, AbstractGroupItem *group); void addEffect(int track, GenTime pos, QDomElement effect); void deleteEffect(int track, GenTime pos, QDomElement effect); void updateEffect(int track, GenTime pos, QDomElement effect, int ix, bool triggeredByUser = true); @@ -78,7 +80,7 @@ public: int duration() const; void deleteSelectedClips(); void cutSelectedClips(); - void setContextMenu(QMenu *timeline, QMenu *clip, QMenu *transition); + void setContextMenu(QMenu *timeline, QMenu *clip, QMenu *transition, QActionGroup *clipTypeGroup); void checkTrackHeight(); //QList tracksList() const; void setTool(PROJECTTOOL tool); @@ -108,6 +110,17 @@ public: void autoTransition(); QStringList getLadspaParams(QDomElement effect) const; void initCursorPos(int pos); + void lockTrack(int ix, bool lock); + void groupClips(bool group = true); + void doGroupClips(QList clipInfos, QList transitionInfos, bool group); + void loadGroups(const QDomNodeList groups); + void splitAudio(); + void doSplitAudio(const GenTime &pos, int track, bool split); + void setVideoOnly(); + void setAudioOnly(); + void setAudioAndVideo(); + void doChangeClipType(const GenTime &pos, int track, bool videoOnly, bool audioOnly); + int hasGuide(int pos, int offset); public slots: void setCursorPos(int pos, bool seek = true); @@ -122,16 +135,16 @@ public slots: void slotAddTransition(ClipItem* clip, ItemInfo transitionInfo, int endTrack, QDomElement transition = QDomElement()); void slotAddTransitionToSelectedClips(QDomElement transition); void slotTransitionUpdated(Transition *, QDomElement); - void slotTransitionTrackUpdated(Transition *tr, int track); void slotSwitchTrackAudio(int ix); void slotSwitchTrackVideo(int ix); + void slotSwitchTrackLock(int ix); void slotUpdateClip(const QString &clipId); void slotAddClipMarker(const QString &id, GenTime t, QString c); bool addGuide(const GenTime pos, const QString &comment); void slotAddGuide(); void slotEditGuide(CommentedTime guide); - void slotEditGuide(); - void slotDeleteGuide(); + void slotEditGuide(int guidePos = -1); + void slotDeleteGuide(int guidePos = -1); void slotDeleteAllGuides(); void editGuide(const GenTime oldPos, const GenTime pos, const QString &comment); void copyClip(); @@ -154,11 +167,9 @@ protected: virtual void wheelEvent(QWheelEvent * e); virtual QStringList mimeTypes() const; virtual Qt::DropActions supportedDropActions() const; - virtual void resizeEvent(QResizeEvent * event); private: - uint m_tracksHeight; - uint m_selectedTrack; + int m_tracksHeight; int m_projectDuration; int m_cursorPos; KdenliveDoc *m_document; @@ -180,7 +191,7 @@ private: QPoint m_clickEvent; QList m_searchPoints; QList m_guides; - void updateSnapPoints(AbstractClipItem *selected); + void updateSnapPoints(AbstractClipItem *selected, QList offsetList = QList (), bool skipSelectedItems = false); ClipItem *getClipItemAt(int pos, int track); ClipItem *getClipItemAt(GenTime pos, int track); ClipItem *getClipItemAtEnd(GenTime pos, int track); @@ -192,15 +203,21 @@ private: void checkScrolling(); /** Should we auto scroll while playing (keep in sync with KdenliveSettings::autoscroll() */ bool m_autoScroll; - void displayContextMenu(QPoint pos, AbstractClipItem *clip = NULL); + void displayContextMenu(QPoint pos, AbstractClipItem *clip, AbstractGroupItem *group); QMenu *m_timelineContextMenu; QMenu *m_timelineContextClipMenu; QMenu *m_timelineContextTransitionMenu; QAction *m_autoTransition; + QAction *m_changeSpeedAction; + QAction *m_pasteEffectsAction; + QAction *m_ungroupAction; + QAction *m_editGuide; + QAction *m_deleteGuide; + QActionGroup *m_clipTypeGroup; QTimer m_scrollTimer; int m_scrollOffset; + bool m_clipDrag; - QList m_searchStrings; int m_findIndex; PROJECTTOOL m_tool; QCursor m_razorCursor; @@ -222,12 +239,19 @@ private: ClipItem *getMainActiveClip() const; bool insertPossible(AbstractGroupItem *group, const QPoint &pos) const; void resetSelectionGroup(bool selectItems = true); - void groupSelectedItems(bool force = false); + void groupSelectedItems(bool force = false, bool createNewGroup = false); + /** Get available space for clip move (min and max free positions) */ + void getClipAvailableSpace(AbstractClipItem *item, GenTime &minimum, GenTime &maximum); + /** Get available space for transition move (min and max free positions) */ + void getTransitionAvailableSpace(AbstractClipItem *item, GenTime &minimum, GenTime &maximum); + void updateClipTypeActions(ClipItem *clip); private slots: void slotRefreshGuides(); void slotEnableRefresh(); void slotCheckMouseScrolling(); + void slotEditTimeLineGuide(); + void slotDeleteTimeLineGuide(); signals: void cursorMoved(int, int); @@ -240,6 +264,7 @@ signals: void trackHeightChanged(); void displayMessage(const QString, MessageType); void showClipFrame(DocClipBase *, const int); + void doTrackLock(int, bool); }; #endif