changeset 64:5ea1999befd4

New JAI ImageLoader plugin. Currently uses first beta version of the plugin. Needs Java 1.4. digilib/io/FileOps.java digilib/servlet/Scaler.java Modified to use JAIImageLoaderDocuImage. digilib/image/JAIImageLoaderDocuImage.java New class JAIImageLoaderDocuImage.
author robcast
date Tue, 07 Jan 2003 18:26:06 +0100
parents c2ac0efbce8d
children 842e3ccabc60
files servlet/src/digilib/image/JAIImageLoaderDocuImage.java servlet/src/digilib/io/FileOps.java servlet/src/digilib/servlet/Scaler.java
diffstat 3 files changed, 179 insertions(+), 6 deletions(-) [+]
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/servlet/src/digilib/image/JAIImageLoaderDocuImage.java	Tue Jan 07 18:26:06 2003 +0100
@@ -0,0 +1,168 @@
+/* JAIImageLoaderDocuImage -- Image class implementation using JAI's ImageLoader Plugin
+
+  Digital Image Library servlet components
+
+  Copyright (C) 2001, 2002 Robert Casties (robcast@mail.berlios.de)
+
+  This program is free software; you can redistribute  it and/or modify it
+  under  the terms of  the GNU General  Public License as published by the
+  Free Software Foundation;  either version 2 of the  License, or (at your
+  option) any later version.
+   
+  Please read license.txt for the full details. A copy of the GPL
+  may be found at http://www.gnu.org/copyleft/lgpl.html
+
+  You should have received a copy of the GNU General Public License
+  along with this program; if not, write to the Free Software
+  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
+
+*/
+
+package digilib.image;
+
+import javax.servlet.*;
+import javax.servlet.http.*;
+import java.io.*;
+import java.util.*;
+
+import java.awt.*;
+import java.awt.image.*;
+import java.awt.image.renderable.*;
+import javax.media.jai.*;
+
+import digilib.*;
+import digilib.io.*;
+
+
+public class JAIImageLoaderDocuImage extends DocuImageImpl {
+
+  private RenderedImage img;
+
+  public JAIImageLoaderDocuImage() {
+  }
+
+  public JAIImageLoaderDocuImage(Utils u) {
+    util = u;
+  }
+
+  /**
+   *  load image file
+   */
+  public void loadImage(File f) throws FileOpException {
+    System.gc();
+    img = JAI.create("ImageRead", f.getAbsolutePath());
+    if (img == null) {
+      util.dprintln(3, "ERROR(loadImage): unable to load file");
+      throw new FileOpException("Unable to load File!");
+    }
+  }
+
+  /**
+   *  write image of type mt to Stream
+   */
+  public void writeImage(String mt, ServletResponse res)
+         throws FileOpException {
+    try {
+    // setup output
+    ParameterBlock pb3 = new ParameterBlock();
+    pb3.addSource(img);
+    pb3.add(res.getOutputStream());
+    if (mt == "image/jpeg") {
+      pb3.add("JPEG");
+    } else if (mt == "image/png") {
+      pb3.add("PNG");
+    } else {
+      // unknown mime type
+      util.dprintln(2, "ERROR(writeImage): Unknown mime type "+mt);
+      throw new FileOpException("Unknown mime type: "+mt);
+    }
+    res.setContentType(mt);
+    // render output
+    JAI.create("ImageWrite", pb3);
+
+    } catch (IOException e) {
+      throw new FileOpException("Error writing image.");
+    }
+  }
+
+  public int getWidth() {
+    if (img != null) {
+      return img.getWidth();
+    }
+    return 0;
+  }
+
+  public int getHeight() {
+    if (img != null) {
+      return img.getHeight();
+    }
+    return 0;
+  }
+
+
+  /**
+   *  crop and scale image
+   *    take rectangle width,height at position x_off,y_off
+   *    and scale by scale
+   */
+   public void cropAndScale(int x_off, int y_off, int width, int height,
+         float scale, int qual) throws ImageOpException {
+
+    Interpolation scaleInt = null;
+    // setup interpolation quality
+    if (qual > 1) {
+      util.dprintln(4, "quality q2");
+      scaleInt = Interpolation.getInstance(Interpolation.INTERP_BICUBIC);
+    } else if (qual == 1) {
+      util.dprintln(4, "quality q1");
+      scaleInt = Interpolation.getInstance(Interpolation.INTERP_BILINEAR);
+    } else {
+      util.dprintln(4, "quality q0");
+      scaleInt = Interpolation.getInstance(Interpolation.INTERP_NEAREST);
+    }
+
+    // setup Crop
+    ParameterBlock pb1 = new ParameterBlock();
+    pb1.addSource(img);
+    pb1.add((float)x_off);
+    pb1.add((float)y_off);
+    pb1.add((float)width);
+    pb1.add((float)height);
+    RenderedImage croppedImg = JAI.create("crop", pb1);
+    img = null; // free img
+
+    util.dprintln(3, "CROP:"+croppedImg.getWidth()+"x"+croppedImg.getHeight()); //DEBUG
+
+    if (croppedImg == null) {
+      util.dprintln(2, "ERROR(cropAndScale): error in crop");
+      throw new ImageOpException("Unable to crop");
+    }
+
+    // setup scale
+    ParameterBlock pb2 = new ParameterBlock();
+    pb2.addSource(croppedImg);
+    pb2.add(scale);
+    pb2.add(scale);
+    pb2.add(0f);
+    pb2.add(0f);
+    pb2.add(scaleInt);
+    // the following is nice but way too slow...
+    //if (opCrop.getColorModel().getPixelSize() < 8) {
+    // change color model if necessary
+    //  util.dprintln("converting color model...");
+    //  BufferedImage bi = new BufferedImage(1, 1, BufferedImage.TYPE_BYTE_GRAY);
+    //  ImageLayout lay = new ImageLayout(bi);
+    //  rh = new RenderingHints(JAI.KEY_IMAGE_LAYOUT, lay);
+    //}
+    RenderedImage scaledImg = JAI.create("scale", pb2);
+    croppedImg = null; // free opCrop
+
+    if (scaledImg == null) {
+      util.dprintln(2, "ERROR(cropAndScale): error in scale");
+      throw new ImageOpException("Unable to scale");
+    }
+
+    img = scaledImg;
+  }
+
+}
--- a/servlet/src/digilib/io/FileOps.java	Wed Aug 28 23:21:31 2002 +0200
+++ b/servlet/src/digilib/io/FileOps.java	Tue Jan 07 18:26:06 2003 +0100
@@ -32,6 +32,7 @@
   public static String[] fileTypes = {
             "jpg", "image/jpeg",
             "jpeg", "image/jpeg",
+            "jp2", "image/jp2",
             "png", "image/png",
             "gif", "image/gif",
             "tif", "image/tiff",
--- a/servlet/src/digilib/servlet/Scaler.java	Wed Aug 28 23:21:31 2002 +0200
+++ b/servlet/src/digilib/servlet/Scaler.java	Tue Jan 07 18:26:06 2003 +0100
@@ -30,6 +30,7 @@
 import digilib.image.*;
 import digilib.auth.*;
 
+//import tilecachetool.*;
 
 //public class Scaler extends HttpServlet implements SingleThreadModel {
 public class Scaler extends HttpServlet {
@@ -61,6 +62,9 @@
   public void init(ServletConfig config) throws ServletException {
     super.init(config);
 
+    // Debuggin!
+    //TCTool tctool = new TCTool();
+    
     // first we need an Utils to setup ServletOps UGLY!!
     util = new Utils(5);
     // servletOps takes a ServletConfig to get the config file name
@@ -99,10 +103,10 @@
     // FileOps instance
     fileOp = new FileOps(util);
     // global DocuImage instance (don't reuse inside a request!)
-    globalImage = new JAIDocuImage(util);
-//    globalImage = new JIMIDocuImage(util);
+    //globalImage = new JAIDocuImage(util);
+    // globalImage = new JIMIDocuImage(util);
     //globalImage = new ImageLoaderDocuImage(util);
-
+    globalImage = new JAIImageLoaderDocuImage(util);
   }
 
   /**Process the HTTP Get request*/
@@ -207,10 +211,10 @@
     try {
 
     // DocuImage instance
-    DocuImage docuImage = new JAIDocuImage(util);
-//    DocuImage docuImage = new JIMIDocuImage(util);
+    //DocuImage docuImage = new JAIDocuImage(util);
+    //DocuImage docuImage = new JIMIDocuImage(util);
     //DocuImage docuImage = new ImageLoaderDocuImage(util);
-
+    DocuImage docuImage = new JAIImageLoaderDocuImage(util);
 
     /**
      *  find the file to load/send