X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fabstractclipitem.h;h=1420788ed928901364fab1a84d6d95bb8b65d756;hb=c3302003093710ee247ad84c0fe2ef3c579d417f;hp=09fd98d4209c98d036fba13408ddcb6d6dfe2e68;hpb=d7a6993a720e685d921bbf9d715789307e79effe;p=kdenlive diff --git a/src/abstractclipitem.h b/src/abstractclipitem.h index 09fd98d4..1420788e 100644 --- a/src/abstractclipitem.h +++ b/src/abstractclipitem.h @@ -22,32 +22,52 @@ #define ABSTRACTCLIPITEM #include +#include + +#if QT_VERSION >= 0x040600 +#include +#endif + #include "definitions.h" #include "gentime.h" class CustomTrackScene; class QGraphicsSceneMouseEvent; -class AbstractClipItem : public QObject , public QGraphicsRectItem +class AbstractClipItem : public QObject, public QGraphicsRectItem { Q_OBJECT + Q_PROPERTY(QRectF rect READ rect WRITE setRect) + Q_PROPERTY(qreal opacity READ opacity WRITE setOpacity) + public: - AbstractClipItem(const ItemInfo info, const QRectF& rect, double fps); + AbstractClipItem(const ItemInfo &info, const QRectF& rect, double fps); + virtual ~ AbstractClipItem(); void updateSelectedKeyFrame(); - void updateKeyFramePos(const GenTime pos, const double value); - void addKeyFrame(const GenTime pos, const double value); + + /** @brief Move the selected keyframe (does not influence the effect, only the display in timeline). + * @param pos new Position + * @param value new Value */ + void updateKeyFramePos(const GenTime &pos, const double value); + int checkForSingleKeyframe(); + int addKeyFrame(const GenTime &pos, const double value); bool hasKeyFrames() const; + int editedKeyFramePos() const; int selectedKeyFramePos() const; double selectedKeyFrameValue() const; + double editedKeyFrameValue() const; double keyFrameFactor() const; + /** @brief Returns the number of keyframes the selected effect has. */ + int keyFrameNumber() const; ItemInfo info() const; CustomTrackScene* projectScene(); void updateRectGeometry(); void updateItem(); void setItemLocked(bool locked); bool isItemLocked() const; + void closeAnimation(); - virtual OPERATIONTYPE operationMode(QPointF pos) = 0; + virtual OPERATIONTYPE operationMode(const QPointF &pos) = 0; virtual GenTime startPos() const ; virtual void setTrack(int track); virtual GenTime endPos() const ; @@ -55,30 +75,62 @@ public: virtual int track() const ; virtual GenTime cropStart() const ; virtual GenTime cropDuration() const ; - virtual void resizeStart(int posx); - virtual void resizeEnd(int posx); + /** @brief Return the current item's height */ + static int itemHeight(); + /** @brief Return the current item's vertical offset + * For example transitions are drawn at 1/3 of track height */ + static int itemOffset(); + + /** @brief Resizes the clip from the start. + * @param posx Absolute position of new in point + * @param hasSizeLimit (optional) Whether the clip has a maximum size */ + virtual void resizeStart(int posx, bool hasSizeLimit = true, bool emitChange = true); + + /** @brief Resizes the clip from the end. + * @param posx Absolute position of new out point */ + virtual void resizeEnd(int posx, bool emitChange = true); virtual double fps() const; virtual void updateFps(double fps); virtual GenTime maxDuration() const; - virtual void setCropStart(GenTime pos); + virtual void setCropStart(const GenTime &pos); + /** @brief Set this clip as the main selected clip (or not). */ + void setMainSelectedClip(bool selected); + /** @brief Is this clip selected as the main clip. */ + bool isMainSelectedClip(); + protected: ItemInfo m_info; -// int m_track; + /** The position of the current keyframe when it has moved */ int m_editedKeyframe; + /** The position of the current keyframe before it was moved */ int m_selectedKeyframe; /* GenTime m_cropStart; GenTime m_cropDuration; GenTime m_startPos;*/ GenTime m_maxDuration; QMap m_keyframes; + /** @brief Strech factor so that keyframes display on the full clip height. */ double m_keyframeFactor; + /** @brief Offset factor so that keyframes minimum value are displaed at the bottom of the clip. */ + double m_keyframeOffset; + /** @brief Default reset value for keyframe. */ double m_keyframeDefault; + /** The (keyframe) parameter that is visible and editable in timeline (on the clip) */ + int m_visibleParam; double m_fps; - //QRect visibleRect(); - void drawKeyFrames(QPainter *painter, QRectF exposedRect); + /** @brief True if this is the last clip the user selected */ + bool m_isMainSelectedClip; + /** @brief Draw the keyframes of a clip + * @param painter The painter device for the clip + * @param limitedKeyFrames The keyframes can be of type "keyframe" or "simplekeyframe". In the + * "simplekeyframe" type, the effect always starts on clip start and ends on clip end. With the + * "keyframe" type, the effect starts on the first keyframe and ends on the last keyframe + */ + void drawKeyFrames(QPainter *painter, const QTransform &transformation, bool limitedKeyFrames); int mouseOverKeyFrames(QPointF pos, double maxOffset); - virtual void mousePressEvent(QGraphicsSceneMouseEvent * event); + void mousePressEvent(QGraphicsSceneMouseEvent * event); + }; #endif