X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fcustomtrackview.h;h=422b02a68cd74b2396206b3a0dd7167cb6903e14;hb=40d8c63ec12c38560be338806ca1ccd9a01ddc0d;hp=269b49debd38f8f8e5f09d8404bd5b03886b1413;hpb=c5e9fb057510f0595832ea3dad6e6ba96ea24eeb;p=kdenlive diff --git a/src/customtrackview.h b/src/customtrackview.h index 269b49de..422b02a6 100644 --- a/src/customtrackview.h +++ b/src/customtrackview.h @@ -48,8 +48,8 @@ public: virtual void mouseReleaseEvent(QMouseEvent * event); virtual void mouseMoveEvent(QMouseEvent * event); virtual void mouseDoubleClickEvent(QMouseEvent *event); - void addTrack(TrackInfo type); - void removeTrack(); + void addTrack(TrackInfo type, int ix = -1); + void removeTrack(int ix); int cursorPos(); void checkAutoScroll(); void moveClip(const ItemInfo start, const ItemInfo end); @@ -58,21 +58,19 @@ public: void resizeClip(const ItemInfo start, const ItemInfo end); void addClip(QDomElement xml, const QString &clipId, ItemInfo info, EffectsList list = EffectsList()); void deleteClip(ItemInfo info); - void slotAddClipMarker(); - void slotEditClipMarker(); - void slotDeleteClipMarker(); - void slotDeleteAllClipMarkers(); + 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 deleteClip(const QString &clipId); void slotAddEffect(QDomElement effect, GenTime pos, int track); 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); + void updateEffect(int track, GenTime pos, QDomElement effect, int ix, bool triggeredByUser = true); void moveEffect(int track, GenTime pos, int oldPos, int newPos); void addTransition(ItemInfo transitionInfo, int endTrack, QDomElement params); void deleteTransition(ItemInfo transitionInfo, int endTrack, QDomElement params); - void updateTransition(int track, GenTime pos, QDomElement oldTransition, QDomElement transition); + void updateTransition(int track, GenTime pos, QDomElement oldTransition, QDomElement transition, bool updateTransitionWidget); void moveTransition(GenTime oldpos, GenTime newpos); void activateMonitor(); int duration() const; @@ -80,7 +78,7 @@ public: void cutSelectedClips(); void setContextMenu(QMenu *timeline, QMenu *clip, QMenu *transition); void checkTrackHeight(); - QList tracksList() const; + //QList tracksList() const; void setTool(PROJECTTOOL tool); void cutClip(ItemInfo info, GenTime cutTime, bool cut); void slotSeekToPreviousSnap(); @@ -94,10 +92,16 @@ public: void clipStart(); void clipEnd(); void changeClipSpeed(); - void doChangeClipSpeed(ItemInfo info, double speed, const QString &id); + void doChangeClipSpeed(ItemInfo info, const double speed, const double oldspeed, const QString &id); void setDocumentModified(); void setInPoint(); void setOutPoint(); + void slotInsertSpace(); + void slotRemoveSpace(); + void insertSpace(const GenTime &pos, int track, const GenTime duration, bool add); + ClipItem *getActiveClipUnderCursor(bool allowOutsideCursor = false) const; + void addTimelineTrack(int ix, TrackInfo trackinfo); + void deleteTimelineTrack(int ix, TrackInfo trackinfo); public slots: void setCursorPos(int pos, bool seek = true); @@ -112,6 +116,7 @@ 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 slotUpdateClip(const QString &clipId); @@ -127,6 +132,9 @@ public slots: void pasteClip(); void pasteClipEffects(); void slotUpdateAllThumbs(); + void slotCheckPositionScrolling(); + void slotInsertTrack(int ix); + void slotDeleteTrack(int ix); protected: virtual void drawBackground(QPainter * painter, const QRectF & rect); @@ -145,6 +153,7 @@ private: uint m_selectedTrack; int m_projectDuration; int m_cursorPos; + int m_spacerStart; KdenliveDoc *m_document; CustomTrackScene *m_scene; QGraphicsLineItem *m_cursorLine; @@ -176,18 +185,20 @@ private: QMenu *m_timelineContextMenu; QMenu *m_timelineContextClipMenu; QMenu *m_timelineContextTransitionMenu; + QTimer m_scrollTimer; + int m_scrollOffset; QList m_searchStrings; int m_findIndex; PROJECTTOOL m_tool; QCursor m_razorCursor; + QCursor m_spacerCursor; /** list containing items currently copied in the timeline */ QList m_copiedItems; /** Used to get the point in timeline where a context menu was opened */ QPoint m_menuPosition; bool m_blockRefresh; AbstractGroupItem *m_selectionGroup; - AbstractGroupItem *m_dropGroup; /** Get the index of the video track that is just below current track */ int getPreviousVideoTrack(int track); @@ -197,19 +208,21 @@ private: bool canBeMoved(QList items, GenTime offset, int trackOffset) const; ClipItem *getClipUnderCursor() const; ClipItem *getMainActiveClip() const; - ClipItem *getActiveClipUnderCursor() const; + bool insertPossible(AbstractGroupItem *group, const QPoint &pos) const; + void resetSelectionGroup(); private slots: void slotRefreshGuides(); void slotEnableRefresh(); + void slotCheckMouseScrolling(); signals: void cursorMoved(int, int); void zoomIn(); void zoomOut(); void mousePosition(int); - void clipItemSelected(ClipItem*); - void transitionItemSelected(Transition*); + void clipItemSelected(ClipItem*, int ix = -1); + void transitionItemSelected(Transition*, bool update = false); void activateDocumentMonitor(); void trackHeightChanged(); void displayMessage(const QString, MessageType);