annotate dwt/graphics/ImageLoader.d @ 9:ad2b69216039

moved org.eclipse.swt to dwt
author Frank Benoit <benoit@tionex.de>
date Sat, 05 Jan 2008 17:39:49 +0100
parents org/eclipse/swt/graphics/ImageLoader.d@640e6456a9ff
children 63c023465156
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
6
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
1 /*******************************************************************************
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
2 * Copyright (c) 2000, 2006 IBM Corporation and others.
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
3 * All rights reserved. This program and the accompanying materials
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
4 * are made available under the terms of the Eclipse Public License v1.0
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
5 * which accompanies this distribution, and is available at
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
6 * http://www.eclipse.org/legal/epl-v10.html
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
7 *
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
8 * Contributors:
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
9 * IBM Corporation - initial API and implementation
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
10 *******************************************************************************/
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
11 module org.eclipse.swt.graphics.ImageLoader;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
12
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
13
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
14 public import org.eclipse.swt.graphics.ImageLoaderListener;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
15 public import org.eclipse.swt.graphics.ImageLoaderEvent;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
16 public import org.eclipse.swt.graphics.ImageData;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
17
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
18 import org.eclipse.swt.SWT;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
19 import org.eclipse.swt.internal.Compatibility;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
20 //import org.eclipse.swt.internal.image.*;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
21
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
22 import tango.core.Exception;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
23 import tango.core.Array;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
24 import tango.io.model.IConduit;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
25
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
26 class FileFormat{
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
27 static ImageData[] load( InputStream, ImageLoader ){ return null; }
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
28 static void save( OutputStream, int, ImageLoader ){}
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
29 }
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
30
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
31 /**
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
32 * Instances of this class are used to load images from,
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
33 * and save images to, a file or stream.
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
34 * <p>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
35 * Currently supported image formats are:
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
36 * </p><ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
37 * <li>BMP (Windows or OS/2 Bitmap)</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
38 * <li>ICO (Windows Icon)</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
39 * <li>JPEG</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
40 * <li>GIF</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
41 * <li>PNG</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
42 * <li>TIFF</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
43 * </ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
44 * <code>ImageLoaders</code> can be used to:
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
45 * <ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
46 * <li>load/save single images in all formats</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
47 * <li>load/save multiple images (GIF/ICO/TIFF)</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
48 * <li>load/save animated GIF images</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
49 * <li>load interlaced GIF/PNG images</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
50 * <li>load progressive JPEG images</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
51 * </ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
52 */
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
53
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
54 public class ImageLoader {
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
55
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
56 /**
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
57 * the array of ImageData objects in this ImageLoader.
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
58 * This array is read in when the load method is called,
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
59 * and it is written out when the save method is called
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
60 */
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
61 public ImageData[] data;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
62
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
63 /**
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
64 * the width of the logical screen on which the images
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
65 * reside, in pixels (this corresponds to the GIF89a
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
66 * Logical Screen Width value)
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
67 */
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
68 public int logicalScreenWidth;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
69
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
70 /**
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
71 * the height of the logical screen on which the images
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
72 * reside, in pixels (this corresponds to the GIF89a
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
73 * Logical Screen Height value)
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
74 */
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
75 public int logicalScreenHeight;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
76
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
77 /**
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
78 * the background pixel for the logical screen (this
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
79 * corresponds to the GIF89a Background Color Index value).
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
80 * The default is -1 which means 'unspecified background'
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
81 *
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
82 */
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
83 public int backgroundPixel;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
84
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
85 /**
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
86 * the number of times to repeat the display of a sequence
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
87 * of animated images (this corresponds to the commonly-used
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
88 * GIF application extension for "NETSCAPE 2.0 01").
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
89 * The default is 1. A value of 0 means 'display repeatedly'
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
90 */
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
91 public int repeatCount;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
92
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
93 /*
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
94 * the set of ImageLoader event listeners, created on demand
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
95 */
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
96 ImageLoaderListener[] imageLoaderListeners;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
97
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
98 /**
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
99 * Construct a new empty ImageLoader.
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
100 */
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
101 public this() {
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
102 reset();
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
103 }
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
104
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
105 /**
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
106 * Resets the fields of the ImageLoader, except for the
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
107 * <code>imageLoaderListeners</code> field.
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
108 */
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
109 void reset() {
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
110 data = null;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
111 logicalScreenWidth = 0;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
112 logicalScreenHeight = 0;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
113 backgroundPixel = -1;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
114 repeatCount = 1;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
115 }
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
116
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
117 /**
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
118 * Loads an array of <code>ImageData</code> objects from the
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
119 * specified input stream. Throws an error if either an error
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
120 * occurs while loading the images, or if the images are not
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
121 * of a supported type. Returns the loaded image data array.
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
122 *
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
123 * @param stream the input stream to load the images from
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
124 * @return an array of <code>ImageData</code> objects loaded from the specified input stream
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
125 *
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
126 * @exception IllegalArgumentException <ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
127 * <li>ERROR_NULL_ARGUMENT - if the stream is null</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
128 * </ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
129 * @exception SWTException <ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
130 * <li>ERROR_IO - if an IO error occurs while reading from the stream</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
131 * <li>ERROR_INVALID_IMAGE - if the image stream contains invalid data</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
132 * <li>ERROR_UNSUPPORTED_FORMAT - if the image stream contains an unrecognized format</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
133 * </ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
134 */
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
135 public ImageData[] load(InputStream stream) {
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
136 if (stream is null) SWT.error(SWT.ERROR_NULL_ARGUMENT);
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
137 reset();
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
138 data = FileFormat.load(stream, this);
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
139 return data;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
140 }
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
141
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
142 /**
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
143 * Loads an array of <code>ImageData</code> objects from the
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
144 * file with the specified name. Throws an error if either
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
145 * an error occurs while loading the images, or if the images are
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
146 * not of a supported type. Returns the loaded image data array.
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
147 *
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
148 * @param filename the name of the file to load the images from
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
149 * @return an array of <code>ImageData</code> objects loaded from the specified file
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
150 *
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
151 * @exception IllegalArgumentException <ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
152 * <li>ERROR_NULL_ARGUMENT - if the file name is null</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
153 * </ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
154 * @exception SWTException <ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
155 * <li>ERROR_IO - if an IO error occurs while reading from the file</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
156 * <li>ERROR_INVALID_IMAGE - if the image file contains invalid data</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
157 * <li>ERROR_UNSUPPORTED_FORMAT - if the image file contains an unrecognized format</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
158 * </ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
159 */
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
160 public ImageData[] load(char[] filename) {
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
161 if (filename is null) SWT.error(SWT.ERROR_NULL_ARGUMENT);
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
162 InputStream stream = null;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
163 void close(){
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
164 try {
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
165 if( stream !is null ) stream.close();
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
166 } catch (IOException e) {
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
167 // Ignore error
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
168 }
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
169 }
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
170 try {
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
171 stream = Compatibility.newFileInputStream(filename);
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
172 scope(exit) close();
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
173
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
174 return load(stream);
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
175 } catch (IOException e) {
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
176 SWT.error(SWT.ERROR_IO, e);
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
177 }
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
178 return null;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
179 }
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
180
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
181 /**
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
182 * Saves the image data in this ImageLoader to the specified stream.
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
183 * The format parameter can have one of the following values:
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
184 * <dl>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
185 * <dt><code>IMAGE_BMP</code></dt>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
186 * <dd>Windows BMP file format, no compression</dd>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
187 * <dt><code>IMAGE_BMP_RLE</code></dt>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
188 * <dd>Windows BMP file format, RLE compression if appropriate</dd>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
189 * <dt><code>IMAGE_GIF</code></dt>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
190 * <dd>GIF file format</dd>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
191 * <dt><code>IMAGE_ICO</code></dt>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
192 * <dd>Windows ICO file format</dd>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
193 * <dt><code>IMAGE_JPEG</code></dt>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
194 * <dd>JPEG file format</dd>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
195 * <dt><code>IMAGE_PNG</code></dt>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
196 * <dd>PNG file format</dd>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
197 * </dl>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
198 *
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
199 * @param stream the output stream to write the images to
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
200 * @param format the format to write the images in
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
201 *
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
202 * @exception IllegalArgumentException <ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
203 * <li>ERROR_NULL_ARGUMENT - if the stream is null</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
204 * </ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
205 * @exception SWTException <ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
206 * <li>ERROR_IO - if an IO error occurs while writing to the stream</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
207 * <li>ERROR_INVALID_IMAGE - if the image data contains invalid data</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
208 * <li>ERROR_UNSUPPORTED_FORMAT - if the image data cannot be saved to the requested format</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
209 * </ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
210 */
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
211 public void save(OutputStream stream, int format) {
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
212 if (stream is null) SWT.error(SWT.ERROR_NULL_ARGUMENT);
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
213 FileFormat.save(stream, format, this);
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
214 }
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
215
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
216 /**
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
217 * Saves the image data in this ImageLoader to a file with the specified name.
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
218 * The format parameter can have one of the following values:
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
219 * <dl>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
220 * <dt><code>IMAGE_BMP</code></dt>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
221 * <dd>Windows BMP file format, no compression</dd>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
222 * <dt><code>IMAGE_BMP_RLE</code></dt>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
223 * <dd>Windows BMP file format, RLE compression if appropriate</dd>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
224 * <dt><code>IMAGE_GIF</code></dt>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
225 * <dd>GIF file format</dd>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
226 * <dt><code>IMAGE_ICO</code></dt>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
227 * <dd>Windows ICO file format</dd>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
228 * <dt><code>IMAGE_JPEG</code></dt>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
229 * <dd>JPEG file format</dd>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
230 * <dt><code>IMAGE_PNG</code></dt>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
231 * <dd>PNG file format</dd>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
232 * </dl>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
233 *
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
234 * @param filename the name of the file to write the images to
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
235 * @param format the format to write the images in
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
236 *
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
237 * @exception IllegalArgumentException <ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
238 * <li>ERROR_NULL_ARGUMENT - if the file name is null</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
239 * </ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
240 * @exception SWTException <ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
241 * <li>ERROR_IO - if an IO error occurs while writing to the file</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
242 * <li>ERROR_INVALID_IMAGE - if the image data contains invalid data</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
243 * <li>ERROR_UNSUPPORTED_FORMAT - if the image data cannot be saved to the requested format</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
244 * </ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
245 */
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
246 public void save(char[] filename, int format) {
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
247 if (filename is null) SWT.error(SWT.ERROR_NULL_ARGUMENT);
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
248 OutputStream stream = null;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
249 try {
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
250 stream = Compatibility.newFileOutputStream(filename);
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
251 } catch (IOException e) {
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
252 SWT.error(SWT.ERROR_IO, e);
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
253 }
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
254 save(stream, format);
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
255 try {
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
256 stream.close();
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
257 } catch (IOException e) {
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
258 }
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
259 }
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
260
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
261 /**
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
262 * Adds the listener to the collection of listeners who will be
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
263 * notified when image data is either partially or completely loaded.
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
264 * <p>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
265 * An ImageLoaderListener should be added before invoking
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
266 * one of the receiver's load methods. The listener's
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
267 * <code>imageDataLoaded</code> method is called when image
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
268 * data has been partially loaded, as is supported by interlaced
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
269 * GIF/PNG or progressive JPEG images.
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
270 *
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
271 * @param listener the listener which should be notified
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
272 *
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
273 * @exception IllegalArgumentException <ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
274 * <li>ERROR_NULL_ARGUMENT - if the listener is null</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
275 * </ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
276 *
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
277 * @see ImageLoaderListener
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
278 * @see ImageLoaderEvent
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
279 */
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
280 public void addImageLoaderListener(ImageLoaderListener listener) {
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
281 if (listener is null) SWT.error (SWT.ERROR_NULL_ARGUMENT);
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
282 imageLoaderListeners ~= listener;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
283 }
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
284
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
285 /**
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
286 * Removes the listener from the collection of listeners who will be
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
287 * notified when image data is either partially or completely loaded.
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
288 *
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
289 * @param listener the listener which should no longer be notified
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
290 *
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
291 * @exception IllegalArgumentException <ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
292 * <li>ERROR_NULL_ARGUMENT - if the listener is null</li>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
293 * </ul>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
294 *
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
295 * @see #addImageLoaderListener(ImageLoaderListener)
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
296 */
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
297 public void removeImageLoaderListener(ImageLoaderListener listener) {
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
298 if (listener is null) SWT.error (SWT.ERROR_NULL_ARGUMENT);
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
299 if (imageLoaderListeners.length == 0 ) return;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
300 tango.core.Array.remove( imageLoaderListeners, listener, delegate bool(ImageLoaderListener l1, ImageLoaderListener l2 ){ return l1 is l2; });
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
301 }
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
302
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
303 /**
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
304 * Returns <code>true</code> if the receiver has image loader
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
305 * listeners, and <code>false</code> otherwise.
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
306 *
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
307 * @return <code>true</code> if there are <code>ImageLoaderListener</code>s, and <code>false</code> otherwise
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
308 *
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
309 * @see #addImageLoaderListener(ImageLoaderListener)
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
310 * @see #removeImageLoaderListener(ImageLoaderListener)
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
311 */
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
312 public bool hasListeners() {
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
313 return imageLoaderListeners.length > 0;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
314 }
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
315
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
316 /**
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
317 * Notifies all image loader listeners that an image loader event
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
318 * has occurred. Pass the specified event object to each listener.
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
319 *
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
320 * @param event the <code>ImageLoaderEvent</code> to send to each <code>ImageLoaderListener</code>
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
321 */
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
322 public void notifyListeners(ImageLoaderEvent event) {
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
323 if (!hasListeners()) return;
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
324 foreach( listener; imageLoaderListeners ){
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
325 listener.imageDataLoaded(event);
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
326 }
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
327 }
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
328
640e6456a9ff more ...
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
329 }