annotate servlet/src/digilib/image/JIMIDocuImage.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
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 JIMI toolkit
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 com.sun.jimi.core.*;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
29 import com.sun.jimi.core.raster.*;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
30 import com.sun.jimi.core.filters.*;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
31
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
32 import java.awt.*;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
33 import java.awt.image.*;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
34
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
35 import digilib.*;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
36 import digilib.io.*;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
37
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
38
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
39 public class JIMIDocuImage extends DocuImageImpl {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
40
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
41 private JimiRasterImage img;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
42 private ImageProducer imgp;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
43
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
44 public JIMIDocuImage() {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
45 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
46
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
47 public JIMIDocuImage(Utils u) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
48 util = u;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
49 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
50
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
51 /**
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
52 * load image file
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
53 */
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
54 public void loadImage(File f) throws FileOpException {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
55 System.gc();
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
56 try {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
57 img = Jimi.getRasterImage(f.toURL());
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
58 } catch (java.net.MalformedURLException e) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
59 util.dprintln(3, "ERROR(loadImage): MalformedURLException");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
60 } catch (JimiException e) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
61 util.dprintln(3, "ERROR(loadImage): JIMIException");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
62 throw new FileOpException("Unable to load File!"+e);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
63 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
64 if (img == null) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
65 util.dprintln(3, "ERROR(loadImage): unable to load file");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
66 throw new FileOpException("Unable to load File!");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
67 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
68 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
69
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
70 /**
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
71 * write image of type mt to Stream
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
72 */
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
73 public void writeImage(String mt, ServletResponse res)
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
74 throws FileOpException {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
75 try {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
76 // setup output
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
77 res.setContentType(mt);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
78 // render output
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
79 Jimi.putImage(mt, imgp, res.getOutputStream());
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
80
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
81 } catch (JimiException e) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
82 throw new FileOpException("Error writing image!"+e);
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."+e);
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 ImageFilter scaleFilter;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
112 int destWidth = (int)(scale * (float)width);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
113 int destHeight = (int)(scale * (float)height);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
114
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
115 // setup Crop
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
116 ImageProducer croppedImg = img.getCroppedImageProducer(x_off, y_off, width, height);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
117 //util.dprintln(3, "CROP:"+croppedImg.getWidth()+"x"+croppedImg.getHeight()); //DEBUG
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
118
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
119 if (croppedImg == null) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
120 util.dprintln(2, "ERROR(cropAndScale): error in crop");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
121 throw new ImageOpException("Unable to crop");
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 scale and interpolation quality
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
125 if (qual > 0) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
126 util.dprintln(4, "quality q1");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
127 scaleFilter = new AreaAverageScaleFilter(destWidth, destHeight);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
128 } else {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
129 util.dprintln(4, "quality q0");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
130 scaleFilter = new ReplicatingScaleFilter(destWidth, destHeight);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
131 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
132
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
133 ImageProducer scaledImg = new FilteredImageSource(croppedImg, scaleFilter);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
134
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
135 if (scaledImg == null) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
136 util.dprintln(2, "ERROR(cropAndScale): error in scale");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
137 throw new ImageOpException("Unable to scale");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
138 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
139
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
140 imgp = scaledImg;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
141 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
142
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
143 }