JIU 0.12.0 Homepage

net.sourceforge.jiu.gui.awt
Class BufferedRGB24Image

java.lang.Object
  extended bynet.sourceforge.jiu.gui.awt.BufferedRGB24Image
All Implemented Interfaces:
ByteChannelImage, IntegerImage, PixelImage, RGB24Image, RGBImage, RGBIndex, RGBIntegerImage

public class BufferedRGB24Image
extends Object
implements RGB24Image

A bridge class to use BufferedImage objects (class defined in the standard runtime library, package java.awt.image) as RGB24Image objects within JIU. This class encapsulates a single BufferedImage object. It enables reusing existing BufferedImage objects as input or output of JIU operations, removing the necessity for the conversion step from java.awt.Image to net.sourceforge.jiu.data.PixelImage (or vice versa) and thus reducing memory consumption. The name of this class is a combination of BufferedImage (the class of the object that is encapsulated) and RGB24Image (the JIU image data interface).

Internally, this class uses BufferedImage's getRGB and setRGB methods to access image data. This approach is slower than working directly on the BufferedImage's data buffers. However, using getRGB and setRGB, this class will work with all types of BufferedImage objects.

Note that while the abstract java.awt.Image class existed from the very beginning (version 1.0) of the Java runtime library, java.awt.image.BufferedImage has not been added until version 1.2.

Usage example

This code snippet demonstrates to how combine functionality from Java's runtime library with JIU by using this class. Requires Java 1.4 or higher. Obviously, BufferedRGB24Image objects can only be used with operations that work on classes implementing RGB24Image.
  import java.awt.image.BufferedImage;
  import java.io.File;
  import javax.imageio.ImageIO;
  import net.sourceforge.jiu.color.Invert;
  import net.sourceforge.jiu.data.PixelImage;
  import net.sourceforge.jiu.gui.awt.BufferedRGB24Image;
  ...
  BufferedImage bufferedImage = ImageIO.read(new File("image.jpg"));
  BufferedRGB24Image image = new BufferedRGB24Image(bufferedImage);
  Invert invert = new Invert();
  invert.setInputImage(image);
  invert.process();
  PixelImage outputImage = invert.getOutputImage();
 
If you can be sure that an image object can be input and output image at the same time (as is the case with some operations), you can even work with only one BufferedRGB24Image object. Invert is one of these operations, so the following would work:
  Invert invert = new Invert();
  invert.setInputImage(image);
  invert.setOutputImage(image);
  invert.process();
  // image now is inverted
 

Since:
0.10.0
Author:
Marco Schmidt

Field Summary
 
Fields inherited from interface net.sourceforge.jiu.data.RGBIndex
INDEX_BLUE, INDEX_GREEN, INDEX_RED
 
Constructor Summary
BufferedRGB24Image(BufferedImage bufferedImage)
          Creates a new BufferedRGB24Image object, storing the argument BufferedImage object internally.
 
