X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fkthumb.h;h=63c5df0117b0f4d53dbec4e918e06add563e4a51;hb=12c52e2d2e97f703714b83dfd385db2de5f03f18;hp=cb24b9b30bd09bff7b65db5d2012dbcb065b19f0;hpb=4be9030ba656aeb05ac8b28aaae5aa79cdf461d5;p=kdenlive diff --git a/src/kthumb.h b/src/kthumb.h index cb24b9b3..63c5df01 100644 --- a/src/kthumb.h +++ b/src/kthumb.h @@ -20,9 +20,8 @@ #include #include -#include -#include #include +#include #include @@ -32,13 +31,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; @@ -48,33 +48,8 @@ class Profile; class ClipManager; - - -class MyThread : public QThread { - Q_OBJECT -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; - -signals: - void audioThumbProgress(const int); - void audioThumbOver(); -}; - -class KThumb: public QObject { +class KThumb: public QObject +{ Q_OBJECT public: @@ -83,11 +58,13 @@ Q_OBJECT public: void setProducer(Mlt::Producer *producer); void askForAudioThumbs(const QString &id); bool hasProducer() const; + void clearProducer(); + void updateThumbUrl(const QString &hash); public slots: void extractImage(int frame, int frame2); QPixmap extractImage(int frame, int width, int height); - 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); /* void getImage(KUrl url, int frame, int width, int height); @@ -96,24 +73,33 @@ public slots: 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); + static QImage getFrame(Mlt::Producer *producer, int framepos, int width, int height); private slots: - void slotAudioThumbProgress(const int progress); void slotAudioThumbOver(); + void slotCreateAudioThumbs(); private: - MyThread audioThumbProducer; + QFuture m_audioThumbProducer; KUrl m_url; QString m_thumbFile; double m_dar; Mlt::Producer *m_producer; ClipManager *m_clipManager; QString m_id; - int m_mainFrame; + QList m_requestedThumbs; + QFuture m_future; + QFile m_audioThumbFile; + bool m_stopAudioThumbs; + double m_frame; + double m_frameLength; + int m_frequency; + int m_channels; + int m_arrayWidth; + void doGetThumbs(); signals: - void thumbReady(int, QPixmap); + void thumbReady(int, QImage); void mainThumbReady(const QString &, QPixmap); void audioThumbReady(QMap >); };