Llevo unos cuatro años ya trabajando en proyectos con Java y nunca había tenido que trabajar con la API de imágenes que Sun proporciona. Bueno, pues ahora estoy embarcado en un pequeño proyecto en el cual había que procesar imágenes.

Como siempre me pasa, debido a tiempos, prefiero tirar de google y mirar lo que alguien ha andado y defenderme como buenamente puedo, antes que estudiar a fondo la API. Craso error. Después de dar vueltas sobre código algo obsoleto, descubro la clase ImageIO, disponible a partir de la versión 1.4, más potente para estos menesteres.

No es una panacea de clase, pero seguro que ayuda a más de un despistado como yo hace un par de días.

Actualización: Javier Murillo me manda una actualización de la clase. Está publicada en el siguiente hilo

JAVA:
  1.  
  2. /*
  3. * ImageUtils.java
  4. *
  5. * Created on 20 de julio de 2005, 11:47
  6. * Resizes jpeg image files on your file system.
  7. * Uses the com.sun.image.codec.jpeg package shipped
  8. * by Sun with Java 2 Standard Edition.
  9. *
  10. * @author Randy Belknap
  11. * @revision Alejandro Sánchez Marcos
  12. * se aprovecha la nueva clase ImageIO de 1.4
  13. * y se añaden algunos métodos nuevos
  14. */
  15.  
  16. package com.electroduendes.util.image;
  17.  
  18. import java.awt.geom.AffineTransform;
  19. import java.awt.image.AffineTransformOp;
  20. import java.awt.image.BufferedImage;
  21. import java.io.File;
  22. import javax.imageio.ImageIO;
  23. import org.apache.log4j.Logger;
  24.  
  25. /**
  26. */
  27. public class ImageUtils {
  28. static Logger logger = Logger.getLogger(ImageUtils.class);
  29. /*
  30. * devuelve la lista de formatos disponibles a leer por ImageIO
  31. * @return un array de strings con los mismos.
  32. */
  33. public static String[] getAvailableFormats(){
  34. return ImageIO.getReaderFormatNames();
  35. }
  36.  
  37. /*
  38. * devuelve una imagen (buffer) en función de la ruta de un archivo
  39. * mejoras
  40. * @param la ruta del archivo con su nombre
  41. * @return BufferedImage la imagen en el buffer
  42. */
  43. public static BufferedImage loadBufferedImage(String fileName) {
  44. BufferedImage image = null;
  45. try {
  46. /*FileInputStream fis = new FileInputStream(fileName);JPEGImageDecoder decoder = JPEGCodec.createJPEGDecoder(fis);bi = decoder.decodeAsBufferedImage();fis.close();*/
  47. // MAS RAPIDO a partir de 1.4
  48. image = ImageIO.read( new File( fileName ) );
  49. }
  50. catch (Exception e) {
  51. logger.debug("error al intentar leer la imágen");
  52. return null;
  53. }
  54. return image;
  55.  
  56. }
  57. /**
  58. * comprueba que la imágen tiene un mínimo en pixels
  59. * width y height tienen que tener un tamaño igual o mayor que el pasado
  60. * como argumento
  61. *
  62. * @param w ancho mínimo
  63. * @param h alto mínimo
  64. * @return true o false
  65. *
  66. */
  67. public static boolean isGreaterThanMinSize(int w, int h, BufferedImage imgSrc){
  68. int nHeight = imgSrc.getHeight();
  69. int nWidth = imgSrc.getWidth();
  70. if ((nHeight return false;
  71. } else {
  72. return true;
  73. }
  74. }
  75.  
  76. /*
  77. * calcula el factor de escala mínimo y en base a eso escala la imagen
  78. * según el dicho factor.
  79. * @param nMaxWidth minimo tamaño para el ancho
  80. * @param nMaxHeight minimo tamaño para el alto
  81. * @param imgSrc la imágen
  82. */
  83. public static BufferedImage scaleToSize(int nMaxWidth, int nMaxHeight, BufferedImage imgSrc) {
  84. int nHeight = imgSrc.getHeight();
  85. int nWidth = imgSrc.getWidth();
  86. double scaleX = (double)nMaxWidth / (double)nWidth;
  87. double scaleY = (double)nMaxHeight / (double)nHeight;
  88. double fScale = Math.min(scaleX, scaleY);
  89. return scale(fScale, imgSrc);
  90. }
  91.  
  92. /*
  93. * escala una imagen en porcentaje.
  94. * @param scale ejemplo: scale=0.6 (escala la imágen al 60%)
  95. * @param srcImg una imagen BufferedImage
  96. * @return un BufferedImage escalado
  97. */
  98. public static BufferedImage scale(double scale, BufferedImage srcImg) {
  99. if (scale == 1 ) {
  100. return srcImg;
  101. }
  102. (AffineTransform.getScaleInstance(scale, scale), null);
  103.  
  104. return op.filter(srcImg, null);
  105.  
  106. }
  107.  
  108. public static void saveImageToDisk(BufferedImage bi, String str, String format) {
  109. if (bi != null && str != null) {
  110.  
  111. // más rápido con ImageIO
  112. try {
  113. ImageIO.write( bi, format /* formato */, new File( str ) /* destino */ );
  114. } catch (Exception e){}
  115. }
  116. }
  117.  
  118. public static void main(String args[]) {
  119. if(args.length != 3){usage();}
  120. System.out.println(args[0]);
  121. BufferedImage bImg = loadBufferedImage(args[0]);
  122. System.out.println(bImg);
  123. BufferedImage bImgEscaladaG = scaleToSize(800, 600, bImg);
  124. BufferedImage bImgEscaladaP = scaleToSize(320, 200, bImg);
  125.  
  126. saveImageToDisk(bImgEscaladaG, args[1],"JPEG");
  127. saveImageToDisk(bImgEscaladaP, args[2],"JPEG");
  128. System.exit(0);
  129. }
  130.  
  131. public static void usage(){
  132. System.out.println("usage: java ImageUtils archivo_original imagen_grande imagen_pequeña ");
  133. System.exit(1);
  134. }
  135.  
  136. }
  137.