diff options
| author | Gunnar Sletta <gunnar.sletta@nokia.com> | 2010-12-21 15:38:55 +0100 |
|---|---|---|
| committer | Gunnar Sletta <gunnar.sletta@nokia.com> | 2010-12-21 15:38:55 +0100 |
| commit | e0d01169b279a528616688efd946561512b837e3 (patch) | |
| tree | 8334e184522b1a16b0ab8d38cebb1a34ea29598a /src/adaptationlayers/qsgthreadedtexturemanager.h | |
| parent | 0783353952758777b1935a9ae068e2201b486a97 (diff) | |
Threaded texture manager.
Diffstat (limited to 'src/adaptationlayers/qsgthreadedtexturemanager.h')
| -rw-r--r-- | src/adaptationlayers/qsgthreadedtexturemanager.h | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/src/adaptationlayers/qsgthreadedtexturemanager.h b/src/adaptationlayers/qsgthreadedtexturemanager.h new file mode 100644 index 0000000..4d16f17 --- /dev/null +++ b/src/adaptationlayers/qsgthreadedtexturemanager.h @@ -0,0 +1,31 @@ +#ifndef QSGTHREADEDTEXTUREMANAGER_H +#define QSGTHREADEDTEXTUREMANAGER_H + +#include "qsgtexturemanager.h" + +class QSGThreadedTextureManagerThread; +class QSGThreadedTextureManagerPrivate; +class QSGThreadedTexture; + +class QSGThreadedTextureManager : public QSGTextureManager +{ + Q_OBJECT + Q_DECLARE_PRIVATE(QSGThreadedTextureManager); + +public: + QSGThreadedTextureManager(); + + QSGTextureRef upload(const QImage &image); + QSGTextureRef requestUpload(const QImage &image, const QObject *listener, const char *slot); + +protected: + virtual void createThreadContext(); + virtual void makeThreadContextCurrent(); + virtual void uploadInThread(const QImage &image, QSGTexture *texture); + +private: + friend class QSGThreadedTextureManagerThread; + friend class QSGThreadedTexture; +}; + +#endif // QSGTHREADEDTEXTUREMANAGER_H |
