annotate servlet/src/digilib/image/JIMIDocuImage.java @ 73:3b8797fc3e90

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 63c8186455c1
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
73
3b8797fc3e90 New servlet version 1.5b.
robcast
parents: 1
diff changeset
39 /** Implementation of DocuImage using the JIMI image Library. */
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
40 public class JIMIDocuImage extends DocuImageImpl {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
41
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
42 private JimiRasterImage img;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
43 private ImageProducer imgp;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
44
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
45 public JIMIDocuImage() {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
46 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
47
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
48 public JIMIDocuImage(Utils u) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
49 util = u;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
50 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
51
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
52 /**
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
53 * load image file
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
54 */
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
55 public void loadImage(File f) throws FileOpException {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
56 System.gc();
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
57 try {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
58 img = Jimi.getRasterImage(f.toURL());
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
59 } catch (java.net.MalformedURLException e) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
60 util.dprintln(3, "ERROR(loadImage): MalformedURLException");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
61 } catch (JimiException e) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
62 util.dprintln(3, "ERROR(loadImage): JIMIException");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
63 throw new FileOpException("Unable to load File!"+e);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
64 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
65 if (img == null) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
66 util.dprintln(3, "ERROR(loadImage): unable to load file");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
67 throw new FileOpException("Unable to load File!");
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 /**
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
72 * write image of type mt to Stream
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
73 */
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
74 public void writeImage(String mt, ServletResponse res)
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
75 throws FileOpException {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
76 try {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
77 // setup output
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
78 res.setContentType(mt);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
79 // render output
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
80 Jimi.putImage(mt, imgp, res.getOutputStream());
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
81
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
82 } catch (JimiException e) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
83 throw new FileOpException("Error writing image!"+e);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
84 } catch (IOException e) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
85 throw new FileOpException("Error writing image."+e);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
86 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
87 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
88
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
89 public int getWidth() {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
90 if (img != null) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
91 return img.getWidth();
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
92 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
93 return 0;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
94 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
95
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
96 public int getHeight() {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
97 if (img != null) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
98 return img.getHeight();
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
99 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
100 return 0;
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 /**
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
105 * crop and scale image
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
106 * take rectangle width,height at position x_off,y_off
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
107 * and scale by scale
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
108 */
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
109 public void cropAndScale(int x_off, int y_off, int width, int height,
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
110 float scale, int qual) throws ImageOpException {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
111
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
112 ImageFilter scaleFilter;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
113 int destWidth = (int)(scale * (float)width);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
114 int destHeight = (int)(scale * (float)height);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
115
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
116 // setup Crop
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
117 ImageProducer croppedImg = img.getCroppedImageProducer(x_off, y_off, width, height);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
118 //util.dprintln(3, "CROP:"+croppedImg.getWidth()+"x"+croppedImg.getHeight()); //DEBUG
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
119
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
120 if (croppedImg == null) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
121 util.dprintln(2, "ERROR(cropAndScale): error in crop");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
122 throw new ImageOpException("Unable to crop");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
123 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
124
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
125 // setup scale and interpolation quality
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
126 if (qual > 0) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
127 util.dprintln(4, "quality q1");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
128 scaleFilter = new AreaAverageScaleFilter(destWidth, destHeight);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
129 } else {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
130 util.dprintln(4, "quality q0");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
131 scaleFilter = new ReplicatingScaleFilter(destWidth, destHeight);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
132 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
133
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
134 ImageProducer scaledImg = new FilteredImageSource(croppedImg, scaleFilter);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
135
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
136 if (scaledImg == null) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
137 util.dprintln(2, "ERROR(cropAndScale): error in scale");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
138 throw new ImageOpException("Unable to scale");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
139 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
140
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
141 imgp = scaledImg;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
142 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
143
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
144 }