*@author Jason Wood
*/
-#include <qdom.h>
+#include <QtXml/qdom.h>
#include <QPixmap>
#include <QObject>
#include <QTimer>
#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;
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
/** 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();*/
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;
+ const ClipType & clipType() const;
/** set clip type (audio, text, image,...) */
- void setClipType(CLIPTYPE type);
+ void setClipType(ClipType type);
/** remove tmp file if the clip has one (for example text clips) */
void removeTmpFile() const;
void setProducer(Mlt::Producer *producer, bool reset = false, bool readPropertiesFromProducer = false);
/** Retrieve a producer for a track */
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);
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;
* 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<int, QMap<int, QByteArray> > m_audioFrameCache;
-
/** Free cache data */
void slotClearAudioCache();
- void askForAudioThumbs();
QString getClipHash() const;
void refreshThumbUrl();
const char *producerProperty(const char *name) const;
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;
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 <CutZoneInfo> 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;
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();
+ void setAnalysisData(const QString &name, const QString &data, int offset = 0);
+ QMap <QString, QString> analysisData() const;
+ int lastSeekPosition;
+ /** Cache for every audio Frame with 10 Bytes */
+ /** format is frame -> channel ->bytes */
+ QMap<int, QMap<int, QByteArray> > audioFrameCache;
+ /** Returns all current properties for this clip */
+ QMap <QString, QString> properties() const;
+ /** Return the current values for a set of properties */
+ QMap <QString, QString> currentProperties(const QMap<QString, QString> &props);
+ QMap <QString, QStringList> 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
* that exist. */
uint m_refcount;
QList <Mlt::Producer *> m_baseTrackProducers;
+ QList <Mlt::Producer *> m_videoTrackProducers;
QList <Mlt::Producer *> m_audioTrackProducers;
QList <Mlt::Producer *> m_toDeleteProducers;
- Mlt::Producer *m_videoOnlyProducer;
- CLIPTYPE m_clipType;
+ 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;
/** Holds clip infos like fps, size,... */
QMap <QString, QString> m_properties;
/** Holds clip metadata like author, copyright,... */
- QMap <QString, QString> m_metadata;
+ QMap <QString, QStringList> m_metadata;
+ /** Holds clip analysis data that can be used later to create markers or keyframes */
+ QMap <QString, QString> m_analysisdata;
/** 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);
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:
void updateAudioThumbnail(const audioByteArray& data);
- bool slotGetAudioThumbs();
QList < CommentedTime > commentedSnapMarkers() const;
GenTime findNextSnapMarker(const GenTime & currTime);
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 GenTime & time, QString comment);
+ void editSnapMarker(const GenTime & time, const QString &comment);
+ void addSnapMarker(const CommentedTime &marker);
QList < GenTime > snapMarkers() const;
- QString markerComment(GenTime t);
+ QString markerComment(const GenTime &t) const;
+ CommentedTime markerAt(const GenTime &t) const;
void setClipThumbFrame(const uint &ix);
uint getClipThumbFrame() const;
- void setProperties(QMap <QString, QString> properties);
- void setMetadata(QMap <QString, QString> properties);
- QMap <QString, QString> properties() const;
- QMap <QString, QString> metadata() const;
- void slotExtractImage(int frame, int frame2);
+ void setProperties(QMap<QString, QString> properties);
+ void setMetadata(const QMap <QString, QString> &properties, const QString &tool = QString());
+ void slotExtractImage(const QList <int> &frames);
signals:
void gotAudioData();