X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fcustomtrackview.h;h=30142581c4dd6fbdd3850fa2d627a8c2e5066082;hb=4597bc7d1f0cc45b08f9d70ab661eff995e6a127;hp=790b9a2eb14025cfd807d0ec4dfcdf7ac3a188db;hpb=8bc8742e845c95035f09b5305183e1a4ac962bb9;p=kdenlive diff --git a/src/customtrackview.h b/src/customtrackview.h index 790b9a2e..30142581 100644 --- a/src/customtrackview.h +++ b/src/customtrackview.h @@ -25,26 +25,29 @@ #include #include #include - -#include +#include #include "kdenlivedoc.h" #include "docclipbase.h" #include "guide.h" +#include "effectslist.h" class ClipItem; class AbstractClipItem; +class AbstractGroupItem; class Transition; +class CustomTrackScene; class CustomTrackView : public QGraphicsView { Q_OBJECT public: - CustomTrackView(KdenliveDoc *doc, QGraphicsScene * projectscene, QWidget *parent = 0); + CustomTrackView(KdenliveDoc *doc, CustomTrackScene* projectscene, QWidget *parent = 0); virtual ~ CustomTrackView(); virtual void mousePressEvent(QMouseEvent * event); virtual void mouseReleaseEvent(QMouseEvent * event); virtual void mouseMoveEvent(QMouseEvent * event); + virtual void mouseDoubleClickEvent(QMouseEvent *event); void addTrack(TrackInfo type); void removeTrack(); int cursorPos(); @@ -53,18 +56,19 @@ public: /** 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, int clipId, ItemInfo info); + void addClip(QDomElement xml, const QString &clipId, ItemInfo info, EffectsList list = EffectsList()); void deleteClip(ItemInfo info); void slotAddClipMarker(); void slotEditClipMarker(); void slotDeleteClipMarker(); - void addMarker(const int id, const GenTime &pos, const QString comment); + void slotDeleteAllClipMarkers(); + void addMarker(const QString &id, const GenTime &pos, const QString comment); void setScale(double scaleFactor); - void deleteClip(int clipId); + 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); + void updateEffect(int track, GenTime pos, QDomElement effect, int ix); 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); @@ -82,16 +86,27 @@ public: void slotSeekToPreviousSnap(); void slotSeekToNextSnap(); double getSnapPointForPos(double pos); - QDomElement xmlInfo(); + void editKeyFrame(const GenTime pos, const int track, const int index, const QString keyframes); + bool findString(const QString &text); + bool findNextString(const QString &text); + void initSearchStrings(); + void clearSearchStrings(); + void clipStart(); + void clipEnd(); + void changeClipSpeed(); + void doChangeClipSpeed(ItemInfo info, const double speed, const double oldspeed, const QString &id); + void setDocumentModified(); + void setInPoint(); + void setOutPoint(); public slots: void setCursorPos(int pos, bool seek = true); void moveCursorPos(int delta); void updateCursorPos(); void slotDeleteEffect(ClipItem *clip, QDomElement effect); - void slotChangeEffectState(ClipItem *clip, QDomElement effect, bool disable); + void slotChangeEffectState(ClipItem *clip, int effectPos, bool disable); void slotChangeEffectPosition(ClipItem *clip, int currentPos, int newPos); - void slotUpdateClipEffect(ClipItem *clip, QDomElement oldeffect, QDomElement effect); + void slotUpdateClipEffect(ClipItem *clip, QDomElement oldeffect, QDomElement effect, int ix); void slotRefreshEffects(ClipItem *clip); void setDuration(int duration); void slotAddTransition(ClipItem* clip, ItemInfo transitionInfo, int endTrack, QDomElement transition = QDomElement()); @@ -99,12 +114,19 @@ public slots: void slotTransitionUpdated(Transition *, QDomElement); void slotSwitchTrackAudio(int ix); void slotSwitchTrackVideo(int ix); - void slotUpdateClip(int clipId); - void slotAddClipMarker(int id, GenTime t, QString c); - void addGuide(const GenTime pos, const QString &comment); + 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 slotDeleteAllGuides(); void editGuide(const GenTime oldPos, const GenTime pos, const QString &comment); + void copyClip(); + void pasteClip(); + void pasteClipEffects(); + void slotUpdateAllThumbs(); protected: virtual void drawBackground(QPainter * painter, const QRectF & rect); @@ -120,27 +142,27 @@ protected: private: uint m_tracksHeight; + uint m_selectedTrack; int m_projectDuration; int m_cursorPos; - ClipItem *m_dropItem; KdenliveDoc *m_document; - void addItem(DocClipBase *clip, QPoint pos); + CustomTrackScene *m_scene; QGraphicsLineItem *m_cursorLine; ItemInfo m_dragItemInfo; + ItemInfo m_selectionGroupInfo; OPERATIONTYPE m_operationMode; OPERATIONTYPE m_moveOpMode; AbstractClipItem *m_dragItem; Guide *m_dragGuide; - KUndoStack *m_commandStack; + QUndoStack *m_commandStack; QGraphicsItem *m_visualTip; QGraphicsItemAnimation *m_animation; QTimeLine *m_animationTimer; QColor m_tipColor; QPen m_tipPen; - double m_scale; QPoint m_clickPoint; QPoint m_clickEvent; - QList m_snapPoints; + QList m_searchPoints; QList m_guides; void updateSnapPoints(AbstractClipItem *selected); ClipItem *getClipItemAt(int pos, int track); @@ -154,22 +176,44 @@ private: QMenu *m_timelineContextMenu; QMenu *m_timelineContextClipMenu; QMenu *m_timelineContextTransitionMenu; - QList m_tracksList; + + QList m_searchStrings; + int m_findIndex; PROJECTTOOL m_tool; QCursor m_razorCursor; + /** 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); void updateClipFade(ClipItem * item, bool updateFadeOut = false); + 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; + ClipItem *getClipUnderCursor() const; + ClipItem *getMainActiveClip() const; + ClipItem *getActiveClipUnderCursor() const; + +private slots: + void slotRefreshGuides(); + void slotEnableRefresh(); signals: void cursorMoved(int, int); void zoomIn(); void zoomOut(); void mousePosition(int); - void clipItemSelected(ClipItem*); + void clipItemSelected(ClipItem*, int ix = -1); void transitionItemSelected(Transition*); void activateDocumentMonitor(); void trackHeightChanged(); + void displayMessage(const QString, MessageType); + void showClipFrame(DocClipBase *, const int); }; #endif