X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fkthumb.h;h=1d71582dd762e07cb4b682c4521593cc36978b85;hb=29b7373a465ab472ad5be4edf00e98aabfe7825e;hp=ffbd745d16042ce6c9a9db2f6176af922ab6adf9;hpb=f10ecf3c4538b19705753e118c3bc8c4702d4747;p=kdenlive diff --git a/src/kthumb.h b/src/kthumb.h index ffbd745d..1d71582d 100644 --- a/src/kthumb.h +++ b/src/kthumb.h @@ -18,12 +18,13 @@ #ifndef KTHUMB_H #define KTHUMB_H -#include -#include -#include -#include +#include +#include +#include +#include -#include +#include +#include #include @@ -31,13 +32,14 @@ /**KRender encapsulates the client side of the interface to a renderer. From Kdenlive's point of view, you treat the KRender object as the renderer, and simply use it as if it was local. Calls are asyncrhonous - -you send a call out, and then recieve the return value through the +you send a call out, and then receive the return value through the relevant signal that get's emitted once the call completes. *@author Jason Wood */ -namespace Mlt { +namespace Mlt +{ class Miracle; class Consumer; class Producer; @@ -47,60 +49,81 @@ class Profile; class ClipManager; -class MyThread : public QThread { - -public: - virtual void run(); - void init(QObject *parent, KUrl url, QString target, double frame, double frameLength, int frequency, int channels, int arrayWidth); - bool isWorking(); - bool stop_me; - -private: - QFile f; - KUrl m_url; - double m_frame; - double m_frameLength; - int m_frequency; - int m_channels; - int m_arrayWidth; - bool m_isWorking; - QObject *m_parent; -}; - - -class KThumb: public QObject { +class KThumb: public QObject +{ Q_OBJECT public: - KThumb(ClipManager *clipManager, KUrl url, QObject * parent = 0, const char *name = 0); + KThumb(ClipManager *clipManager, KUrl url, const QString &id, const QString &hash, QObject * parent = 0, const char *name = 0); ~KThumb(); + void setProducer(Mlt::Producer *producer); + void askForAudioThumbs(const QString &id); + bool hasProducer() const; + void clearProducer(); + void updateThumbUrl(const QString &hash); + void extractImage(int frame, int frame2); + QPixmap extractImage(int frame, int width, int height); +#if KDE_IS_VERSION(4,5,0) + /** @brief Request thumbnails for the frame range. */ + void queryIntraThumbs(int start, int end); + /** @brief Query cached thumbnail. */ + QImage findCachedThumb(const QString path); +#endif public slots: - void extractImage(int frame, int frame2); - void updateClipUrl(KUrl url); + void updateClipUrl(KUrl url, const QString &hash); static QPixmap getImage(KUrl url, int width, int height); - static QPixmap getImage(QDomElement xml, int frame, int width, int height); +// static QPixmap getImage(QDomElement xml, int frame, int width, int height); /* void getImage(KUrl url, int frame, int width, int height); void getThumbs(KUrl url, int startframe, int endframe, int width, int height);*/ void stopAudioThumbs(); void removeAudioThumb(); void getAudioThumbs(int channel, double frame, double frameLength, int arrayWidth); static QPixmap getImage(KUrl url, int frame, int width, int height); - static QPixmap getFrame(Mlt::Producer producer, int framepos, int width, int height); - -protected: - virtual void customEvent(QEvent * event); + static QImage getFrame(Mlt::Producer *producer, int framepos, int width, int height); + /** @brief Calculates image variance, useful to know if a thumbnail is interesting. + * @return an integer between 0 and 100. 0 means no variance, eg. black image while bigger values mean contrasted image + * */ + static uint imageVariance(QImage image); + +private slots: + void slotAudioThumbOver(); + void slotCreateAudioThumbs(); +#if KDE_IS_VERSION(4,5,0) + /** @brief Fetch all requested frames. */ + void slotGetIntraThumbs(); +#endif private: - MyThread thumbProducer; + QFuture m_audioThumbProducer; KUrl m_url; QString m_thumbFile; - Mlt::Profile *m_profile; + double m_dar; + Mlt::Producer *m_producer; ClipManager *m_clipManager; + QString m_id; + QList m_requestedThumbs; + /** @brief Controls the thumbnails process. */ + QFuture m_future; + /** @brief Controls the intra frames thumbnails process (cached thumbnails). */ + QFuture m_intra; + QFile m_audioThumbFile; + bool m_stopAudioThumbs; + double m_frame; + double m_frameLength; + int m_frequency; + int m_channels; + int m_arrayWidth; + /** @brief List of frame numbers from which we want to extract thumbnails. */ + QList m_intraFramesQueue; + void doGetThumbs(); signals: - void thumbReady(int frame, QPixmap pm); + void thumbReady(int, QImage); + void mainThumbReady(const QString &, QPixmap); void audioThumbReady(QMap >); + /** @brief We have finished caching all requested thumbs. */ + void thumbsCached(); }; #endif