`
eimhee
  • 浏览: 2150979 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

一个JAVA图形缩放处理工具类

阅读更多
 调用的例子
  1. import java.io.FileOutputStream;
  2. import java.io.IOException;

  3. import javax.imageio.ImageIO;

  4. public class T {
  5.   public static void main(String[] args) throws Exception, IOException {
  6.     ImageIO.write(ImageUtils.resizeImage("d:/www.java2000.net.gif", ImageUtils.IMAGE_GIF, 3020),
  7.         "JPEG"new FileOutputStream("d:/test.jpg"));
  8.   }
  9. }

源代码,如果你复制源代码不方便,来这里:http://www.java2000.net/p10821
  1. import java.awt.Dimension;
  2. import java.awt.Image;
  3. import java.awt.image.BufferedImage;
  4. import java.awt.image.PixelGrabber;
  5. import java.io.File;
  6. import java.io.IOException;
  7. import java.util.Iterator;
  8. import java.util.Locale;
  9. import javax.imageio.IIOImage;
  10. import javax.imageio.ImageIO;
  11. import javax.imageio.ImageWriteParam;
  12. import javax.imageio.ImageWriter;
  13. import javax.imageio.plugins.jpeg.JPEGImageWriteParam;
  14. import javax.imageio.stream.ImageOutputStream;
  15. public class ImageUtils {
  16.   public static final int IMAGE_UNKNOWN = -1;
  17.   public static final int IMAGE_JPEG = 0;
  18.   public static final int IMAGE_PNG = 1;
  19.   public static final int IMAGE_GIF = 2;
  20.   /**
  21.    * Resizes an image
  22.    * 
  23.    * @param imgName
  24.    *          The image name to resize. Must be the complet path to the file
  25.    * @param type
  26.    *          int
  27.    * @param maxWidth
  28.    *          The image's max width
  29.    * @param maxHeight
  30.    *          The image's max height
  31.    * @return A resized <code>BufferedImage</code>
  32.    */
  33.   public static BufferedImage resizeImage(String imgName, int type, int maxWidth, int maxHeight) {
  34.     try {
  35.       return resizeImage(ImageIO.read(new File(imgName)), type, maxWidth, maxHeight);
  36.     } catch (IOException e) {
  37.       e.printStackTrace();
  38.       return null;
  39.     }
  40.   }
  41.   /**
  42.    * Resizes an image.
  43.    * 
  44.    * @param image
  45.    *          The image to resize
  46.    * @param maxWidth
  47.    *          The image's max width
  48.    * @param maxHeight
  49.    *          The image's max height
  50.    * @return A resized <code>BufferedImage</code>
  51.    * @param type
  52.    *          int
  53.    */
  54.   public static BufferedImage resizeImage(BufferedImage image, int type, int maxWidth, int maxHeight) {
  55.     Dimension largestDimension = new Dimension(maxWidth, maxHeight);
  56.     // Original size
  57.     int imageWidth = image.getWidth(null);
  58.     int imageHeight = image.getHeight(null);
  59.     float aspectRatio = (float) imageWidth / imageHeight;
  60.     if (imageWidth > maxWidth || imageHeight > maxHeight) {
  61.       if ((float) largestDimension.width / largestDimension.height > aspectRatio) {
  62.         largestDimension.width = (int) Math.ceil(largestDimension.height * aspectRatio);
  63.       } else {
  64.         largestDimension.height = (int) Math.ceil(largestDimension.width / aspectRatio);
  65.       }
  66.       imageWidth = largestDimension.width;
  67.       imageHeight = largestDimension.height;
  68.     }
  69.     return createHeadlessSmoothBufferedImage(image, type, imageWidth, imageHeight);
  70.   }
  71.   /**
  72.    * Saves an image to the disk.
  73.    * 
  74.    * @param image
  75.    *          The image to save
  76.    * @param toFileName
  77.    *          The filename to use
  78.    * @param type
  79.    *          The image type. Use <code>ImageUtils.IMAGE_JPEG</code> to save as
  80.    *          JPEG images, or <code>ImageUtils.IMAGE_PNG</code> to save as PNG.
  81.    * @return <code>false</code> if no appropriate writer is found
  82.    */
  83.   public static boolean saveImage(BufferedImage image, String toFileName, int type) {
  84.     try {
  85.       return ImageIO.write(image, type == IMAGE_JPEG ? "jpg" : "png"new File(toFileName));
  86.     } catch (IOException e) {
  87.       e.printStackTrace();
  88.       return false;
  89.     }
  90.   }
  91.   /**
  92.    * Compress and save an image to the disk. Currently this method only supports
  93.    * JPEG images.
  94.    * 
  95.    * @param image
  96.    *          The image to save
  97.    * @param toFileName
  98.    *          The filename to use
  99.    * @param type
  100.    *          The image type. Use <code>ImageUtils.IMAGE_JPEG</code> to save as
  101.    *          JPEG images, or <code>ImageUtils.IMAGE_PNG</code> to save as PNG.
  102.    */
  103.   public static void saveCompressedImage(BufferedImage image, String toFileName, int type) {
  104.     try {
  105.       if (type == IMAGE_PNG) {
  106.         throw new UnsupportedOperationException("PNG compression not implemented");
  107.       }
  108.       Iterator iter = ImageIO.getImageWritersByFormatName("jpg");
  109.       ImageWriter writer;
  110.       writer = (ImageWriter) iter.next();
  111.       ImageOutputStream ios = ImageIO.createImageOutputStream(new File(toFileName));
  112.       writer.setOutput(ios);
  113.       ImageWriteParam iwparam = new JPEGImageWriteParam(Locale.getDefault());
  114.       iwparam.setCompressionMode(ImageWriteParam.MODE_EXPLICIT);
  115.       iwparam.setCompressionQuality(0.7F);
  116.       writer.write(nullnew IIOImage(image, nullnull), iwparam);
  117.       ios.flush();
  118.       writer.dispose();
  119.       ios.close();
  120.     } catch (IOException e) {
  121.       e.printStackTrace();
  122.     }
  123.   }
  124.   /**
  125.    * Creates a <code>BufferedImage</code> from an <code>Image</code>. This
  126.    * method can function on a completely headless system. This especially
  127.    * includes Linux and Unix systems that do not have the X11 libraries
  128.    * installed, which are required for the AWT subsystem to operate. This method
  129.    * uses nearest neighbor approximation, so it's quite fast. Unfortunately, the
  130.    * result is nowhere near as nice looking as the
  131.    * createHeadlessSmoothBufferedImage method.
  132.    * 
  133.    * @param image
  134.    *          The image to convert
  135.    * @param w
  136.    *          The desired image width
  137.    * @param h
  138.    *          The desired image height
  139.    * @return The converted image
  140.    * @param type
  141.    *          int
  142.    */
  143.   public static BufferedImage createHeadlessBufferedImage(BufferedImage image, int type, int width,
  144.       int height) {
  145.     if (type == ImageUtils.IMAGE_PNG && hasAlpha(image)) {
  146.       type = BufferedImage.TYPE_INT_ARGB;
  147.     } else {
  148.       type = BufferedImage.TYPE_INT_RGB;
  149.     }
  150.     BufferedImage bi = new BufferedImage(width, height, type);
  151.     for (int y = 0; y < height; y++) {
  152.       for (int x = 0; x < width; x++) {
  153.         bi.setRGB(x, y, image.getRGB(x * image.getWidth() / width, y * image.getHeight() / height));
  154.       }
  155.     }
  156.     return bi;
  157.   }
  158.   /**
  159.    * Creates a <code>BufferedImage</code> from an <code>Image</code>. This
  160.    * method can function on a completely headless system. This especially
  161.    * includes Linux and Unix systems that do not have the X11 libraries
  162.    * installed, which are required for the AWT subsystem to operate. The
  163.    * resulting image will be smoothly scaled using bilinear filtering.
  164.    * 
  165.    * @param source
  166.    *          The image to convert
  167.    * @param w
  168.    *          The desired image width
  169.    * @param h
  170.    *          The desired image height
  171.    * @return The converted image
  172.    * @param type
  173.    *          int
  174.    */
  175.   public static BufferedImage createHeadlessSmoothBufferedImage(BufferedImage source, int type,
  176.       int width, int height) {
  177.     if (type == ImageUtils.IMAGE_PNG && hasAlpha(source)) {
  178.       type = BufferedImage.TYPE_INT_ARGB;
  179.     } else {
  180.       type = BufferedImage.TYPE_INT_RGB;
  181.     }
  182.     BufferedImage dest = new BufferedImage(width, height, type);
  183.     int sourcex;
  184.     int sourcey;
  185.     double scalex = (double) width / source.getWidth();
  186.     double scaley = (double) height / source.getHeight();
  187.     int x1;
  188.     int y1;
  189.     double xdiff;
  190.     double ydiff;
  191.     int rgb;
  192.     int rgb1;
  193.     int rgb2;
  194.     for (int y = 0; y < height; y++) {
  195.       sourcey = y * source.getHeight() / dest.getHeight();
  196.       ydiff = scale(y, scaley) - sourcey;
  197.       for (int x = 0; x < width; x++) {
  198.         sourcex = x * source.getWidth() / dest.getWidth();
  199.         xdiff = scale(x, scalex) - sourcex;
  200.         x1 = Math.min(source.getWidth() - 1, sourcex + 1);
  201.         y1 = Math.min(source.getHeight() - 1, sourcey + 1);
  202.         rgb1 = getRGBInterpolation(source.getRGB(sourcex, sourcey), source.getRGB(x1, sourcey),
  203.             xdiff);
  204.         rgb2 = getRGBInterpolation(source.getRGB(sourcex, y1), source.getRGB(x1, y1), xdiff);
  205.         rgb = getRGBInterpolation(rgb1, rgb2, ydiff);
  206.         dest.setRGB(x, y, rgb);
  207.       }
  208.     }
  209.     return dest;
  210.   }
  211.   private static double scale(int point, double scale) {
  212.     return point / scale;
  213.   }
  214.   private static int getRGBInterpolation(int value1, int value2, double distance) {
  215.     int alpha1 = (value1 & 0xFF000000) >>> 24;
  216.     int red1 = (value1 & 0x00FF0000) >> 16;
  217.     int green1 = (value1 & 0x0000FF00) >> 8;
  218.     int blue1 = (value1 & 0x000000FF);
  219.     int alpha2 = (value2 & 0xFF000000) >>> 24;
  220.     int red2 = (value2 & 0x00FF0000) >> 16;
  221.     int green2 = (value2 & 0x0000FF00) >> 8;
  222.     int blue2 = (value2 & 0x000000FF);
  223.     int rgb = ((int) (alpha1 * (1.0 - distance) + alpha2 * distance) << 24)
  224.         | ((int) (red1 * (1.0 - distance) + red2 * distance) << 16)
  225.         | ((int) (green1 * (1.0 - distance) + green2 * distance) << 8)
  226.         | (int) (blue1 * (1.0 - distance) + blue2 * distance);
  227.     return rgb;
  228.   }
  229.   /**
  230.    * Determines if the image has transparent pixels.
  231.    * 
  232.    * @param image
  233.    *          The image to check for transparent pixel.s
  234.    * @return <code>true</code> of <code>false</code>, according to the result
  235.    */
  236.   public static boolean hasAlpha(Image image) {
  237.     try {
  238.       PixelGrabber pg = new PixelGrabber(image, 0011false);
  239.       pg.grabPixels();
  240.       return pg.getColorModel().hasAlpha();
  241.     } catch (InterruptedException e) {
  242.       return false;
  243.     }
  244.   }
  245. }

分享到:
评论
1 楼 zzzsmail 2009-01-21  
[img][/img][url][/url][flash=200,200][/flash][size=xx-small][/size][align=left][/align][/color][color=cyan][/color][color=darkblue]  

相关推荐

    java图片处理工具类

    在Java编程语言中,处理图片是一项常见的任务,尤其在网页开发、移动应用或者图形用户界面设计中。本篇文章将深入探讨如何使用Java...通过深入理解这些技术,我们可以创建出强大的图片处理工具类,满足日常开发需求。

    图片裁剪、缩放工具类

    总结来说,这个图片裁剪和缩放工具类是一个实用的Java库,涵盖了图片操作的基本需求,同时具备生成图形验证码的能力。它的两种处理方式提供了灵活性,适应不同的应用场景,且其有效性已经在实际项目中得到验证。对于...

    毕业论文设计-IT计算机-java图形图象处理(论文+系统).zip

    这篇毕业论文设计主要聚焦在IT计算机领域,使用Java语言进行图形图像处理的实践与研究。...通过这样的项目,学生可以深入理解Java图形图像处理的原理,同时掌握软件开发的完整流程,为未来的职业生涯打下坚实的基础。

    java图形图象处理(论文+系统).zip

    Java图形图像处理是一个涵盖广泛的领域,它涉及到使用Java编程语言来创建、编辑、分析和显示图像。这个领域的应用包括但不限于科学可视化、艺术创作、工程设计、数据可视化以及各种软件界面的美化。在这个“java图形...

    java图形图象处理(论文+系统)

    5. **毕业设计与论文**:在Java图形图像处理的毕业设计中,学生通常会面临创建一个具有特定功能的图像处理系统,比如图像编辑器、人脸识别系统或图像分析工具。论文则需要详细阐述所采用的技术、实现方法以及实验...

    java图片加水印工具类

    总之,这个“java图片加水印工具类”是一个实用的组件,可以帮助Java开发者轻松地在图片上添加水印,提升工作效率,同时保持代码的整洁和可维护性。无论你是进行个人项目还是企业级应用,它都能成为一个有价值的辅助...

    java 图片缩放类

    `DwindlePic` 类是一个简单的Java图片缩放工具,通过合理地利用Java标准库中的类和接口,实现了基本的图片加载、缩放和保存功能。在实际应用中可以根据需要进一步扩展该类的功能,例如添加异常处理机制、支持更多的...

    JAVA源码JAVA图形图象处理(论文+系统)

    - `java.awt.image.BufferedImage`是Java自带的一个用于处理图像的类。 - 它提供了读取、写入和修改图像的基本方法。 2. **JAI (Java Advanced Imaging)** - JAI是一个强大的图像处理库,它可以实现复杂图像操作...

    java从图片缩放

    在Java编程中,图片缩放是一项常见的任务,特别是在开发图形用户界面(GUI)或处理图像数据时。这个主题涉及到图像处理的基本概念、Java中的图像API以及如何使用它们来实现缩放功能。以下是对这一主题的详细说明: ...

    java图形图象处理(系统)

    Java图形图像处理是一个涵盖广泛的领域,它涉及到使用Java编程语言来创建、操作和显示各种图形和图像。在Java中,图形图像处理主要依赖于Java AWT(Abstract Window Toolkit)和Swing这两个库,它们提供了丰富的API...

    java图形图象处理.zip

    Java图形图像处理是一个涵盖广泛的领域,它涉及到使用Java编程语言来创建、操作和显示各种图形和图像。在Java中,图形图像处理主要依赖于Java 2D API(Application Programming Interface)和Java AWT(Abstract ...

    java图形图象处理(论文+系统).rar

    Java图形图像处理的一个关键部分是`java.awt.image`包,它包含了一系列用于图像操作的类,如`BufferedImage`用于存储和操作图像,`ImageFilter`用于图像过滤和转换,`ColorModel`和`Raster`则用于处理像素数据。...

    (毕业设计)java图形图象处理(论文+系统)

    Java图形图像处理是一个涵盖广泛的领域,它涉及到使用Java编程语言来创建、编辑、分析和展示图像。在Java中,这主要通过Java的丰富的图形库,如Java AWT(Abstract Window Toolkit)和Swing来实现。这些库提供了丰富...

    毕业答辩-java图形图象处理(论文系统).rar

    Java图形图像处理是一个涵盖广泛领域的主题,特别是在软件开发中,尤其是在毕业设计或论文项目中,它经常被用作展示技术能力和创新思维的平台。在这个Java图形图像处理的论文系统中,我们可以推测它可能包含了以下几...

    java图形图象处理(文+系统).zip

    Java图形图像处理是一个涵盖广泛的领域,它涉及到使用Java编程语言来创建、操作和显示各种图形和图像。在Java中,图形图像处理主要依赖于Java 2D API和JavaFX库,这两个工具集提供了丰富的功能,使得开发者能够进行...

    JAVA开发java图形图象处理(论文+系统)

    Java图形图像处理是Java开发中的一个重要领域,尤其在软件工程的毕业设计中,它经常作为学生展示编程技能和解决问题能力的课题。这个压缩包文件很可能包含了一篇关于该主题的论文以及一个实际的图像处理系统源代码。...

    java图形图象处理毕设论文源代码程序

    Java图形图像处理是计算机科学领域中的一个重要分支,特别是在软件开发和毕业设计中常常被用作实践项目。这篇毕设论文的源代码程序旨在探讨如何利用Java语言进行有效的图像操作和处理。下面将详细阐述Java在图形图像...

    Java图片处理工具ImageMagick

    Java图片处理工具ImageMagick是一个强大的跨平台图形处理库,它允许开发人员在Java应用程序中进行复杂的图像操作,包括但不限于转换、编辑、合成图像以及处理大量格式的图像文件。ImageMagick是由C语言编写的,但...

Global site tag (gtag.js) - Google Analytics