/***************************************************
*
* cismet GmbH, Saarbruecken, Germany
*
* ... and it just works.
*
****************************************************/
/*
* Copyright (C) 2010 srichter
*
* 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 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package de.cismet.tools.gui;
import org.jdesktop.swingx.graphics.ShadowRenderer;
import java.awt.Color;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.GraphicsEnvironment;
import java.awt.Image;
import java.awt.RenderingHints;
import java.awt.Transparency;
import java.awt.geom.AffineTransform;
import java.awt.image.BufferedImage;
import javax.swing.JComponent;
/**
* DOCUMENT ME!
*
* @author srichter
* @version $Revision$, $Date$
*/
public final class ImageUtil {
//~ Methods ----------------------------------------------------------------
/**
* DOCUMENT ME!
*
* @param bi DOCUMENT ME!
* @param component DOCUMENT ME!
* @param insetX DOCUMENT ME!
* @param insetY DOCUMENT ME!
*
* @return DOCUMENT ME!
*/
public static Image adjustScale(final BufferedImage bi,
final JComponent component,
final int insetX,
final int insetY) {
final double scalex = (double)component.getWidth() / bi.getWidth();
final double scaley = (double)component.getHeight() / bi.getHeight();
final double scale = Math.min(scalex, scaley);
if (scale <= 1d) {
return bi.getScaledInstance((int)(bi.getWidth() * scale) - insetX,
(int)(bi.getHeight() * scale)
- insetY,
Image.SCALE_SMOOTH);
} else {
return bi;
}
}
/**
* DOCUMENT ME!
*
* @param bi DOCUMENT ME!
* @param targetW DOCUMENT ME!
* @param targetH DOCUMENT ME!
* @param insetX DOCUMENT ME!
* @param insetY DOCUMENT ME!
*
* @return DOCUMENT ME!
*/
public static Image adjustScale(final BufferedImage bi,
final int targetW,
final int targetH,
final int insetX,
final int insetY) {
final double scalex = (double)targetW / bi.getWidth();
final double scaley = (double)targetH / bi.getHeight();
final double scale = Math.min(scalex, scaley);
if (scale <= 1d) {
return bi.getScaledInstance((int)(bi.getWidth() * scale) - insetX,
(int)(bi.getHeight() * scale)
- insetY,
Image.SCALE_SMOOTH);
} else {
return bi;
}
}
/**
* DOCUMENT ME!
*
* @param origImage DOCUMENT ME!
* @param maxWidth DOCUMENT ME!
* @param maxHeight DOCUMENT ME!
*
* @return DOCUMENT ME!
*/
public static Image resizeOnScale(final Image origImage, final int maxWidth, final int maxHeight) {
final int origWidth = origImage.getWidth(null);
final int origHeight = origImage.getHeight(null);
final double ratio = origWidth / (double)origHeight;
final int resizedWidth;
final int resizedHeight;
if (ratio > (maxWidth / maxHeight)) {
resizedWidth = maxWidth;
resizedHeight = (int)Math.round(maxWidth / ratio);
} else {
resizedWidth = (int)Math.round(maxHeight * ratio);
resizedHeight = maxHeight;
}
return origImage.getScaledInstance(resizedWidth, resizedHeight, Image.SCALE_SMOOTH);
}
/**
* DOCUMENT ME!
*
* @param in DOCUMENT ME!
* @param shadowPixel DOCUMENT ME!
*
* @return DOCUMENT ME!
*/
public static BufferedImage generateShadow(final Image in, final int shadowPixel) {
if (in == null) {
return null;
}
final BufferedImage input;
if (in instanceof BufferedImage) {
input = (BufferedImage)in;
} else {
final BufferedImage temp = new BufferedImage(in.getWidth(null),
in.getHeight(null),
BufferedImage.TYPE_4BYTE_ABGR);
final Graphics tg = temp.createGraphics();
tg.drawImage(in, 0, 0, null);
tg.dispose();
input = temp;
}
if (shadowPixel < 1) {
return input;
}
final ShadowRenderer renderer = new ShadowRenderer(shadowPixel, 0.5f, Color.BLACK);
final BufferedImage shadow = renderer.createShadow(input);
final BufferedImage result = new BufferedImage(input.getWidth() + (2 * shadowPixel),
input.getHeight()
+ (2 * shadowPixel),
BufferedImage.TYPE_4BYTE_ABGR);
final Graphics2D rg = result.createGraphics();
rg.drawImage(shadow, 0, 0, null);
rg.drawImage(input, 0, 0, null);
rg.dispose();
return result;
}
/**
* DOCUMENT ME!
*
* @param src DOCUMENT ME!
* @param degrees DOCUMENT ME!
*
* @return DOCUMENT ME!
*/
public static BufferedImage rotateImage(final BufferedImage src, final double degrees) {
final float radianAngle = (float)Math.toRadians(degrees);
final float sin = (float)Math.abs(Math.sin(radianAngle));
final float cos = (float)Math.abs(Math.cos(radianAngle));
final int width = src.getWidth();
final int height = src.getHeight();
final int newWidth = (int)Math.round((width * cos) + (height * sin));
final int newHeight = (int)Math.round((height * cos) + (width * sin));
final AffineTransform transform = AffineTransform.getTranslateInstance((newWidth - width) / 2,
(newHeight - height)
/ 2);
transform.rotate(radianAngle, width / 2, height / 2);
final BufferedImage result = GraphicsEnvironment.getLocalGraphicsEnvironment()
.getDefaultScreenDevice()
.getDefaultConfiguration()
.createCompatibleImage(newWidth, newHeight, Transparency.TRANSLUCENT);
final Graphics2D g = result.createGraphics();
g.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
g.setRenderingHint(RenderingHints.KEY_INTERPOLATION, RenderingHints.VALUE_INTERPOLATION_BICUBIC);
g.setRenderingHint(RenderingHints.KEY_RENDERING, RenderingHints.VALUE_RENDER_QUALITY);
g.drawRenderedImage(src, transform);
g.dispose();
return result;
}
}