X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Ftransition.h;h=90e690e4ea3e5c928bdb7673aa71e0c82474f400;hb=4ae3260592acc87712db77b7d3fe0cc2be7d76bc;hp=f5f1ba755c493296cdc3aefe652fc8affefef67e;hpb=9628108325c436f9abcee1c1dd03ca32d45f8c8f;p=kdenlive diff --git a/src/transition.h b/src/transition.h index f5f1ba75..90e690e4 100644 --- a/src/transition.h +++ b/src/transition.h @@ -15,6 +15,12 @@ * * ***************************************************************************/ +/** + * @class Transition + * @author Jean-Baptiste Mardelle + * @brief Describes a transition with a name, parameters, keyframes, etc. + */ + #ifndef TRANSITION_H #define TRANSITION_H @@ -28,74 +34,69 @@ #include "definitions.h" #include "abstractclipitem.h" - -/**Describes a Transition, with a name, parameters keyframes, etc. - *@author Jean-Baptiste Mardelle - */ - class ClipItem; -class Transition : public AbstractClipItem { +class Transition : public AbstractClipItem +{ Q_OBJECT public: - Transition(const ItemInfo info, int transitiontrack, double fps, QDomElement params = QDomElement(), bool automaticTransition = false); + Transition(const ItemInfo &info, int transitiontrack, double fps, const QDomElement ¶ms = QDomElement(), bool automaticTransition = false); virtual ~Transition(); virtual void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget); virtual int type() const; - /** Returns an XML representation of this transition. */ + + /** @brief Returns an XML representation of this transition. */ QDomElement toXML(); - /** Return the track number of transition in the playlist*/ + /** @brief Returns the track number of the transition in the playlist. */ int transitionEndTrack() const; - bool hasClip(const ClipItem * clip) const; - bool belongsToClip(const ClipItem * clip) const; - bool invertedTransition() const; - QString transitionName() const; QString transitionTag() const; - OPERATIONTYPE operationMode(QPointF pos); + QStringList transitionInfo() const; + OPERATIONTYPE operationMode(const QPointF &pos); + static int itemHeight(); + static int itemOffset(); //const QMap < QString, QString > transitionParameters() const; - void setTransitionParameters(const QDomElement params); - void setTransitionDirection(bool inv); + void setTransitionParameters(const QDomElement ¶ms); void setTransitionTrack(int track); - QPixmap transitionPixmap() const; - //Transition *reparent(ClipItem * clip); - bool isValid() const; - /** Transition should be linked to another track */ + + /** @brief Links the transition to another track. + * + * This happens only if the current track is not forced. */ void updateTransitionEndTrack(int newtrack); void setForcedTrack(bool force, int track); bool forcedTrack() const; - const ClipItem *referencedClip() const; Transition *clone(); bool isAutomatic() const; void setAutomatic(bool automatic); bool hasGeometry(); + int defaultZValue() const; + /** @brief When a transition is resized, check if keyframes are out of the transition and fix if necessary. + * @param oldEnd the previous transition end, so that when we expand the transition, if there is a keyframe at end we move it + */ + bool updateKeyframes(int oldEnd); protected: virtual QVariant itemChange(GraphicsItemChange change, const QVariant &value); private: - bool m_singleClip; QString m_name; bool m_forceTransitionTrack; - /** true if the transition was added automatically and should be moved with its clip */ + /** @brief True if the transition is attached to its clip. */ bool m_automaticTransition; - /** contains the transition parameters */ + + /** @brief Contains the transition parameters. */ QDomElement m_parameters; - /** The clip to which the transition is attached */ - ClipItem *m_referenceClip; - /** The 2nd clip to which the transition is attached */ - ClipItem *m_secondClip; int m_transitionTrack; - /** Return the display name for a transition type */ + /** @brief Returns the display name for a transition type. */ QString getTransitionName(const TRANSITIONTYPE & type); - /** Return the transition type for a given name */ + /** @brief Returns the transition type for a given name. */ TRANSITIONTYPE getTransitionForName(const QString & type); };