/* | 
|
 * Copyright (c) 1997, 2005, Oracle and/or its affiliates. All rights reserved. | 
|
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. | 
|
 * | 
|
 * This code is free software; you can redistribute it and/or modify it | 
|
 * under the terms of the GNU General Public License version 2 only, as | 
|
 * published by the Free Software Foundation.  Oracle designates this | 
|
 * particular file as subject to the "Classpath" exception as provided | 
|
 * by Oracle in the LICENSE file that accompanied this code. | 
|
 * | 
|
 * This code 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 | 
|
 * version 2 for more details (a copy is included in the LICENSE file that | 
|
 * accompanied this code). | 
|
 * | 
|
 * You should have received a copy of the GNU General Public License version | 
|
 * 2 along with this work; if not, write to the Free Software Foundation, | 
|
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. | 
|
 * | 
|
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA | 
|
 * or visit www.oracle.com if you need additional information or have any | 
|
 * questions. | 
|
*/  | 
|
package sun.awt.image;  | 
|
import java.awt.AWTException;  | 
|
import java.awt.Component;  | 
|
import java.awt.Graphics2D;  | 
|
import java.awt.GraphicsConfiguration;  | 
|
import java.awt.GraphicsDevice;  | 
|
import java.awt.ImageCapabilities;  | 
|
import java.awt.Rectangle;  | 
|
import java.awt.Transparency;  | 
|
import java.awt.geom.AffineTransform;  | 
|
import java.awt.image.BufferedImage;  | 
|
import java.awt.image.ColorModel;  | 
|
import java.awt.image.DirectColorModel;  | 
|
import java.awt.image.Raster;  | 
|
import java.awt.image.VolatileImage;  | 
|
import java.awt.image.WritableRaster;  | 
|
public class BufferedImageGraphicsConfig  | 
|
extends GraphicsConfiguration  | 
|
{ | 
|
private static final int numconfigs = BufferedImage.TYPE_BYTE_BINARY;  | 
|
private static BufferedImageGraphicsConfig configs[] =  | 
|
new BufferedImageGraphicsConfig[numconfigs];  | 
|
public static BufferedImageGraphicsConfig getConfig(BufferedImage bImg) {  | 
|
BufferedImageGraphicsConfig ret;  | 
|
int type = bImg.getType();  | 
|
if (type > 0 && type < numconfigs) {  | 
|
ret = configs[type];  | 
|
if (ret != null) {  | 
|
return ret;  | 
|
}  | 
|
}  | 
|
ret = new BufferedImageGraphicsConfig(bImg, null);  | 
|
if (type > 0 && type < numconfigs) {  | 
|
configs[type] = ret;  | 
|
}  | 
|
return ret;  | 
|
}  | 
|
GraphicsDevice gd;  | 
|
ColorModel model;  | 
|
Raster raster;  | 
|
int width, height;  | 
|
public BufferedImageGraphicsConfig(BufferedImage bufImg, Component comp) {  | 
|
        if (comp == null) { | 
|
this.gd = new BufferedImageDevice(this);  | 
|
        } else { | 
|
Graphics2D g2d = (Graphics2D)comp.getGraphics();  | 
|
this.gd = g2d.getDeviceConfiguration().getDevice();  | 
|
}  | 
|
this.model = bufImg.getColorModel();  | 
|
this.raster = bufImg.getRaster().createCompatibleWritableRaster(1, 1);  | 
|
this.width = bufImg.getWidth();  | 
|
this.height = bufImg.getHeight();  | 
|
}  | 
|
    /** | 
|
     * Return the graphics device associated with this configuration. | 
|
*/  | 
|
public GraphicsDevice getDevice() {  | 
|
return gd;  | 
|
}  | 
|
    /** | 
|
     * Returns a BufferedImage with channel layout and color model | 
|
     * compatible with this graphics configuration.  This method | 
|
     * has nothing to do with memory-mapping | 
|
     * a device.  This BufferedImage has | 
|
     * a layout and color model | 
|
     * that is closest to this native device configuration and thus | 
|
     * can be optimally blitted to this device. | 
|
*/  | 
|
public BufferedImage createCompatibleImage(int width, int height) {  | 
|
WritableRaster wr = raster.createCompatibleWritableRaster(width, height);  | 
|
return new BufferedImage(model, wr, model.isAlphaPremultiplied(), null);  | 
|
}  | 
|
    /** | 
|
     * Returns the color model associated with this configuration. | 
|
*/  | 
|
public ColorModel getColorModel() {  | 
|
return model;  | 
|
}  | 
|
    /** | 
|
     * Returns the color model associated with this configuration that | 
|
     * supports the specified transparency. | 
|
*/  | 
|
public ColorModel getColorModel(int transparency) {  | 
|
if (model.getTransparency() == transparency) {  | 
|
return model;  | 
|
}  | 
|
switch (transparency) {  | 
|
case Transparency.OPAQUE:  | 
|
return new DirectColorModel(24, 0xff0000, 0xff00, 0xff);  | 
|
case Transparency.BITMASK:  | 
|
return new DirectColorModel(25, 0xff0000, 0xff00, 0xff, 0x1000000);  | 
|
case Transparency.TRANSLUCENT:  | 
|
return ColorModel.getRGBdefault();  | 
|
default:  | 
|
return null;  | 
|
}  | 
|
}  | 
|
    /** | 
|
     * Returns the default Transform for this configuration.  This | 
|
     * Transform is typically the Identity transform for most normal | 
|
     * screens.  Device coordinates for screen and printer devices will | 
|
     * have the origin in the upper left-hand corner of the target region of | 
|
     * the device, with X coordinates | 
|
     * increasing to the right and Y coordinates increasing downwards. | 
|
     * For image buffers, this Transform will be the Identity transform. | 
|
*/  | 
|
public AffineTransform getDefaultTransform() {  | 
|
return new AffineTransform();  | 
|
}  | 
|
    /** | 
|
     * | 
|
     * Returns a Transform that can be composed with the default Transform | 
|
     * of a Graphics2D so that 72 units in user space will equal 1 inch | 
|
     * in device space. | 
|
     * Given a Graphics2D, g, one can reset the transformation to create | 
|
     * such a mapping by using the following pseudocode: | 
|
     * <pre> | 
|
     *      GraphicsConfiguration gc = g.getGraphicsConfiguration(); | 
|
     * | 
|
     *      g.setTransform(gc.getDefaultTransform()); | 
|
     *      g.transform(gc.getNormalizingTransform()); | 
|
     * </pre> | 
|
     * Note that sometimes this Transform will be identity (e.g. for | 
|
     * printers or metafile output) and that this Transform is only | 
|
     * as accurate as the information supplied by the underlying system. | 
|
     * For image buffers, this Transform will be the Identity transform, | 
|
     * since there is no valid distance measurement. | 
|
*/  | 
|
public AffineTransform getNormalizingTransform() {  | 
|
return new AffineTransform();  | 
|
}  | 
|
public Rectangle getBounds() {  | 
|
return new Rectangle(0, 0, width, height);  | 
|
}  | 
|
}  |