summaryrefslogtreecommitdiffstats
path: root/kimgio/README
diff options
context:
space:
mode:
Diffstat (limited to 'kimgio/README')
-rw-r--r--kimgio/README75
1 files changed, 75 insertions, 0 deletions
diff --git a/kimgio/README b/kimgio/README
new file mode 100644
index 000000000..6c9cec844
--- /dev/null
+++ b/kimgio/README
@@ -0,0 +1,75 @@
+KDE Image I/O library
+---------------------
+This library allows applications that use the Qt library
+(i.e. QImageIO, QImage, QPixmap and friends) to read and
+write images in extra formats. Current formats include:
+
+JPEG <read> <write>
+JPEG2000 <read> <write>
+XV <read> <write>
+EPS <read> <write>
+NETPBM <incomplete>
+PNG <read> <write, only with newer libraries>
+TIFF <read>
+TGA <read> <write>
+PCX <read> <write>
+SGI <read> <write> (images/x-rgb: *.bw, *.rgb, *.rgba, *.sgi)
+DDS <read>
+XCF <read>
+
+(Some example files are in kdenonbeta/kimgio_examples.)
+
+
+To use these formats, you only need to:
+
+1. link the application with the libkio library
+2. Include the <kimageio.h> header
+3. call KImageIO::registerFormats() once, somewhere in your code
+ before you load an image.
+
+Writing handlers
+----------------
+
+0. Please read the documentation for the QImageIO class in the Qt
+documentation.
+
+1. When writing handlers, there is a function naming convention;
+suppose, for example, we were writing PNG read and write handlers,
+we would name them
+
+void kimgio_png_read ( QImageIO * );
+void kimgio_png_write( QImageIO * );
+
+ie
+
+kimgio_<format>_<read/write>
+
+This should reduce the chance of identifier clashes with other code.
+
+2. Remember that a given KDE application may try to load dozens of
+images at once such as when loading icons, or creating thumbnails.
+Also, it may well be loading them over a network connection.
+Therefore,
+
+ - Avoid creating temporary files or allocating too much memory
+ when decoding and encoding. Especially try to avoid firing off
+ external programs.
+
+ - Don't assume that the IODevice which is the source or target
+ of the image data is pointing to a file on the local filesystem.
+ Use the IODevice methods to read and write image data.
+
+ - Check for file corruption or premature end of the image,
+ especially before using values read from the file
+ e.g. for memory allocations.
+
+3. If you only have either a reader or the writer for a particular
+format, don't use NULL in QImageIO::defineIOHandler. Instead, write
+a stub function for the unimplemented handler which displays a message
+on standard output. This prevents kimgio-using programs dumping core
+when attempting to call the unimplemented handler.
+
+
+Yours in good faith and pedantry,
+
+Sirtaj Singh Kang <taj@kde.org>, 23 September 1998.