X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fdocclipbase.h;h=fa363746de9081425d298039932d0360973276ab;hb=12bd13b246f3cf974339c619c62104ca10af3170;hp=95e0b6bf11ddaf038eb43c5f43bc12138f86ec27;hpb=ced15078727eb750fc6b3a6af574ed99409fc706;p=kdenlive diff --git a/src/docclipbase.h b/src/docclipbase.h index 95e0b6bf..fa363746 100644 --- a/src/docclipbase.h +++ b/src/docclipbase.h @@ -82,8 +82,8 @@ Q_OBJECT public: /** Returns the internal unique id of the clip. */ const QString &getId() const; - void setId(const QString &newId); + bool hasAudioThumb() const; //KThumb *thumbCreator; bool audioThumbCreated() const; /*void getClipMainThumb();*/ @@ -119,9 +119,11 @@ Q_OBJECT public: /** 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, bool readPropertiesFromProducer = false); /** Retrieve a producer for a track */ - Mlt::Producer *producer(int track = -1); + Mlt::Producer *getProducer(int track = -1); + /** Get a copy of the producer, for use in the clip monitor */ + Mlt::Producer *getCloneProducer(); /** Retrieve the producer that shows only video */ - Mlt::Producer *videoProducer(); + Mlt::Producer *videoProducer(int track); /** Retrieve the producer that shows only audio */ Mlt::Producer *audioProducer(int track); @@ -136,7 +138,7 @@ Q_OBJECT public: QDomDocument sceneToXML(const GenTime & startTime, const GenTime & endTime) const; /** returns a QString containing all of the XML data required to recreate this clip. */ - QDomElement toXML() const; + QDomElement toXML(bool hideTemporaryProperties = false) const; /** Returns true if the xml passed matches the values in this clip */ bool matchesXML(const QDomElement & element) const; @@ -160,28 +162,21 @@ Q_OBJECT public: * it uses it as part of it's own composition. */ bool referencesClip(DocClipBase * clip) const; - /** Sets the thumbnail to be used by this clip */ - void setThumbnail(const QPixmap & pixmap); - /** Returns the thumbnail producer used by this clip */ KThumb *thumbProducer(); - /** Returns the thumbnail used by this clip */ - const QPixmap & thumbnail() const; - /** Cache for every audio Frame with 10 Bytes */ /** format is frame -> channel ->bytes */ 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 deleteProducers(bool clearThumbCreator = true); + void deleteProducers(); /** Set default play zone for clip monitor */ void setZone(QPoint zone); @@ -203,7 +198,12 @@ Q_OBJECT public: bool hasAudioCodec(const QString &codec) const; bool checkHash() const; void setPlaceHolder(bool place); - QPixmap extractImage(int frame, int width, int height); + QImage extractImage(int frame, int width, int height); + void clearThumbProducer(); + void reloadThumbProducer(); + void cleanupProducers(); + bool isClean() const; + bool getAudioThumbs(); private: // Private attributes @@ -211,18 +211,15 @@ private: // Private attributes * that exist. */ uint m_refcount; QList m_baseTrackProducers; + QList m_videoTrackProducers; QList m_audioTrackProducers; - Mlt::Producer *m_videoOnlyProducer; + QList m_toDeleteProducers; CLIPTYPE m_clipType; /** A list of snap markers; these markers are added to a clips snap-to points, and are displayed as necessary. */ QList < CommentedTime > m_snapMarkers; - - /** A thumbnail for this clip */ - QPixmap m_thumbnail; GenTime m_duration; - QTimer *m_audioTimer; KThumb *m_thumbProd; bool m_audioThumbCreated; @@ -242,9 +239,12 @@ private: // Private attributes /** Try to make sure we don't delete a producer while using it */ QMutex m_producerMutex; + QMutex m_replaceMutex; + + /** @brief This timer will trigger creation of audio thumbnails. */ + QTimer m_audioTimer; /** Create connections for audio thumbnails */ - void slotCreateAudioTimer(); void slotRefreshProducer(); void setProducerProperty(const char *name, int data); void setProducerProperty(const char *name, double data); @@ -256,8 +256,7 @@ private: // Private attributes public slots: - void updateAudioThumbnail(QMap > data); - bool slotGetAudioThumbs(); + void updateAudioThumbnail(const audioByteArray& data); QList < CommentedTime > commentedSnapMarkers() const; GenTime findNextSnapMarker(const GenTime & currTime); GenTime findPreviousSnapMarker(const GenTime & currTime); @@ -271,16 +270,19 @@ public slots: 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(int frame, int frame2); + void slotExtractImage(QList frames); signals: void gotAudioData(); /** @brief Generate a proxy clip (lower resolution copy) named like the clip's hash. */ - void createProxy(const QString id); + void createProxy(const QString &id); /** @brief Abort creation of the proxy clip (lower resolution copy). */ - void abortProxy(const QString id, const QString proxyPath); + void abortProxy(const QString &id, const QString &proxyPath); }; #endif