/*
* Copyright (c) 2009, 2013, Oracle and/or its affiliates. All rights reserved.
* ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*/
package com.sun.javafx.iio;
import com.sun.javafx.iio.ImageStorage.ImageType;
import java.nio.Buffer;
import java.nio.ByteBuffer;
/**
* A class representing the data and metadata of a single image.
*/
public class ImageFrame {
private ImageType imageType;
private ByteBuffer imageData;
private int width;
private int height;
private int stride;
private float pixelScale;
private byte[][] palette;
private ImageMetadata metadata;
/**
* Create an ImageFrame
with a default 72DPI pixel scale.
*
* @param imageType The type of image data. The value of this field also
* implies the number of bands.
* @param imageData The image data.
* @param width The image width.
* @param height The image height.
* @param stride The stride from a pixel position in one row to the same
* horizontal position in the next row.
* @param palette The image palette. This is ignored unless the type is
* one of the palette types.
* @param metadata The image metadata.
*/
public ImageFrame(ImageType imageType, ByteBuffer imageData,
int width, int height, int stride, byte[][] palette,
ImageMetadata metadata)
{
this(imageType, imageData,
width, height, stride, palette,
1.0f, metadata);
}
/**
* Create an ImageFrame
.
*
* @param imageType The type of image data. The value of this field also
* implies the number of bands.
* @param imageData The image data.
* @param width The image width.
* @param height The image height.
* @param stride The stride from a pixel position in one row to the same
* horizontal position in the next row.
* @param palette The image palette. This is ignored unless the type is
* one of the palette types.
* @param pixelScale The scale of a 72DPI virtual pixel in the resolution
* of the image (1.0f for 72DPI images, 2.0f for 144DPI images, etc.).
* @param metadata The image metadata.
*/
public ImageFrame(ImageType imageType, ByteBuffer imageData,
int width, int height, int stride, byte[][] palette,
float pixelScale, ImageMetadata metadata)
{
this.imageType = imageType;
this.imageData = imageData;
this.width = width;
this.height = height;
this.stride = stride;
this.palette = palette;
this.pixelScale = pixelScale;
this.metadata = metadata;
}
public ImageType getImageType() {
return this.imageType;
}
public Buffer getImageData() {
return this.imageData;
}
public int getWidth() {
return this.width;
}
public int getHeight() {
return this.height;
}
public int getStride() {
return this.stride;
}
public byte[][] getPalette() {
return this.palette;
}
public void setPixelScale(float pixelScale) {
this.pixelScale = pixelScale;
}
public float getPixelScale() {
return pixelScale;
}
public ImageMetadata getMetadata() {
return this.metadata;
}
}