X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fdocclipbase.h;h=60e1402baa9fd3d1c6ce3205e09a1625b451be04;hb=25a95ff4dba48d6a94c5c1d0d653617b1c327b90;hp=8e83242e9e43753d4ba81a32d969704a88aa017e;hpb=db3a514547826b7d83b336f0bd93eed7c25c6b3c;p=kdenlive diff --git a/src/docclipbase.h b/src/docclipbase.h index 8e83242e..60e1402b 100644 --- a/src/docclipbase.h +++ b/src/docclipbase.h @@ -42,15 +42,22 @@ class KdenliveDoc; class KThumb; class ClipManager; -namespace Mlt { +namespace Mlt +{ class Producer; }; +struct CutZoneInfo { + QPoint zone; + QString description; +}; + -class DocClipBase: public QObject { +class DocClipBase: public QObject +{ 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 seperately, it should be possible to combin the two, as is + * - 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 * and video. */ @@ -58,11 +65,8 @@ Q_OBJECT public: // DocClipBase & operator=(const DocClipBase & clip); virtual ~ DocClipBase(); - /** sets the name of this clip. */ - void setName(const QString name); - /** returns the name of this clip. */ - const QString & name() const; + const QString name() const; /** Returns the description of this clip. */ const QString description() const; @@ -84,7 +88,7 @@ Q_OBJECT public: /** returns the duration of this clip */ const GenTime & duration() const; - const GenTime &maxDuration() const; + const GenTime maxDuration() const; /** returns the duration of this clip */ void setDuration(GenTime dur); @@ -110,8 +114,14 @@ Q_OBJECT public: return false; } - void setProducer(Mlt::Producer *producer); + /** Sets producers for the current clip (one for each track due to a limitation in MLT's track mixing */ + void setProducer(Mlt::Producer *producer, bool reset = false); + /** Retrieve a producer for a track */ Mlt::Producer *producer(int track = -1); + /** Retrieve the producer that shows only video */ + Mlt::Producer *videoProducer(); + /** Retrieve the producer that shows only audio */ + Mlt::Producer *audioProducer(int track); /** Returns true if this clip is a project clip, false otherwise. Overridden in DocClipProject, * where it returns true. */ @@ -142,7 +152,7 @@ Q_OBJECT public: bool hasFileSize() const; /** Returns the filesize, or 0 if there is no appropriate filesize. */ - uint fileSize() const; + qulonglong fileSize() const; /** Returns true if this clip refers to the clip passed in. A clip refers to another clip if * it uses it as part of it's own composition. */ @@ -157,25 +167,50 @@ Q_OBJECT public: /** Returns the thumbnail used by this clip */ const QPixmap & thumbnail() const; - static DocClipBase *createClip(KdenliveDoc *doc, const QDomElement & element); /** Cache for every audio Frame with 10 Bytes */ /** format is frame -> channel ->bytes */ - QMap > audioFrameChache; + QMap > m_audioFrameCache; /** Free cache data */ void slotClearAudioCache(); void askForAudioThumbs(); QString getClipHash() const; + void refreshThumbUrl(); + const char *producerProperty(const char *name) const; + void setProducerProperty(const char *name, const char *data); + void resetProducerProperty(const char *name); + void clearProducers(); + void deleteProducers(bool clearThumbCreator = true); + + /** Set default play zone for clip monitor */ + void setZone(QPoint zone); + /** Get default play zone for clip monitor */ + QPoint zone() const; + + /** Returns true is clip is missing but user wants to keep it as placeholder */ + bool isPlaceHolder() const; + void setValid(); + static QString getHash(const QString &path); + + void addCutZone(int in, int out, QString desc = QString()); + bool hasCutZone(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()); + + bool hasVideoCodec(const QString &codec) const; + bool hasAudioCodec(const QString &codec) const; + bool checkHash() const; + void setPlaceHolder(bool place); private: // Private attributes - /** The name of this clip */ - QString m_name; - /** A description of this clip */ - QString m_description; + /** The number of times this clip is used in the project - the number of references to this clip * that exist. */ uint m_refcount; QList m_baseTrackProducers; + QList m_audioTrackProducers; + Mlt::Producer *m_videoOnlyProducer; CLIPTYPE m_clipType; /** A list of snap markers; these markers are added to a clips snap-to points, and are displayed as necessary. */ @@ -191,21 +226,28 @@ private: // Private attributes /** a unique numeric id */ QString m_id; + + /** Wheter the clip is a placeholder (clip missing but user wants to see it) */ + bool m_placeHolder; + + QList m_cutZones; + void setAudioThumbCreated(bool isDone); /** Holds clip infos like fps, size,... */ QMap m_properties; + /** Holds clip metadata like author, copyright,... */ + QMap m_metadata; /** Create connections for audio thumbnails */ void slotCreateAudioTimer(); void slotRefreshProducer(); - void setProducerProperty(const char *name, const char *data); void setProducerProperty(const char *name, int data); - void getFileHash(const QString &url); + void setProducerProperty(const char *name, double data); + void getFileHash(const QString url); public slots: void updateAudioThumbnail(QMap > data); bool slotGetAudioThumbs(); QList < CommentedTime > commentedSnapMarkers() const; - void setSnapMarkers(QList < CommentedTime > markers); GenTime findNextSnapMarker(const GenTime & currTime); GenTime findPreviousSnapMarker(const GenTime & currTime); GenTime hasSnapMarkers(const GenTime & time); @@ -217,10 +259,12 @@ public slots: void setClipThumbFrame(const uint &ix); uint getClipThumbFrame() const; void setProperties(QMap properties); + void setMetadata(QMap properties); QMap properties() const; + QMap metadata() const; + signals: - void getAudioThumbs(); void gotAudioData(); };