X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fdocclipbase.h;h=f59df01f81a665fb081eff7433064a71754e72dd;hb=c3302003093710ee247ad84c0fe2ef3c579d417f;hp=e6e722c25447d1a3b57d80b8d2c53423e908c281;hpb=71e41ad0c197e2e2eb033dff7800427f64d3428f;p=kdenlive diff --git a/src/docclipbase.h b/src/docclipbase.h index e6e722c2..f59df01f 100644 --- a/src/docclipbase.h +++ b/src/docclipbase.h @@ -35,19 +35,15 @@ #include "definitions.h" /* -class DocTrackBase; class DocClipAVFile; -class DocClipTextFile; -class DocClipVirtual; class EffectDescriptionList;*/ -class KdenliveDoc; class KThumb; class ClipManager; namespace Mlt { class Producer; -}; +} struct CutZoneInfo { QPoint zone; @@ -57,7 +53,8 @@ struct CutZoneInfo { class DocClipBase: public QObject { -Q_OBJECT public: +Q_OBJECT +public: /** this enum determines the types of "feed" available within this clip. types must be non-exclusive * - e.g. if you can have audio and video separately, it should be possible to combin the two, as is * done here. If a new clip type is added then it should be possible to combine it with both audio @@ -92,7 +89,7 @@ Q_OBJECT public: const GenTime & duration() const; const GenTime maxDuration() const; /** returns the duration of this clip */ - void setDuration(GenTime dur); + void setDuration(const GenTime &dur); /** returns clip type (audio, text, image,...) */ const CLIPTYPE & clipType() const; @@ -175,7 +172,7 @@ Q_OBJECT public: void deleteProducers(); /** Set default play zone for clip monitor */ - void setZone(QPoint zone); + void setZone(const QPoint &zone); /** Get default play zone for clip monitor */ QPoint zone() const; @@ -184,11 +181,11 @@ Q_OBJECT public: void setValid(); static QString getHash(const QString &path); - void addCutZone(int in, int out, QString desc = QString()); - bool hasCutZone(QPoint p) const; + void addCutZone(int in, int out, const QString &desc = QString()); + bool hasCutZone(const QPoint &p) const; void removeCutZone(int in, int out); QList cutZones() const; - void updateCutZone(int oldin, int oldout, int in, int out, QString desc = QString()); + void updateCutZone(int oldin, int oldout, int in, int out, const QString &desc = QString()); bool hasVideoCodec(const QString &codec) const; bool hasAudioCodec(const QString &codec) const; @@ -200,12 +197,19 @@ Q_OBJECT public: void cleanupProducers(); bool isClean() const; bool getAudioThumbs(); - void setAnalysisData(const QString &name, const QString &data); + void setAnalysisData(const QString &name, const QString &data, int offset = 0); QMap analysisData() const; int lastSeekPosition; /** Cache for every audio Frame with 10 Bytes */ /** format is frame -> channel ->bytes */ QMap > audioFrameCache; + /** Returns all current properties for this clip */ + QMap properties() const; + /** Return the current values for a set of properties */ + QMap currentProperties(const QMap &props); + QMap metadata() const; + /** @brief Returns a short info string about the clip to display in tooltip */ + const QString shortInfo() const; private: // Private attributes /** The number of times this clip is used in the project - the number of references to this clip @@ -236,7 +240,7 @@ private: // Private attributes /** Holds clip infos like fps, size,... */ QMap m_properties; /** Holds clip metadata like author, copyright,... */ - QMap m_metadata; + QMap m_metadata; /** Holds clip analysis data that can be used later to create markers or keyframes */ QMap m_analysisdata; @@ -256,6 +260,8 @@ private: // Private attributes void adjustProducerProperties(Mlt::Producer *prod, const QString &id, bool mute, bool blind); /** @brief Create another instance of a producer. */ Mlt::Producer *cloneProducer(Mlt::Producer *source); + /** @brief Offset all keyframes of a geometry. */ + const QString geometryWithOffset(const QString &data, int offset); public slots: @@ -265,21 +271,16 @@ public slots: GenTime findPreviousSnapMarker(const GenTime & currTime); GenTime hasSnapMarkers(const GenTime & time); QString deleteSnapMarker(const GenTime & time); - void editSnapMarker(const GenTime & time, QString comment); - void addSnapMarker(const CommentedTime marker); + void editSnapMarker(const GenTime & time, const QString &comment); + void addSnapMarker(const CommentedTime &marker); QList < GenTime > snapMarkers() const; - QString markerComment(GenTime t) const; - CommentedTime markerAt(GenTime t) const; + QString markerComment(const GenTime &t) const; + CommentedTime markerAt(const GenTime &t) const; void setClipThumbFrame(const uint &ix); uint getClipThumbFrame() const; - void setProperties(QMap properties); - void setMetadata(QMap properties); - /** Returns all current properties for this clip */ - QMap properties() const; - /** Return the current values for a set of properties */ - QMap currentProperties(QMap props); - QMap metadata() const; - void slotExtractImage(QList frames); + void setProperties(QMap properties); + void setMetadata(const QMap &properties, const QString &tool = QString()); + void slotExtractImage(const QList &frames); signals: void gotAudioData();