advertisement
javaboutique
Search Tips
Articles  |   Tutorials  |   Reviews  |   Tools  |   by Category  |   by Date  |   by Name  |   Submit  |   Source  |   Forums  |  
javaboutique
Browse DevX


Partners & Affiliates











advertisement

Tutorials : Using Rasters for Image Processing, Part 2 :

Using Rasters for Image Processing, Part 2

by Anghel Leonard

In Part 1 of this series, you learned about the rasters concept as well as what raster components you need in order to use them in Java applications.

Part 2 will explain how to define a Raster/WritableRaster as a single object in a few different ways. First, you will learn how to create a raster from an array of pixels, from an Image, and from an BufferedImage object. You will also learn how to convert a raster to an Image/BufferedImage object and how to apply the Java2D filters to rasters. Complete applications for extracting rasters and for filter rasters with the ConvolveOp, AffineTransformOp and BandCombineOp classes are provided.

Creating a Raster Using the Raster and WritableRaster Classes

As you learned in Part 1, to create a raster, you need a DataBuffer object and a SampleModel object. Since you already know how to obtain these objects, it's time to learn how to use them.

To create a raster, you use two classes from the java.awt.image package: Raster and WritableRaster. Because the Raster class is abstract, its constructors are declared protected. This means you can't create instances of the raster class. So, to create Raster objects, you use a set of static methods from the Raster class. Each of these static methods returns a WritableRaster object—except the createRaster method, which returns a Raster object. The createRaster method looks like this:

public static Raster createRaster(SampleModel SM, DataBuffer DB, Point location):
This creates a Raster object using the specified SampleModel and DataBuffer objects. The location parameter represents the origins of the raster. If this parameter is null then the origins are (0,0).
Point P=new Point(0,0);      
Raster R=Raster.createRaster(SM,DB,P); 
// In this case, P can be replace with null 

After you've made a Raster object with the createRaster method, you can use it to gain access to the raster's pixels using the getPixel, getPixels, getSample, and getSamples methods:

  • getPixel: The following method returns an array of integers representing the samples of the specified pixel. The pixel coordinates are (x,y):
    public int[] getPixel(int x, int y, int[] intArray):
    Similar to the above method, these methods respectively return an array of float and an array of double:
    public float[] getPixel(int x,int y,float[] floatArray)
    public double[] getPixel(int x,int y,double[] doubleArray)
    
  • getPixels: The following method returns an array of integers representing the raster's samples. This method stores one sample per array element, so you must know the number of color bands in order to identify the samples of one pixel. The raster is delimitated by the x, y, w, and h parameters. The x and y parameters represent the origins of the raster, w is the width, and h is the height:
    public int[] getPixels(int x,int y,int w,int h,int[] intArray):
    Similar to the above method, these methods respectively return an array of float and an array of double:
    public float[] getPixels(int x,int y,int w,int h,loat[] floatArray)
    public double[] getPixels(int x,int y,int w,int h,double[] doubleArray)
    
  • getSample: The following method returns an int representing a sample of the pixel from the (x,y) coordinates. The sample belongs to the color band specified by the band parameter.
    public int getSample(int x,int y,int band):
    Similar to the above method, these methods return a float and a double, respectively:
    public float getSampleFloat(int x,int y,int band)
    public double getSampleDouble(int x,int y,int band)
    
  • getSamples: The following method returns an array of integers representing all samples from the specified raster and the specified band, one sample per array element. The raster is delimitated by the x,y,w,h parameters. The x,y prameters represents the origins of the raster, w is the width and h is the height of it.The band parameter represents the color band that contains all samples that will be extracted.
    public int[] getSamples(int x,int y,int w,int h,int band,int[] intArray)
    Similar to the above method, these methods returns a float and a double, respectively:
    public float[] getSamples(int x,int y,int w,int h,int band,float[] floatArray)
    public double[] getSamples(int x,int y,int w,int h,int band,double[] doubleArray)
    
As you can see, the Raster class doesn't contain methods for modifying its pixel's properties. To modify them, you must obtain an WritableRaster object. The WritableRaster class provides some setter methods that can be used to modify the pixels of a raster. This class also inherits from the Raster class the getter methods listed above. The WritableRaster object can be obtained using the following static methods from the Raster class:
  • public static WritableRaster createWritableRaster(SampleModel SM, DataBuffer DB, Point location): This method creates a WritableRaster object using the specified SampleModel and DataBuffer objects. The location parameter represents the origin coordinates of the raster. If this parameter is null, then the origin coordinates will be (0,0).
    Point P=new Point(0,0);      
    WritableRaster R=Raster.createWritableRaster(SM,DB,P); 
    // In this case, P can be replace with null 
    
  • public static WritableRaster createWritableRaster(SampleModel SM, Point location): This method creates an WritableRaster object using the specified SampleModel object. The location parameter represents the origin coordinates of the raster. If this parameter is null, then the origin coordinates will be (0,0).
The two above methods can be used for any SampleModel object.

How to Add Java Applets to Your Site

New on the Java Boutique:

New Review:

Time Management Made Easy with the Quartz Enterprise Job Scheduler
Why not just use the Java timer API? This open source scheduling API boasts simplicity, ease-of-integration, a well-rounded feature set, and it's free!

New Applet:

Reverse Complement
Reverse Complement is a simple applet that converts DNA or RNA sequences into three useful formats.

Elsewhere on internet.com:

WebDeveloper Java
Lots of Java information on webdeveloper.com

WDVL Java
Thorough Java resource at the Web Developer's Virtual Library.

ScriptSearch Java
Hundreds of free Java code files to download.

jGuru: Your View of the Java Universe
Customizable portal with online training, FAQs, regular news updates, and tutorials.

XML error: undefined entity at line 19
advertisement
Receive Articles via our XML/RSS feed
Receive Articles via our XML/RSS feed

JavaBytes
Internet Cyclone
This powerful, easy-to-use, internet optimizer is for Windows 95, 98, ME, NT, 2000 and XP. It's designed to automatically optimize your Windows settings, boosting your Internet connection up to 200%.

Linux Vendors Head to the Cloud in Search of Cash
iPhone 3GS: Overheating Fears, OS Update Nears
PostgreSQL 8.4 Revs Up Database Admin, Security
PHP 5.3 Accelerates PHP
Sun Releases NetBeans 6.7 IDE for Java, PHP
Why Firefox Doesn't Take Google Chrome Features
First Major PHP Update in Years Coming Soon
Red Hat CEO Calls on Oracle to Keep Java Open
Google Widens AdSense for iPhone, Android Apps
Eclipse Galileo Releases 33 Open Source Projects

A Taste of JavaFX for the Uninitiated
A Guide to Caching and Compression for High Performance Web Applications
How User-Centered Design Can Put User Stories in Proper Context
Explore C# 4's New Dynamic Types and Named/Optional Parameters
Enterprise Architecture: The Journey Begins Here, Part 2
Create a Syslog Sender/Receiver Using the MS Winsock Control
AMD CodeAnalyst Helps Developers Optimize and Tune Applications
Securing Microsoft's Cloud Infrastructure
Introducing the Azure Services Platform
An Introduction to Microsoft .NET Services for Developers

Advertising Info  |   Member Services  |   Contact Us  |   Help  |   Feedback  |   Site Map  |   Network Map  |   About

internet.commediabistro.comJusttechjobs.comGraphics.com

Search:

WebMediaBrands Corporate Info

Legal Notices, Licensing, Reprints, Permissions, Privacy Policy.
Advertise | Newsletters | Shopping | E-mail Offers | Freelance Jobs