annotate dwt/internal/image/TIFFFileFormat.d @ 13:3d9bbe0a83a0

FileFormats
author Frank Benoit <benoit@tionex.de>
date Sun, 06 Jan 2008 22:54:14 +0100
parents
children 8cec8f536af3
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
13
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
1 /*******************************************************************************
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
2 * Copyright (c) 2000, 2005 IBM Corporation and others.
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
3 * All rights reserved. This program and the accompanying materials
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
4 * are made available under the terms of the Eclipse Public License v1.0
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
5 * which accompanies this distribution, and is available at
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
6 * http://www.eclipse.org/legal/epl-v10.html
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
7 *
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
8 * Contributors:
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
9 * IBM Corporation - initial API and implementation
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
10 *******************************************************************************/
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
11 module dwt.internal.image.TIFFFileFormat;
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
12
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
13 import dwt.internal.image.TIFFRandomFileAccess;
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
14 import dwt.internal.image.TIFFDirectory;
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
15 import dwt.SWT;
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
16 import dwt.graphics.ImageData;
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
17 import dwt.graphics.ImageLoader;
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
18 import dwt.internal.image.FileFormat;
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
19
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
20 import tango.core.Exception;
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
21
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
22 /**
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
23 * Baseline TIFF decoder revision 6.0
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
24 * Extension T4-encoding CCITT T.4 1D
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
25 */
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
26 final class TIFFFileFormat : FileFormat {
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
27
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
28 bool isFileFormat(LEDataInputStream stream) {
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
29 try {
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
30 byte[] header = new byte[4];
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
31 stream.read(header);
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
32 stream.unread(header);
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
33 if (header[0] != header[1]) return false;
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
34 if (!(header[0] == 0x49 && header[2] == 42 && header[3] == 0) &&
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
35 !(header[0] == 0x4d && header[2] == 0 && header[3] == 42)) {
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
36 return false;
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
37 }
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
38 return true;
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
39 } catch (TracedException e) {
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
40 return false;
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
41 }
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
42 }
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
43
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
44 ImageData[] loadFromByteStream() {
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
45 byte[] header = new byte[8];
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
46 bool isLittleEndian;
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
47 ImageData[] images = new ImageData[0];
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
48 TIFFRandomFileAccess file = new TIFFRandomFileAccess(inputStream);
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
49 try {
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
50 file.read(header);
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
51 if (header[0] != header[1]) SWT.error(SWT.ERROR_INVALID_IMAGE);
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
52 if (!(header[0] == 0x49 && header[2] == 42 && header[3] == 0) &&
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
53 !(header[0] == 0x4d && header[2] == 0 && header[3] == 42)) {
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
54 SWT.error(SWT.ERROR_INVALID_IMAGE);
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
55 }
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
56 isLittleEndian = header[0] == 0x49;
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
57 int offset = isLittleEndian ?
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
58 (header[4] & 0xFF) | ((header[5] & 0xFF) << 8) | ((header[6] & 0xFF) << 16) | ((header[7] & 0xFF) << 24) :
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
59 (header[7] & 0xFF) | ((header[6] & 0xFF) << 8) | ((header[5] & 0xFF) << 16) | ((header[4] & 0xFF) << 24);
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
60 file.seek(offset);
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
61 TIFFDirectory directory = new TIFFDirectory(file, isLittleEndian, loader);
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
62 ImageData image = directory.read();
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
63 /* A baseline reader is only expected to read the first directory */
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
64 images = [image];
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
65 } catch (IOException e) {
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
66 SWT.error(SWT.ERROR_IO, e);
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
67 }
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
68 return images;
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
69 }
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
70
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
71 void unloadIntoByteStream(ImageLoader loader) {
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
72 /* We do not currently support writing multi-page tiff,
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
73 * so we use the first image data in the loader's array. */
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
74 ImageData image = loader.data[0];
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
75 TIFFDirectory directory = new TIFFDirectory(image);
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
76 try {
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
77 directory.writeToStream(outputStream);
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
78 } catch (IOException e) {
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
79 SWT.error(SWT.ERROR_IO, e);
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
80 }
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
81 }
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
82
3d9bbe0a83a0 FileFormats
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
83 }