X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fcustomtrackview.h;h=c0aea67124c27def55c1ee52789e24e70ea0be0d;hb=a0dc08d2834e5112efba8ce7d2072791aed3d8b3;hp=7e8a67e00ff1684152bc34010b569ab6057b9b22;hpb=fe16b157c1f157d522d401620b73f7ec875dc64e;p=kdenlive diff --git a/src/customtrackview.h b/src/customtrackview.h index 7e8a67e0..c0aea671 100644 --- a/src/customtrackview.h +++ b/src/customtrackview.h @@ -31,12 +31,12 @@ #include "docclipbase.h" #include "guide.h" #include "effectslist.h" +#include "customtrackscene.h" class ClipItem; class AbstractClipItem; class AbstractGroupItem; class Transition; -class CustomTrackScene; class CustomTrackView : public QGraphicsView { @@ -54,37 +54,37 @@ public: void changeTrack(int ix, TrackInfo type); int cursorPos(); void checkAutoScroll(); - void moveClip(const ItemInfo start, const ItemInfo end); + void moveClip(const ItemInfo start, const ItemInfo end, bool refresh); void moveGroup(QList startClip, QList startTransition, const GenTime offset, const int trackOffset, bool reverseMove = false); /** move transition, startPos = (old start, old end), endPos = (new start, new end) */ - void moveTransition(const ItemInfo start, const ItemInfo end); - 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 moveTransition(const ItemInfo start, const ItemInfo end, bool m_refresh); + void resizeClip(const ItemInfo start, const ItemInfo end, bool dontWorry = false); + void addClip(QDomElement xml, const QString &clipId, ItemInfo info, EffectsList list = EffectsList(), bool overwrite = false, bool push = false, bool refresh = true); + void deleteClip(ItemInfo info, bool refresh = true); 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); + void updateEffect(int track, GenTime pos, QDomElement insertedEffect, 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 addTransition(ItemInfo transitionInfo, int endTrack, QDomElement params, bool refresh); + void deleteTransition(ItemInfo transitionInfo, int endTrack, QDomElement params, bool refresh); void updateTransition(int track, GenTime pos, QDomElement oldTransition, QDomElement transition, bool updateTransitionWidget); void moveTransition(GenTime oldpos, GenTime newpos); void activateMonitor(); int duration() const; void deleteSelectedClips(); void cutSelectedClips(); - void setContextMenu(QMenu *timeline, QMenu *clip, QMenu *transition, QActionGroup *clipTypeGroup); + void setContextMenu(QMenu *timeline, QMenu *clip, QMenu *transition, QActionGroup *clipTypeGroup, QMenu *markermenu); void checkTrackHeight(); //QList tracksList() const; void setTool(PROJECTTOOL tool); - void cutClip(ItemInfo info, GenTime cutTime, bool cut); + ClipItem *cutClip(ItemInfo info, GenTime cutTime, bool cut, bool execute = true); void slotSeekToPreviousSnap(); void slotSeekToNextSnap(); double getSnapPointForPos(double pos); @@ -96,7 +96,7 @@ public: void clipStart(); void clipEnd(); void changeClipSpeed(); - void doChangeClipSpeed(ItemInfo info, const double speed, const double oldspeed, const QString &id); + void doChangeClipSpeed(ItemInfo info, ItemInfo speedIndependantInfo, const double speed, const double oldspeed, int strobe, const QString &id); void setDocumentModified(); void setInPoint(); void setOutPoint(); @@ -122,12 +122,21 @@ public: void doChangeClipType(const GenTime &pos, int track, bool videoOnly, bool audioOnly); int hasGuide(int pos, int offset); void reloadTransitionLumas(); + void updateProjectFps(); + double fps() const; + int selectedTrack() const; + void selectClip(bool add, bool group = false); + void selectTransition(bool add, bool group = false); + QStringList extractTransitionsLumas(); + void setEditMode(EDITMODE mode); + void insertClipCut(DocClipBase *clip, int in, int out); + void clearSelection(); public slots: void setCursorPos(int pos, bool seek = true); void moveCursorPos(int delta); void updateCursorPos(); - void slotDeleteEffect(ClipItem *clip, QDomElement effect); + void slotDeleteEffect(ClipItem *clip, QDomElement effect, bool affectGroup = true); void slotChangeEffectState(ClipItem *clip, int effectPos, bool disable); void slotChangeEffectPosition(ClipItem *clip, int currentPos, int newPos); void slotUpdateClipEffect(ClipItem *clip, QDomElement oldeffect, QDomElement effect, int ix); @@ -139,7 +148,7 @@ public slots: void slotSwitchTrackAudio(int ix); void slotSwitchTrackVideo(int ix); void slotSwitchTrackLock(int ix); - void slotUpdateClip(const QString &clipId); + void slotUpdateClip(const QString &clipId, bool reload = true); void slotAddClipMarker(const QString &id, GenTime t, QString c); bool addGuide(const GenTime pos, const QString &comment); void slotAddGuide(); @@ -157,6 +166,10 @@ public slots: void slotDeleteTrack(int ix); void slotChangeTrack(int ix); void clipNameChanged(const QString id, const QString name); + void slotTrackUp(); + void slotTrackDown(); + void slotSelectTrack(int ix); + void insertZoneOverwrite(QStringList data, int in); protected: virtual void drawBackground(QPainter * painter, const QRectF & rect); @@ -166,6 +179,7 @@ protected: virtual void dragLeaveEvent(QDragLeaveEvent * event); virtual void dropEvent(QDropEvent * event); virtual void wheelEvent(QWheelEvent * e); + virtual void keyPressEvent(QKeyEvent * event); virtual QStringList mimeTypes() const; virtual Qt::DropActions supportedDropActions() const; @@ -208,14 +222,15 @@ private: QMenu *m_timelineContextMenu; QMenu *m_timelineContextClipMenu; QMenu *m_timelineContextTransitionMenu; + QMenu *m_markerMenu; QAction *m_autoTransition; - QAction *m_changeSpeedAction; 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; @@ -229,16 +244,20 @@ private: QPoint m_menuPosition; bool m_blockRefresh; AbstractGroupItem *m_selectionGroup; + QList m_waitingThumbs; + int m_selectedTrack; + int m_spacerOffset; /** 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 updatePositionEffects(ClipItem * item, ItemInfo info); + bool insertDropClips(const QMimeData *data, const QPoint pos); bool canBePastedTo(ItemInfo info, int type) const; + bool canBePastedTo(QList infoList, int type) const; bool canBePasted(QList items, GenTime offset, int trackOffset) const; bool canBeMoved(QList items, GenTime offset, int trackOffset) const; ClipItem *getClipUnderCursor() const; - ClipItem *getMainActiveClip() const; - bool insertPossible(AbstractGroupItem *group, const QPoint &pos) const; + AbstractClipItem *getMainActiveClip() const; void resetSelectionGroup(bool selectItems = true); void groupSelectedItems(bool force = false, bool createNewGroup = false); /** Get available space for clip move (min and max free positions) */ @@ -246,6 +265,15 @@ private: /** 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); + /** Selects all items in the scene rect, and sets ok to false if a group going over several tracks is found in it */ + QList checkForGroups(const QRectF &rect, bool *ok); + /** Adjust clips under another one when working in overwrite mode */ + void adjustTimelineClips(EDITMODE mode, ClipItem *item, ItemInfo posinfo, QUndoCommand *command); + void adjustTimelineTransitions(EDITMODE mode, Transition *item, QUndoCommand *command); + /** Adjust keyframes when pasted to another clip */ + void adjustKeyfames(GenTime oldstart, GenTime newstart, GenTime duration, QDomElement xml); private slots: void slotRefreshGuides(); @@ -253,6 +281,9 @@ private slots: void slotCheckMouseScrolling(); void slotEditTimeLineGuide(); void slotDeleteTimeLineGuide(); + void slotFetchNextThumbs(); + void checkTrackSequence(int track); + void slotGoToMarker(QAction *action); signals: void cursorMoved(int, int); @@ -260,12 +291,16 @@ signals: void zoomOut(); void mousePosition(int); void clipItemSelected(ClipItem*, int ix = -1); - void transitionItemSelected(Transition*, QPoint p = QPoint(), bool update = false); + void transitionItemSelected(Transition*, int track = 0, QPoint p = QPoint(), bool update = false); void activateDocumentMonitor(); void trackHeightChanged(); + void tracksChanged(); void displayMessage(const QString, MessageType); - void showClipFrame(DocClipBase *, const int); + void showClipFrame(DocClipBase *, QPoint, const int); void doTrackLock(int, bool); + void updateClipMarkers(DocClipBase *); + void updateTrackHeaders(); + void playMonitor(); }; #endif