/*
* Copyright (c) 2000, 2004, 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.Point;
import java.awt.image.BufferedImage;
import java.awt.image.ColorModel;
import java.awt.image.DataBuffer;
import java.awt.image.DirectColorModel;
import java.awt.image.PixelInterleavedSampleModel;
import java.awt.image.SampleModel;
import java.awt.image.SinglePixelPackedSampleModel;
import java.awt.image.WritableRaster;
import sun.java2d.SurfaceData;
WritableRasterNative
This class exists to wrap a native DataBuffer object. The
standard WritableRaster object assumes that a DataBuffer
of a given type (e.g., DataBuffer.TYPE_INT) implies a certain
subclass (e.g., DataBufferInt). But this is not always the
case. DataBufferNative, for example, may allow access to
integer-based data, but it is not DataBufferInt (which is a
final class and cannot be subclassed).
So this class exists simply to allow the WritableRaster
functionality for this new kind of DataBuffer object.
/**
* WritableRasterNative
* This class exists to wrap a native DataBuffer object. The
* standard WritableRaster object assumes that a DataBuffer
* of a given type (e.g., DataBuffer.TYPE_INT) implies a certain
* subclass (e.g., DataBufferInt). But this is not always the
* case. DataBufferNative, for example, may allow access to
* integer-based data, but it is not DataBufferInt (which is a
* final class and cannot be subclassed).
* So this class exists simply to allow the WritableRaster
* functionality for this new kind of DataBuffer object.
*/
public class WritableRasterNative extends WritableRaster {
public static WritableRasterNative createNativeRaster(SampleModel sm,
DataBuffer db)
{
return new WritableRasterNative(sm, db);
}
protected WritableRasterNative(SampleModel sm, DataBuffer db) {
super(sm, db, new Point(0, 0));
}
public static WritableRasterNative createNativeRaster(ColorModel cm,
SurfaceData sd,
int width,
int height)
{
SampleModel smHw = null;
int dataType = 0;
int scanStride = width;
switch (cm.getPixelSize()) {
case 8:
case 12:
// 8-bits uses PixelInterleavedSampleModel
if (cm.getPixelSize() == 8) {
dataType = DataBuffer.TYPE_BYTE;
} else {
dataType = DataBuffer.TYPE_USHORT;
}
int[] bandOffsets = new int[1];
bandOffsets[0] = 0;
smHw = new PixelInterleavedSampleModel(dataType, width,
height,
1, scanStride,
bandOffsets);
break;
// all others use SinglePixelPackedSampleModel
case 15:
case 16:
dataType = DataBuffer.TYPE_USHORT;
int[] bitMasks = new int[3];
DirectColorModel dcm = (DirectColorModel)cm;
bitMasks[0] = dcm.getRedMask();
bitMasks[1] = dcm.getGreenMask();
bitMasks[2] = dcm.getBlueMask();
smHw = new SinglePixelPackedSampleModel(dataType, width,
height, scanStride,
bitMasks);
break;
case 24:
case 32:
dataType = DataBuffer.TYPE_INT;
bitMasks = new int[3];
dcm = (DirectColorModel)cm;
bitMasks[0] = dcm.getRedMask();
bitMasks[1] = dcm.getGreenMask();
bitMasks[2] = dcm.getBlueMask();
smHw = new SinglePixelPackedSampleModel(dataType, width,
height, scanStride,
bitMasks);
break;
default:
throw new InternalError("Unsupported depth " +
cm.getPixelSize());
}
DataBuffer dbn = new DataBufferNative(sd, dataType,
width, height);
return new WritableRasterNative(smHw, dbn);
}
}