summaryrefslogtreecommitdiffstats
path: root/plugins/src/imageformats/jpeg/main.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/src/imageformats/jpeg/main.cpp')
-rw-r--r--plugins/src/imageformats/jpeg/main.cpp76
1 files changed, 76 insertions, 0 deletions
diff --git a/plugins/src/imageformats/jpeg/main.cpp b/plugins/src/imageformats/jpeg/main.cpp
new file mode 100644
index 000000000..691322bf3
--- /dev/null
+++ b/plugins/src/imageformats/jpeg/main.cpp
@@ -0,0 +1,76 @@
+#ifndef QT_CLEAN_NAMESPACE
+#define QT_CLEAN_NAMESPACE
+#endif
+#include <qimageformatplugin.h>
+
+#ifndef QT_NO_IMAGEFORMATPLUGIN
+
+#ifdef QT_NO_IMAGEIO_JPEG
+#undef QT_NO_IMAGEIO_JPEG
+#endif
+#include "../../../../src/kernel/qjpegio.cpp"
+
+class JPEGFormat : public TQImageFormatPlugin
+{
+public:
+ JPEGFormat();
+
+ TQStringList keys() const;
+ bool loadImage( const TQString &format, const TQString &filename, TQImage * );
+ bool saveImage( const TQString &format, const TQString &filename, const TQImage & );
+ bool installIOHandler( const TQString & );
+};
+
+JPEGFormat::JPEGFormat()
+{
+}
+
+
+TQStringList JPEGFormat::keys() const
+{
+ TQStringList list;
+ list << "JPEG";
+
+ return list;
+}
+
+bool JPEGFormat::loadImage( const TQString &format, const TQString &filename, TQImage *image )
+{
+ if ( format != "JPEG" )
+ return FALSE;
+
+ TQImageIO io;
+ io.setFileName( filename );
+ io.setImage( *image );
+
+ read_jpeg_image( &io );
+
+ return TRUE;
+}
+
+bool JPEGFormat::saveImage( const TQString &format, const TQString &filename, const TQImage &image )
+{
+ if ( format != "JPEG" )
+ return FALSE;
+
+ TQImageIO io;
+ io.setFileName( filename );
+ io.setImage( image );
+
+ write_jpeg_image( &io );
+
+ return TRUE;
+}
+
+bool JPEGFormat::installIOHandler( const TQString &name )
+{
+ if ( name.upper() != "JPEG" )
+ return FALSE;
+
+ qInitJpegIO();
+ return TRUE;
+}
+
+Q_EXPORT_PLUGIN( JPEGFormat )
+
+#endif // QT_NO_IMAGEFORMATPLUGIN