1 /***************************************************************************
4 begin : Fri Nov 22 2002
5 copyright : (C) 2002 by Jason Wood
6 email : jasonwood@blueyonder.co.uk
7 ***************************************************************************/
9 /***************************************************************************
11 * This program is free software; you can redistribute it and/or modify *
12 * it under the terms of the GNU General Public License as published by *
13 * the Free Software Foundation; either version 2 of the License, or *
14 * (at your option) any later version. *
16 ***************************************************************************/
23 #include <QDomElement>
27 #include <kdeversion.h>
29 #include <mlt++/Mlt.h>
32 /**KRender encapsulates the client side of the interface to a renderer.
33 From Kdenlive's point of view, you treat the KRender object as the
34 renderer, and simply use it as if it was local. Calls are asyncrhonous -
35 you send a call out, and then receive the return value through the
36 relevant signal that get's emitted once the call completes.
52 class KThumb: public QObject
57 KThumb(ClipManager *clipManager, KUrl url, const QString &id, const QString &hash, QObject * parent = 0, const char *name = 0);
59 void setProducer(Mlt::Producer *producer);
60 void askForAudioThumbs(const QString &id);
61 bool hasProducer() const;
63 void updateThumbUrl(const QString &hash);
64 void extractImage(int frame, int frame2);
65 QPixmap extractImage(int frame, int width, int height);
66 #if KDE_IS_VERSION(4,5,0)
67 /** @brief Request thumbnails for the frame range. */
68 void queryIntraThumbs(int start, int end);
69 /** @brief Query cached thumbnail. */
70 QImage findCachedThumb(const QString path);
74 void updateClipUrl(KUrl url, const QString &hash);
75 static QPixmap getImage(KUrl url, int width, int height);
76 // static QPixmap getImage(QDomElement xml, int frame, int width, int height);
77 /* void getImage(KUrl url, int frame, int width, int height);
78 void getThumbs(KUrl url, int startframe, int endframe, int width, int height);*/
79 void stopAudioThumbs();
80 void removeAudioThumb();
81 void getAudioThumbs(int channel, double frame, double frameLength, int arrayWidth);
82 static QPixmap getImage(KUrl url, int frame, int width, int height);
83 static QImage getFrame(Mlt::Producer *producer, int framepos, int width, int height);
84 /** @brief Calculates image variance, useful to know if a thumbnail is interesting.
85 * @return an integer between 0 and 100. 0 means no variance, eg. black image while bigger values mean contrasted image
87 static uint imageVariance(QImage image);
90 void slotAudioThumbOver();
91 void slotCreateAudioThumbs();
92 #if KDE_IS_VERSION(4,5,0)
93 /** @brief Fetch all requested frames. */
94 void slotGetIntraThumbs();
98 QFuture<void> m_audioThumbProducer;
102 Mlt::Producer *m_producer;
103 ClipManager *m_clipManager;
105 QList <int> m_requestedThumbs;
106 /** @brief Controls the thumbnails process. */
107 QFuture<void> m_future;
108 /** @brief Controls the intra frames thumbnails process (cached thumbnails). */
109 QFuture<void> m_intra;
110 QFile m_audioThumbFile;
111 bool m_stopAudioThumbs;
113 double m_frameLength;
117 /** @brief List of frame numbers from which we want to extract thumbnails. */
118 QList <int> m_intraFramesQueue;
122 void thumbReady(int, QImage);
123 void mainThumbReady(const QString &, QPixmap);
124 void audioThumbReady(QMap <int, QMap <int, QByteArray> >);
125 /** @brief We have finished caching all requested thumbs. */