/*
 * 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); } }