annotate servlet/src/digilib/image/JAIDocuImage.java @ 71:d493563ef672

New servlet version 1.5b. Mostly cleanup. Global parameters for digilib now in DigilibConfiguration, per request parameters are now all in DigilibRequest. The DocuImage implementation can be selected by the configuration docuimage-class. Pixel-by-pixel view implemented with "mo=clip".
author robcast
date Fri, 24 Jan 2003 21:40:59 +0100
parents 0ff3ede32060
children 3b8797fc3e90 6d2032b6121d 9cedd170b581
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
1 /* JAIDocuImage -- Image class implementation using JAI (Java Advanced Imaging)
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
2
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
3 Digital Image Library servlet components
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
4
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
5 Copyright (C) 2001, 2002 Robert Casties (robcast@mail.berlios.de)
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
6
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
7 This program is free software; you can redistribute it and/or modify it
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
8 under the terms of the GNU General Public License as published by the
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
9 Free Software Foundation; either version 2 of the License, or (at your
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
10 option) any later version.
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
11
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
12 Please read license.txt for the full details. A copy of the GPL
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
13 may be found at http://www.gnu.org/copyleft/lgpl.html
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
14
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
15 You should have received a copy of the GNU General Public License
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
16 along with this program; if not, write to the Free Software
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
17 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
18
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
19 */
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
20
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
21 package digilib.image;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
22
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
23 import javax.servlet.*;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
24 import javax.servlet.http.*;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
25 import java.io.*;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
26 import java.util.*;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
27
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
28 import java.awt.*;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
29 import java.awt.image.*;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
30 import java.awt.image.renderable.*;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
31 import javax.media.jai.*;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
32
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
33 import digilib.*;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
34 import digilib.io.*;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
35
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
36
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
37 public class JAIDocuImage extends DocuImageImpl {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
38
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
39 private RenderedImage img;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
40
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
41 public JAIDocuImage() {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
42 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
43
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
44 public JAIDocuImage(Utils u) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
45 util = u;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
46 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
47
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
48 /**
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
49 * load image file
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
50 */
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
51 public void loadImage(File f) throws FileOpException {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
52 System.gc();
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
53 img = JAI.create("fileload", f.getAbsolutePath());
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
54 if (img == null) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
55 util.dprintln(3, "ERROR(loadImage): unable to load file");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
56 throw new FileOpException("Unable to load File!");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
57 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
58 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
59
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
60 /**
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
61 * write image of type mt to Stream
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
62 */
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
63 public void writeImage(String mt, ServletResponse res)
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
64 throws FileOpException {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
65 try {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
66 // setup output
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
67 ParameterBlock pb3 = new ParameterBlock();
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
68 pb3.addSource(img);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
69 pb3.add(res.getOutputStream());
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
70 if (mt == "image/jpeg") {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
71 pb3.add("JPEG");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
72 } else if (mt == "image/png") {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
73 pb3.add("PNG");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
74 } else {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
75 // unknown mime type
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
76 util.dprintln(2, "ERROR(writeImage): Unknown mime type "+mt);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
77 throw new FileOpException("Unknown mime type: "+mt);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
78 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
79 res.setContentType(mt);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
80 // render output
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
81 JAI.create("encode", pb3);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
82
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
83 } catch (IOException e) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
84 throw new FileOpException("Error writing image.");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
85 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
86 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
87
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
88 public int getWidth() {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
89 if (img != null) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
90 return img.getWidth();
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
91 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
92 return 0;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
93 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
94
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
95 public int getHeight() {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
96 if (img != null) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
97 return img.getHeight();
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
98 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
99 return 0;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
100 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
101
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
102
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
103 /**
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
104 * crop and scale image
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
105 * take rectangle width,height at position x_off,y_off
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
106 * and scale by scale
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
107 */
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
108 public void cropAndScale(int x_off, int y_off, int width, int height,
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
109 float scale, int qual) throws ImageOpException {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
110
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
111 Interpolation scaleInt = null;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
112 // setup interpolation quality
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
113 if (qual > 1) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
114 util.dprintln(4, "quality q2");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
115 scaleInt = Interpolation.getInstance(Interpolation.INTERP_BICUBIC);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
116 } else if (qual == 1) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
117 util.dprintln(4, "quality q1");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
118 scaleInt = Interpolation.getInstance(Interpolation.INTERP_BILINEAR);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
119 } else {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
120 util.dprintln(4, "quality q0");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
121 scaleInt = Interpolation.getInstance(Interpolation.INTERP_NEAREST);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
122 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
123
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
124 // setup Crop
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
125 ParameterBlock pb1 = new ParameterBlock();
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
126 pb1.addSource(img);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
127 pb1.add((float)x_off);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
128 pb1.add((float)y_off);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
129 pb1.add((float)width);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
130 pb1.add((float)height);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
131 RenderedImage croppedImg = JAI.create("crop", pb1);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
132 img = null; // free img
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
133
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
134 util.dprintln(3, "CROP:"+croppedImg.getWidth()+"x"+croppedImg.getHeight()); //DEBUG
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
135
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
136 if (croppedImg == null) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
137 util.dprintln(2, "ERROR(cropAndScale): error in crop");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
138 throw new ImageOpException("Unable to crop");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
139 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
140
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
141 // setup scale
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
142 ParameterBlock pb2 = new ParameterBlock();
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
143 pb2.addSource(croppedImg);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
144 pb2.add(scale);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
145 pb2.add(scale);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
146 pb2.add(0f);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
147 pb2.add(0f);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
148 pb2.add(scaleInt);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
149 // the following is nice but way too slow...
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
150 //if (opCrop.getColorModel().getPixelSize() < 8) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
151 // change color model if necessary
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
152 // util.dprintln("converting color model...");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
153 // BufferedImage bi = new BufferedImage(1, 1, BufferedImage.TYPE_BYTE_GRAY);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
154 // ImageLayout lay = new ImageLayout(bi);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
155 // rh = new RenderingHints(JAI.KEY_IMAGE_LAYOUT, lay);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
156 //}
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
157 RenderedImage scaledImg = JAI.create("scale", pb2);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
158 croppedImg = null; // free opCrop
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
159
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
160 if (scaledImg == null) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
161 util.dprintln(2, "ERROR(cropAndScale): error in scale");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
162 throw new ImageOpException("Unable to scale");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
163 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
164
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
165 img = scaledImg;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
166 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
167
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
168 }