X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fcustomtrackview.h;h=4f23d5b7e048dcbeb3b3ab47f3412e9c1ac702bd;hb=4f2ff860ac2157cbc10dec34eafac61a41ffc0ce;hp=994b6ab73a53375b8b8462d155793b4688cdf8e6;hpb=89387739482ef7d5d303026a6f6ff5e1e0e1d16e;p=kdenlive diff --git a/src/customtrackview.h b/src/customtrackview.h index 994b6ab7..4f23d5b7 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: @@ -63,9 +64,10 @@ public: void slotDeleteClipMarker(const QString &comment, const QString &id, const GenTime &position); void slotDeleteAllClipMarkers(const QString &id); void addMarker(const QString &id, const GenTime &pos, const QString comment); - void setScale(double scaleFactor); + void setScale(double scaleFactor, double verticalScale); 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); @@ -94,18 +96,32 @@ public: void clipStart(); void clipEnd(); void changeClipSpeed(); - void doChangeClipSpeed(ItemInfo info, const double speed, const double oldspeed, const QString &id); + void doChangeClipSpeed(ItemInfo info, const double speed, const double oldspeed, int strobe, const QString &id); void setDocumentModified(); void setInPoint(); void setOutPoint(); void slotInsertSpace(); void slotRemoveSpace(); - void insertSpace(const GenTime &pos, int track, const GenTime duration); + void insertSpace(QList clipsToMove, QList transToMove, int track, const GenTime duration, const GenTime offset); ClipItem *getActiveClipUnderCursor(bool allowOutsideCursor = false) const; void deleteTimelineTrack(int ix, TrackInfo trackinfo); void changeTimelineTrack(int ix, TrackInfo trackinfo); void saveThumbnails(); 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); + void reloadTransitionLumas(); public slots: void setCursorPos(int pos, bool seek = true); @@ -120,16 +136,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(); @@ -140,6 +156,7 @@ public slots: void slotInsertTrack(int ix); void slotDeleteTrack(int ix); void slotChangeTrack(int ix); + void clipNameChanged(const QString id, const QString name); protected: virtual void drawBackground(QPainter * painter, const QRectF & rect); @@ -151,14 +168,11 @@ 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; - int m_spacerStart; KdenliveDoc *m_document; CustomTrackScene *m_scene; QGraphicsLineItem *m_cursorLine; @@ -178,7 +192,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); @@ -190,15 +204,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_pasteEffectsAction; + QAction *m_ungroupAction; + QAction *m_editGuide; + QAction *m_deleteGuide; + QActionGroup *m_clipTypeGroup; QTimer m_scrollTimer; + QTimer m_thumbsTimer; int m_scrollOffset; + bool m_clipDrag; - QList m_searchStrings; int m_findIndex; PROJECTTOOL m_tool; QCursor m_razorCursor; @@ -209,10 +229,11 @@ private: QPoint m_menuPosition; bool m_blockRefresh; AbstractGroupItem *m_selectionGroup; + QList m_waitingThumbs; /** Get the index of the video track that is just below current track */ int getPreviousVideoTrack(int track); - void updateClipFade(ClipItem * item, bool updateFadeOut = false); + void updateClipFade(ClipItem * item); bool canBePastedTo(ItemInfo info, int type) const; bool canBePasted(QList items, GenTime offset, int trackOffset) const; bool canBeMoved(QList items, GenTime offset, int trackOffset) const; @@ -220,12 +241,22 @@ private: ClipItem *getMainActiveClip() const; bool insertPossible(AbstractGroupItem *group, const QPoint &pos) const; void resetSelectionGroup(bool selectItems = true); - void groupSelectedItems(); + 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); + /** Whether an item can be moved to a new position without colliding with similar items */ + bool itemCollision(AbstractClipItem *item, ItemInfo newPos); private slots: void slotRefreshGuides(); void slotEnableRefresh(); void slotCheckMouseScrolling(); + void slotEditTimeLineGuide(); + void slotDeleteTimeLineGuide(); + void slotFetchNextThumbs(); signals: void cursorMoved(int, int); @@ -233,11 +264,12 @@ signals: void zoomOut(); void mousePosition(int); void clipItemSelected(ClipItem*, int ix = -1); - void transitionItemSelected(Transition*, bool update = false); + void transitionItemSelected(Transition*, int track = 0, QPoint p = QPoint(), bool update = false); void activateDocumentMonitor(); void trackHeightChanged(); void displayMessage(const QString, MessageType); void showClipFrame(DocClipBase *, const int); + void doTrackLock(int, bool); }; #endif