X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fdocclipbase.h;h=a690377a998e76fd63636f39a6b6b14516fe8f72;hb=cd85961a9520f2f3c909e889dacd8de539468b89;hp=693d8caa7b04a86fd6b06a2db59bc8600932b933;hpb=f46ee295b40e18066ed4220e3d7d351fd77f281c;p=kdenlive diff --git a/src/docclipbase.h b/src/docclipbase.h index 693d8caa..a690377a 100644 --- a/src/docclipbase.h +++ b/src/docclipbase.h @@ -28,7 +28,6 @@ #include #include -#include #include "gentime.h" #include "definitions.h" @@ -43,60 +42,46 @@ class KdenliveDoc; class KThumb; class ClipManager; -class CommentedTime { -public: - CommentedTime(): t(GenTime(0)) {} - CommentedTime(const GenTime time, QString comment) - : t(time), c(comment) { } - - QString comment() const { - return (c.isEmpty() ? i18n("Marker") : c); - } - GenTime time() const { - return t; - } - void setComment(QString comm) { - c = comm; - } -private: - GenTime t; - QString c; +namespace Mlt { +class Producer; }; 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. */ - DocClipBase(ClipManager *clipManager, QDomElement xml, uint id); - DocClipBase(const DocClipBase& clip); - DocClipBase & operator=(const DocClipBase & clip); + DocClipBase(ClipManager *clipManager, QDomElement xml, const QString &id); +// 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; - /** Sets the description for this clip. */ - void setDescription(const QString & descripton); - /** Returns the description of this clip. */ - const QString & description() const; + const QString description() const; + /** Does this clip need a transparent background (e.g. for titles). */ + bool isTransparent() const; + + /** Returns any property of this clip. */ + const QString getProperty(const QString prop) const; + void setProperty(const QString &key, const QString &value); + void clearProperty(const QString &key); /** Returns the internal unique id of the clip. */ - uint getId() const; - void setId(const uint &newId); + const QString &getId() const; + void setId(const QString &newId); //KThumb *thumbCreator; bool audioThumbCreated() const; + /*void getClipMainThumb();*/ /** returns the duration of this clip */ const GenTime & duration() const; + const GenTime &maxDuration() const; /** returns the duration of this clip */ void setDuration(GenTime dur); @@ -122,34 +107,14 @@ Q_OBJECT public: return false; } - /*virtual DocClipAVFile *toDocClipAVFile() { - return 0; - } - - virtual DocClipTextFile *toDocClipTextFile() { - return 0; - } - - virtual bool isDocClipTextFile() const { - return false; - } - - virtual bool isDocClipVirtual() const { - return false; - } - - virtual DocClipVirtual *toDocClipVirtual() { - return 0; - }*/ + void setProducer(Mlt::Producer *producer); + Mlt::Producer *producer(int track = -1); /** Returns true if this clip is a project clip, false otherwise. Overridden in DocClipProject, * where it returns true. */ bool isProjectClip() const { return false; } - // Appends scene times for this clip to the passed vector. - /* virtual void populateSceneTimes(QList < GenTime > - &toPopulate) const = 0;*/ /** Reads in the element structure and creates a clip out of it.*/ // Returns an XML document that describes part of the current scene. @@ -157,7 +122,6 @@ Q_OBJECT public: const GenTime & endTime) const; /** returns a QString containing all of the XML data required to recreate this clip. */ QDomElement toXML() const; - QDomDocument generateSceneList(bool addProducers = true, bool rendering = false) const; /** Returns true if the xml passed matches the values in this clip */ bool matchesXML(const QDomElement & element) const; @@ -195,28 +159,32 @@ Q_OBJECT public: /** format is frame -> channel ->bytes */ QMap > audioFrameChache; - /** Clip is ready to get thumbs */ - void slotRequestAudioThumbs(); /** Free cache data */ void slotClearAudioCache(); - /** puts the clip in a group (used for folder grouping) */ - void setGroup(const QString name, const QString id); - + void askForAudioThumbs(); + QString getClipHash() const; + void refreshThumbUrl(); + const char *producerProperty(const char *name) const; + void setProducerProperty(const char *name, const char *data); + void deleteProducers(); + + /** Set default play zone for clip monitor */ + void setZone(QPoint zone); + /** Get default play zone for clip monitor */ + QPoint zone() const; 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; 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; - QDomElement m_xml; /** A thumbnail for this clip */ QPixmap m_thumbnail; @@ -227,17 +195,21 @@ private: // Private attributes bool m_audioThumbCreated; /** a unique numeric id */ - uint m_id; - uint m_projectThumbFrame; + QString m_id; 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, int data); + void getFileHash(const QString &url); public slots: void updateAudioThumbnail(QMap > data); - void slotGetAudioThumbs(); + bool slotGetAudioThumbs(); QList < CommentedTime > commentedSnapMarkers() const; void setSnapMarkers(QList < CommentedTime > markers); GenTime findNextSnapMarker(const GenTime & currTime); @@ -248,10 +220,13 @@ public slots: void addSnapMarker(const GenTime & time, QString comment); QList < GenTime > snapMarkers() const; QString markerComment(GenTime t); - void setProjectThumbFrame(const uint &ix); - uint getProjectThumbFrame() const; + void setClipThumbFrame(const uint &ix); + uint getClipThumbFrame() const; void setProperties(QMap properties); - QMap properties(); + void setMetadata(QMap properties); + QMap properties() const; + QMap metadata() const; + signals: void getAudioThumbs();