X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fabstractclipitem.h;h=1420788ed928901364fab1a84d6d95bb8b65d756;hb=c3302003093710ee247ad84c0fe2ef3c579d417f;hp=7b7d60e8e2430210938e9a768d817433581eaf76;hpb=4aa4301ad327749a5a1eda6a2c9bb962e6a144e7;p=kdenlive diff --git a/src/abstractclipitem.h b/src/abstractclipitem.h index 7b7d60e8..1420788e 100644 --- a/src/abstractclipitem.h +++ b/src/abstractclipitem.h @@ -22,56 +22,115 @@ #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 ; + virtual int defaultZValue() const ; virtual int track() const ; virtual GenTime cropStart() const ; - virtual void resizeStart(int posx); - virtual void resizeEnd(int posx, bool updateKeyFrames = true); - virtual GenTime duration() const; + virtual GenTime cropDuration() const ; + /** @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 setMaxDuration(const GenTime &max); + 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: - int m_track; + ItemInfo m_info; + /** 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_cropStart; + GenTime m_cropDuration; + GenTime m_startPos;*/ GenTime m_maxDuration; - QMap m_keyframes; + 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; - QPainterPath upperRectPart(QRectF); - QPainterPath lowerRectPart(QRectF); - QRect visibleRect(); - void drawKeyFrames(QPainter *painter, QRectF exposedRect); - int mouseOverKeyFrames(QPointF pos); + /** @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); + void mousePressEvent(QGraphicsSceneMouseEvent * event); + }; #endif