Method Summary
 void clear(byte newValue)
          Sets all the RGB samples in this image to the argument, keeping the alpha value.
 void clear(int newValue)
          Sets all samples in the first channel to the argument value.
 void clear(int channelIndex, byte newValue)
          Sets all samples of one channel to a new value.
 void clear(int channelIndex, int newValue)
          Sets all samples of the channelIndex'th channel to newValue.
 PixelImage createCompatibleImage(int width, int height)
          Creates an instance of the same class as this one, with width and height given by the arguments.
 PixelImage createCopy()
          Creates an new image object that will be of the same type as this one, with the same image data, using entirely new resources.
 long getAllocatedMemory()
          Returns the number of bytes that were dynamically allocated for this image object.
 int getBitsPerPixel()
          Returns the number of bits per pixel of this image.
 byte getByteSample(int x, int y)
          Returns a single byte sample from the first channel and the specified position.
 byte getByteSample(int channelIndex, int x, int y)
          Returns a single byte sample from the image.
 void getByteSamples(int x, int y, int w, int h, byte[] dest, int destOffset)
           
 void getByteSamples(int channelIndex, int x, int y, int w, int h, byte[] dest, int destOffset)
          Copies samples from this image to a byte array.
 int getHeight()
          Returns the vertical resolution of the image in pixels.
 Class getImageType()
          If there is a single interface or class that describes the image data type of this class, the Class object associated with that interface (or class) is returned (or null otherwise).
 int getMaxSample(int channel)
          Returns the maximum value for one of the image's channels.
 int getNumChannels()
          Returns the number of channels in this image.
 int getSample(int x, int y)
          Returns one sample of the first channel (index 0).
 int getSample(int channelIndex, int x, int y)
          Returns one sample, specified by its channel index and location.
 void getSamples(int x, int y, int w, int h, int[] dest, int destOffs)
           
 void getSamples(int channelIndex, int x, int y, int w, int h, int[] dest, int destOffs)
          Copies a number of samples from this image to an int[] object.
 int getWidth()
          Returns the horizontal resolution of the image in pixels.
 void putByteSample(int x, int y, byte newValue)
          Sets one byte sample in the first channel (index 0) to a new value.
 void putByteSample(int channelIndex, int x, int y, byte newValue)
          Sets one byte sample in one channel to a new value.
 void putByteSamples(int x, int y, int w, int h, byte[] src, int srcOffset)
           
 void putByteSamples(int channelIndex, int x, int y, int w, int h, byte[] src, int srcOffset)
          Copies a number of samples from the argument array to this image.
 void putSample(int x, int y, int newValue)
          This method sets one sample of the first channel (index 0) to a new value.
 void putSample(int channelIndex, int x, int y, int newValue)
          This method sets one sample to a new value.
 void putSamples(int channelIndex, int x, int y, int w, int h, int[] src, int srcOffset)
          Copies a number of samples from an int[] array to this image.
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

BufferedRGB24Image

public BufferedRGB24Image(BufferedImage bufferedImage)
Creates a new BufferedRGB24Image object, storing the argument BufferedImage object internally. All image data access will be delegated to that BufferedImage object's methods.

Parameters:
bufferedImage - the underlying BufferedImage object for this BufferedRGB24Image object
Method Detail

clear

public void clear(byte newValue)
Sets all the RGB samples in this image to the argument, keeping the alpha value.

Specified by:
clear in interface ByteChannelImage
Parameters:
newValue - all samples in the image will be set to this value
See Also:
ByteChannelImage.clear(int, byte), IntegerImage.clear(int), IntegerImage.clear(int, int)

clear

public void clear(int newValue)
Description copied from interface: IntegerImage
Sets all samples in the first channel to the argument value. Equal to clear(0, newValue);:

Specified by:
clear in interface IntegerImage

clear

public void clear(int channelIndex,
                  byte newValue)
Description copied from interface: ByteChannelImage
Sets all samples of one channel to a new value.

