X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fcustomtrackview.h;h=e878e5959c1d50f1cf4e6cf16c1194de06ba4423;hb=a23790875ee20326ba0fb9d30b7719979659c2cd;hp=9d6ef6cd95f63ce1cba321c07d1dc7ffeb859102;hpb=772db2edcfe36c7848d633b06a5d306a0dcb3783;p=kdenlive diff --git a/src/customtrackview.h b/src/customtrackview.h index 9d6ef6cd..e878e595 100644 --- a/src/customtrackview.h +++ b/src/customtrackview.h @@ -31,14 +31,15 @@ #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 { +class CustomTrackView : public QGraphicsView +{ Q_OBJECT public: @@ -53,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); + void setContextMenu(QMenu *timeline, QMenu *clip, QMenu *transition, QActionGroup *clipTypeGroup); 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); @@ -95,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(); @@ -110,6 +111,25 @@ public: 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(); + 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); + public slots: void setCursorPos(int pos, bool seek = true); @@ -127,13 +147,13 @@ 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(); 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(); @@ -145,6 +165,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); @@ -154,13 +178,12 @@ 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; - virtual void resizeEvent(QResizeEvent * event); private: - uint m_tracksHeight; - uint m_selectedTrack; + int m_tracksHeight; int m_projectDuration; int m_cursorPos; KdenliveDoc *m_document; @@ -187,24 +210,28 @@ private: ClipItem *getClipItemAt(GenTime pos, int track); ClipItem *getClipItemAtEnd(GenTime pos, int track); ClipItem *getClipItemAtStart(GenTime pos, int track); + Transition *getTransitionItemAt(int pos, int track); Transition *getTransitionItemAt(GenTime pos, int track); Transition *getTransitionItemAtEnd(GenTime pos, int track); Transition *getTransitionItemAtStart(GenTime pos, int track); 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; + QTimer m_thumbsTimer; int m_scrollOffset; bool m_clipDrag; - QList m_searchStrings; int m_findIndex; PROJECTTOOL m_tool; QCursor m_razorCursor; @@ -215,28 +242,42 @@ private: QPoint m_menuPosition; bool m_blockRefresh; AbstractGroupItem *m_selectionGroup; + QList m_waitingThumbs; + int m_selectedTrack; /** 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); + 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); + /** 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, QUndoCommand *command); + void adjustTimelineTransitions(EDITMODE mode, Transition *item, QUndoCommand *command); private slots: void slotRefreshGuides(); void slotEnableRefresh(); void slotCheckMouseScrolling(); + void slotEditTimeLineGuide(); + void slotDeleteTimeLineGuide(); + void slotFetchNextThumbs(); + void checkTrackSequence(int track); signals: void cursorMoved(int, int); @@ -244,12 +285,15 @@ 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 tracksChanged(); void displayMessage(const QString, MessageType); void showClipFrame(DocClipBase *, const int); void doTrackLock(int, bool); + void updateClipMarkers(DocClipBase *); + void updateTrackHeaders(); }; #endif