Specified by:
clear in interface ByteChannelImage
Parameters:
channelIndex - zero-based index of the channel to be cleared (must be smaller than PixelImage.getNumChannels()
newValue - all samples in the channel will be set to this value

clear

public void clear(int channelIndex,
                  int newValue)
Description copied from interface: IntegerImage
Sets all samples of the channelIndex'th channel to newValue.

Specified by:
clear in interface IntegerImage

createCompatibleImage

public PixelImage createCompatibleImage(int width,
                                        int height)
Description copied from interface: PixelImage
Creates an instance of the same class as this one, with width and height given by the arguments.

Specified by:
createCompatibleImage in interface PixelImage
Parameters:
width - the horizontal resolution of the new image
height - the vertical resolution of the new image
Returns:
the new image

createCopy

public PixelImage createCopy()
Description copied from interface: PixelImage
Creates an new image object that will be of the same type as this one, with the same image data, using entirely new resources.

Specified by:
createCopy in interface PixelImage
Returns:
the new image object

getAllocatedMemory

public long getAllocatedMemory()
Description copied from interface: PixelImage
Returns the number of bytes that were dynamically allocated for this image object.

Specified by:
getAllocatedMemory in interface PixelImage
Returns:
allocated memory in bytes

getBitsPerPixel

public int getBitsPerPixel()
Description copied from interface: PixelImage
Returns the number of bits per pixel of this image. That is the number of bits per sample for all channels of this image. Does not include any transparency channels.

Specified by:
getBitsPerPixel in interface PixelImage

getByteSample

public byte getByteSample(int x,
                          int y)
Description copied from interface: ByteChannelImage
Returns a single byte sample from the first channel and the specified position. A call to this method is the same as getByteSample(0, x, y).

Specified by:
getByteSample in interface ByteChannelImage
Parameters:
x - horizontal position of the sample to be returned (must be between 0 and PixelImage.getWidth() - 1
y - vertical position of the sample to be returned (must be between 0 and PixelImage.getHeight() - 1
Returns:
the requested byte sample

getByteSample

public byte getByteSample(int channelIndex,
                          int x,
                          int y)
Description copied from interface: ByteChannelImage
Returns a single byte sample from the image. When possible, try copying several samples at a time for higher speed (ByteChannelImage.getByteSamples(int, int, int, int, int, byte[], int)).

Specified by:
getByteSample in interface ByteChannelImage
Parameters:
channelIndex - the number of the channel of the sample; must be from 0 to PixelImage.getNumChannels() - 1
x - the column of the sample to be returned; must be from 0 to PixelImage.getWidth() - 1
y - the row of the sample; must be from 0 to PixelImage.getHeight() - 1
Returns:
the sample, a single byte value
See Also:
ByteChannelImage.getByteSamples(int, int, int, int, int, byte[], int)

getByteSamples

public void getByteSamples(int channelIndex,
                           int x,
                           int y,
                           int w,
                           int h,
                           byte[] dest,
                           int destOffset)
Description copied from interface: ByteChannelImage
Copies samples from this image to a byte array. Copies num samples in row y of channel channel, starting at horizontal offset x. Data will be written to the dest array, starting at offset destOffset. Data will be copied from one row only, so a maximum of getWidth() samples can be copied with a call to this method.

Specified by:
getByteSamples in interface ByteChannelImage
Parameters:
channelIndex - the index of the channel to be copied from; must be from 0 to getNumChannels() - 1
x - the horizontal offset where copying will start; must be from 0 to getWidth() - 1
y - the row from which will be copied; must be from 0 to getHeight() - 1
w - the number of columns to be copied
h - the number of rows to be copied
dest - the array where the data will be copied to; must have a length of at least destOffset + num
destOffset - the offset into dest where this method will start copying data

getByteSamples

public void getByteSamples(int x,
                           int y,
                           int w,
                           int h,
                           byte[] dest,
                           int destOffset)

getHeight

public int getHeight()
Description copied from interface: PixelImage
Returns the vertical resolution of the image in pixels. Must be one or larger.

Specified by:
getHeight in interface PixelImage
Returns:
height in pixels

getImageType

public Class getImageType()
Description copied from interface: PixelImage
If there is a single interface or class that describes the image data type of this class, the Class object associated with that interface (or class) is returned (or null otherwise). This Class object, if available for two image objects, can be used to find out if they are compatible. Example: MemoryGray8Image returns net.sourceforge.jiu.data.Gray8Image.class.

Specified by:
getImageType in interface PixelImage

getMaxSample

public int getMaxSample(int channel)
Description copied from interface: IntegerImage
Returns the maximum value for one of the image's channels. The minimum value is always 0.

Specified by:
getMaxSample in interface IntegerImage
Parameters:
channel - zero-based index of the channel, from 0 to PixelImage.getNumChannels() - 1
Returns:
maximum allowed sample value

getNumChannels

public int getNumChannels()
Description copied from interface: PixelImage
Returns the number of channels in this image. Must be one or larger.

Specified by:
getNumChannels in interface PixelImage
Returns:
the number of channels

getSample

public int getSample(int x,
                     int y)
Description copied from interface: IntegerImage
Returns one sample of the first channel (index 0). A call to this method must have the same result as the call getSample(0, x, y);.

Specified by:
getSample in interface IntegerImage
Parameters:
x - the horizontal position of the sample, from 0 to PixelImage.getWidth() - 1
y - the vertical position of the sample, from 0 to PixelImage.getHeight() - 1
Returns:
the desired sample

getSample

public int getSample(int channelIndex,
                     int x,
                     int y)
Description copied from interface: IntegerImage
Returns one sample, specified by its channel index and location.

Specified by:
getSample in interface IntegerImage
Parameters:
channelIndex - the number of the channel, from 0 to PixelImage.getNumChannels() - 1
x - the horizontal position of the sample, from 0 to PixelImage.getWidth() - 1
y - the vertical position of the sample, from 0 to PixelImage.getHeight() - 1
Returns:
the desired sample

getSamples

public void getSamples(int x,
                       int y,
                       int w,
                       int h,
                       int[] dest,
                       int destOffs)

getSamples

public void getSamples(int channelIndex,
                       int x,
                       int y,
                       int w,
                       int h,
                       int[] dest,
                       int destOffs)
Description copied from interface: IntegerImage
Copies a number of samples from this image to an int[] object. A rectangular part of one channel is copied. The channel index is given by - the upper left corner of that rectangle is given by the point x / y. Width and height of that rectangle are given by w and h. Each sample will be stored as one int value dest, starting at index destOffs.

Specified by:
getSamples in interface IntegerImage
Parameters:
channelIndex - zero-based index of the channel from which data is to be copied (valid values: 0 to PixelImage.getNumChannels() - 1)
x - horizontal position of upper left corner of the rectangle to be copied
y - vertical position of upper left corner of the rectangle to be copied
w - width of rectangle to be copied
h - height of rectangle to be copied
dest - int array to which the samples will be copied
destOffs - int index into the dest array for the position to which the samples will be copied

getWidth

public int getWidth()
Description copied from interface: PixelImage
Returns the horizontal resolution of the image in pixels. Must be one or larger.

Specified by:
getWidth in interface PixelImage
Returns:
width in pixels

putByteSample

public void putByteSample(int channelIndex,
                          int x,
                          int y,
                          byte newValue)
Description copied from interface: ByteChannelImage
Sets one byte sample in one channel to a new value.

Specified by:
putByteSample in interface ByteChannelImage

putByteSample

public void putByteSample(int x,
                          int y,
                          byte newValue)
Description copied from interface: ByteChannelImage
Sets one byte sample in the first channel (index 0) to a new value. Result is equal to putByteSample(0, x, y, newValue);.

Specified by:
putByteSample in interface ByteChannelImage

putByteSamples

public void putByteSamples(int channelIndex,
                           int x,
                           int y,
                           int w,
                           int h,
                           byte[] src,
                           int srcOffset)
Description copied from interface: ByteChannelImage
Copies a number of samples from the argument array to this image.

Specified by:
putByteSamples in interface ByteChannelImage

putByteSamples

public void putByteSamples(int x,
                           int y,
                           int w,
                           int h,
                           byte[] src,
                           int srcOffset)

putSample

public void putSample(int x,
                      int y,
                      int newValue)
Description copied from interface: IntegerImage
This method sets one sample of the first channel (index 0) to a new value. This call must have the same result as the call putSample(0, x, y). The sample location is given by the spatial coordinates, x and y.

Specified by:
putSample in interface IntegerImage
Parameters:
x - the horizontal position of the sample, from 0 to PixelImage.getWidth() - 1
y - the vertical position of the sample, from 0 to PixelImage.getHeight() - 1
newValue - the new value of the sample

putSample

public void putSample(int channelIndex,
                      int x,
                      int y,
                      int newValue)
Description copied from interface: IntegerImage
This method sets one sample to a new value. The sample location is given by the channel index and the spatial coordinates, x and y.

Specified by:
putSample in interface IntegerImage
Parameters:
channelIndex - the number of the channel, from 0 to PixelImage.getNumChannels() - 1
x - the horizontal position of the sample, from 0 to PixelImage.getWidth() - 1
y - the vertical position of the sample, from 0 to PixelImage.getHeight() - 1
newValue - the new value of the sample

putSamples

public void putSamples(int channelIndex,
                       int x,
                       int y,
                       int w,
                       int h,
                       int[] src,
                       int srcOffset)
Description copied from interface: IntegerImage
Copies a number of samples from an int[] array to this image. A rectangular part of one channel is copied - the upper left corner of that rectangle is given by the point x / y. Width and height of that rectangle are given by w and h. Each sample will be stored as one int value src, starting at index srcOffset.

Specified by:
putSamples in interface IntegerImage
Parameters:
channelIndex - int (from 0 to getNumChannels() - 1) to indicate the channel to which data is copied
x - horizontal position of upper left corner of the rectangle to be copied
y - vertical position of upper left corner of the rectangle to be copied
w - width of rectangle to be copied
h - height of rectangle to be copied
src - int array from which the samples will be copied
srcOffset - int index into the src array for the position from which the samples will be copied

JIU 0.12.0 Homepage

Copyright © 2000, 2001, 2002, 2003, 2004 Marco Schmidt