Image Processing in Java Thesis
Image Processing in Java Thesis
I would like to thank my thesis supervisor, Dr. Vaughan Clarkson, for his thoughts and input in making this a successful project. With his input, this project has certainly resulted in a better product that is much more suitable to a professional involved in image processing. I would also like to thank the users of the newsgroup comp.lang.java.programmer for their input in solving some programming problems.
Page 1 of 88
ABSTRACT
Image processing tools are being rapidly developed for different operating system platforms. These tools are usually big in size, not completely portable across different platforms and lack an ability to be efficiently fielded on the Internet. The purpose of this project is to research current image processing tools and create a simple, easy and flexible image processing widget based on the Java Advanced Imaging (JAI) API. This widget will address the above-mentioned general problems associated with most image processing tools. Some popular image processing applications are discussed, including their strengths and weaknesses and their popularity. This is followed by a more detailed discussion on creating a java widget based on JAI. The features that make this widget easy to use to the average user, as well as any software developer wanting to expand it, are discussed. Further advantages and disadvantages of this widget are also discussed. This is followed by a specification for such a widget. This specification is developed into a design and finally implemented.
Page 2 of 88
Table of Contents
ACKNOWLEDGEMENTS ..........................................................................................1 ABSTRACT..................................................................................................................2 NOTES ..........................................................................................................................6 ABREVIATIONS .........................................................................................................6
INTRODUCTION.............................................................................................................7
IMAGE PROCESSING ....................................................................................................9 INTRODUCTION TO IMAGE PROCESSING...........................................................9 PENTIUM MMX ..........................................................................................................9 DESCRIPTION.........................................................................................................9 USABILITY............................................................................................................10 COMPATIBILITY..................................................................................................10 MICROSOFT DIRECTX............................................................................................10 DESCRIPTION.......................................................................................................10 USAGE AND USABILITY....................................................................................11 PORTABILITY ......................................................................................................11 IMAGE PROCESSING IN MATLAB .......................................................................12 DESCRIPTION.......................................................................................................12 USABILITY............................................................................................................12 USER LEVEL.........................................................................................................13 EXPANDABILITY ................................................................................................13 PORTABILITY ......................................................................................................13 INTERNET .............................................................................................................14 AUTOMATION......................................................................................................14 IMAGEMAGICK .......................................................................................................14 DESCRIPTION.......................................................................................................14 USABILITY............................................................................................................14 USER LEVEL.........................................................................................................15 EXPANDABILITY AND EXTENSIBILITY ........................................................15 PORTABILITY ......................................................................................................15
Page 3 of 88
INTERNET .............................................................................................................16 AUTOMATION......................................................................................................16 ADOBE PHOTOSHOP ..............................................................................................16 DESCRIPTION.......................................................................................................16 USABILITY............................................................................................................17 USER LEVEL.........................................................................................................17 EXPANDABILITY ................................................................................................18 Writing a plug-in .................................................................................................18 Using a plug-in ....................................................................................................18 EXTENSIBILITY ...................................................................................................19 PORTABILITY ......................................................................................................19 METHOD OF IMAGE PROCESSING ..................................................................19 AUTOMATION......................................................................................................20 PROJECT........................................................................................................................21 PROBLEM DESCRIPTION.......................................................................................21 IMPORTANCE OF THIS PROJECT.........................................................................21 RESEARCH AND ANALYSIS - USABILITY .........................................................22 STANDARD TOOLBAR .......................................................................................22 DESIGN AREA ......................................................................................................23 MODIFIER TOOLBAR .........................................................................................24 RESEARCH AND ANALYSIS - EXTENSIBILITY ................................................24 RESEARCH AND ANALYSIS - EXPANDABILITY..............................................29
COMPONENT SPECIFICATION .................................................................................33 OVERVIEW. ..............................................................................................................34 NOTES....................................................................................................................35 NOTATION. ...........................................................................................................35 DECLARATIONS. .....................................................................................................37 CONFIGURATION CONSTANTS AND VARIABLES. .....................................37 EXCEPTIONS. .......................................................................................................38 Exception Messages: ...........................................................................................38 Warning Messages: .............................................................................................38
Page 4 of 88
EVENTS. ................................................................................................................39 STATE MACHINE.....................................................................................................41 INPUTS:..................................................................................................................41 OUTPUTS:..............................................................................................................42 STATE VARIABLE[S]: .........................................................................................42 INITIAL STATE:....................................................................................................42 TRANSITIONS AND OUTPUTS:.........................................................................43 FUNCTIONS. .............................................................................................................50 TYPES.........................................................................................................................55 COMPONENT TYPES...........................................................................................55 GENERAL TYPES.................................................................................................61 EXPECTED CHANGES. ...........................................................................................62
COMPONENT DESIGN ................................................................................................63 DRAWING AREA OBJECTS....................................................................................63 DRAWING AREA......................................................................................................65 MODULE DESIGN ....................................................................................................67
Page 5 of 88
NOTES
The word extensibility is used to describe the addition extra features to the core component or application itself. This would be analogous to adding an undo feature to a component, that is, the component has been extended. This would require programming in the core component. The word expandability is used to describe the addition of toolsets, plug-ins and runtime libraries. This does not require any programming changes to the core component.
ABREVIATIONS
OS GUI JAI Operating System Graphical User Interface Java Advanced Imaging
Page 6 of 88
INTRODUCTION
Image processing is the ability to extract information from images. This is the shortest and simplest definition of image processing. To extract information of any kind from an image, the image has to be first transformed into a data set. Mathematical operations [1] can now be applied on to this data set. This thesis starts off with an introduction to image processing. This is followed by descriptions of current image processing applications and libraries. There are numerous programs that handle image processing. Matlab is one of the more popular programs. Image processing involves intensive mathematics and Matlab being a program designed for intensive mathematics is ideal for writing image-processing applications. Matlab allows a user to manipulate at the lowest level, that is, individual values in the data set. ImageMagick is another program that can do image processing. Unlike Matlab, ImageMagick has command line tools that can be used for image processing. Another program, Photoshop, is a cross between image processing and art. Photoshop was not designed for image processing functions per se, but rather, for creative and artistic needs. DirectX is a set of drivers from Microsoft that are optimised for 2D operations. To use DirectX, a user would have to write a program which calls the necessary routine from the corresponding DirectX file. DirectX was designed to give programmers a standard API (for Windows) for such operations as image processing. This information gives some necessary background information about todays image processing applications. Java Advanced Imaging (JAI) is the Java Application Programming Interface (API) for handling complex graphics. Unlike other graphics libraries, which are known to have portability problems, JAI does not have this problem as JAI has been almost completely1 written in Java and thus is as portable as Java itself. Consequently, this
The actual processing is delegated to native libraries that come with the JAI API, which are specific to
the Operating System platform. The user has no interaction with these libraries and only interacts with the JAI API.
Page 7 of 88
portability comes at a cost, namely the speed of processing. JAI is slower than other graphics libraries as it runs in conjunction with a Java Virtual Machine (JVM). Despite this, JAI is still popular and has other advantages. JAI is probably the most viable graphics library that can be deployed over the Internet. The power is already in the JVM in the clients browser. JAI inherits Java's highly modular programming structure allowing programmers to build highly modular programs. This project requires a graphical component that is based on JAI. A whole chapter is dedicated to discussing the project. This chapter starts with a formal problem description with possible enhancements that can be made. This is followed discussions on the areas that were researched for this project. Why these areas were deemed important, sample scenarios and some sample solutions are also discussed. This is followed by a formal specification for the component. The specification mainly defines the state machine for such a component. Component behaviour, event generation and response are also defined. In the next chapter, this specification is developed into a design in Universal Modelling Language (UML). This design shows how objects interact with other objects and the relationships as well. The final chapter is the conclusion. The degree of success achieved by this project is discussed here. Further improvements are suggested. This is followed by a partial code listing in the appendix. All the interfaces used in the implementation are given, but no source code is included. The primary goal of this project is to create a component that will allow fast and easy access to image processing tools, while being lightweight and portable across multiple operating system platforms.
Page 8 of 88
IMAGE PROCESSING
INTRODUCTION TO IMAGE PROCESSING
The brief definition of image processing is the ability to retrieve information from images. This is achieved by, first transforming the image into a data set. Mathematical operations can be done on this new format. Different kinds of information are retrieved by the different operations that are performed on the data set. It is important to note that the reverse, constructing an image from data, is also image processing. A simple example: how do we find out the differences between two images? We execute an Arithmetic Subtraction operation [2] on both images. As the name implies, subtraction leaves the difference, the resulting image would contain the differences between the two images. Image processing is used in many different fields. In medicine (the ultrasound machine, X-ray machine), astronomy (Hubbles telescope taking photographs in X-rays, Gamma rays, Infrared) and military (image maps used in ground hugging missiles), these are just a few of the fields in which image processing is widely used. Image processing is also used in every day items (digital cameras) to mission critical systems.
PENTIUM MMX
DESCRIPTION
Generally known as Multimedia Extension, MMX is a set of instructions that were added to the original Pentium microprocessor from Intel Corporation. MMX consists of 57 [13] new instructions.
Page 9 of 88
The purpose of the MMX instruction set extension was to provide a hardware performance boost for certain types of multimedia programming. Specifically, MMX instructions are designed to allow processing of large amounts of similar data at once, using a single (or with the minimum number of) instruction(s). This is known as a Single Instruction Multiple Data [4] or SIMD. Objects that benefit from this boost include, audio, video and graphics because they contain a large amount of similar data. Therefore, image processing using MMX can receive a tremendous boost in processing speed over non-MMX processing.
USABILITY
It is not possible for non-MMX applications to use the power of MMX. This means that applications have to be specifically written for MMX. On a higher level, this means that the source code will have to be recompiled with a compiler that can generate and optimise MMX instructions.
COMPATIBILITY
Most of the microprocessors that came out after the introduction of MMX, support the MMX instruction set. Currently, nearly all major computer microprocessor manufacturers, including Intel, AMD and Cyrix, support MMX. Therefore, programmers are almost guaranteed of MMX supported hardware (at least for the desktop computers).
MICROSOFT DIRECTX
DESCRIPTION
Microsoft describes [14] DirectX as an advanced suite of multimedia APIs built into the Windows Operating System. Introduced in 1995 and recognized as a standard on the
Page 10 of 88
Windows platform, DirectX provides a standard development platform (for Windowsbased PCs only) by enabling software developers to access specialized hardware features without having to write hardware-specific code. DirectX is used extensively in games programs as intense image processing is involved. A games programmer could design a game and implement the game using DirectX without getting concerned about what hardware would be available on end computer.
DirectX provides developers with a common set of instructions and components, across all Windows based platforms. At the same time, DirectX also takes advantage of high performance hardware such as dedicated 3D graphics cards. DirectX achieves this by providing a "hardware abstraction layer" (HAL), which uses software drivers to communicate between computer software and computer hardware. As a result, developers can use DirectX to write a single version of their product for the wide range of hardware devices and configurations that exist and at the same get high performance. DirectX provides another layer called the hardware emulation layer (HEL). This layer acts as software-based drivers for actual hardware when hardware is unavailable. For example, HEL could emulate 3D graphics when there is no 3D graphics available.
PORTABILITY
DirectX is only available for the Windows platform. Therefore, programmers wanting to port their programs to other Operating Systems, will have to re-write their program. However, DirectX applications are completely portable across all2 Windows platforms. This is because all Windows platforms use the same DirectX drivers.
Windows NT only supports DirectX 3.0a. It is expected that this will be fixed with the newer versions.
Page 11 of 88
Matlab is a program that specialises in numerical computation. Consequently, Matlab is often used by engineers [5] and students to solve problems involving complex arithmetic. Image processing in Matlab is essentially done by the Image Processing Toolbox. Basically, this is just a collection of image processing functions. These functions rely on the mathematical computational engine behind Matlab to do these functions. Many of these functions are in script format, specifically Matlab M files. Thus, a user wanting to view the code can easily view the source code, (possibly) make modifications and create new functions. Matlab is one of the most popular image processing applications available. Matlab allows manipulations at the lowest level, such as the modification of a single value in a data set. Many extended functions for image processing are available.
USABILITY
Image processing in Matlab is the same as using Matlab for any other problem. Matlab usage requires a user entering commands at the prompt to ask Matlab to do things. This is very similar to the command shell in Unix or Linux. The user can enter a single command to do something or write a script file (or even multiple files) to do a more complex task. In Matlab, this script file would be called an M file. Using these image-processing functions in Matlab requires a general understanding of Matlab itself. Further, to create any complex image manipulation, would require some knowledge of writing M files and thus the Matlab script language. The user should also have some knowledge in the mathematical workings involved in image processing to get the best result efficiently.
Page 12 of 88
There are books and tutorials (including one at the Matlab homepage) available to learn image processing in Matlab.
USER LEVEL
Image processing in Matlab requires a user who already understands how to use Matlab. The user must also know how to write scripts in Matlab to get the best result. Further, the commands used are short and technical requiring the user know what the commands do. Thus, image processing in Matlab is mostly aimed for professionals [18], as it requires a skilled user.
EXPANDABILITY
Most of the image-processing functions available in Matlab are scripts, which are (usually) available for viewing and modification. Even if it were not, Matlab still allows the user to use them in writing new functions. These new functions can then be used to do more image processing. This means that Matlab provides, almost unlimited expandability. Moreover, as the functions are just script files, functions are easily copied over to other machines decreasing wasted time and increasing efficiency.
PORTABILITY
Currently, Matlab is supported on a number of popular Operating Systems and a number of computer platforms (notable exception: Apple Macintosh). Matlab applications are fully portable over different platforms without any modifications. Matlab data files are automatically converted to compatible formats when moved to different platforms, relieving the user from doing any manual file format changes.
Page 13 of 88
INTERNET
Matlab has not been designed to be used over the Internet. Matlab requires a lot of processing and system resources and thus is unsuitable to be used over the Internet. Though it is conceivable that applications written in Matlab may be used over the Internet, it is unlikely as there are more suitable image-processing libraries for this specific purpose.
AUTOMATION
Matlab provides complete automation for all purposes. A user could write a script to perform a common image-processing sequence or even compile it as an application. The application can now be used by anyone to perform the image-processing sequence.
IMAGEMAGICK
DESCRIPTION
ImageMagick is a collection of tools that can be used to read, write and manipulate images. The latest version ImageMagick can manipulate over 68 [15] image formats including TIFF, JPEG, PNG, PDF and GIF. A lot of operations that can be performed on images are already available to the user.
USABILITY
Usage of ImageMagick is through the command prompt. The user types ImageMagick commands with the required options to manipulate images. ImageMagick can display any of the supported graphics formats but requires a suitable graphics server (the X server for Linux) be running at the time.
Page 14 of 88
Familiarity with scripting would enormously increase the efficiency of the user when using ImageMagick.
USER LEVEL
ImageMagick requires a knowledgeable user to make efficient use of it. Operations have to be typed at the command prompt, thus the user have to know what each command and its options do. To get the best result quickly, the user must also have mathematical knowledge of image processing operations. To make really good use of ImageMagick, the user should also know some command line scripting language of the Operating System the user is using. For example, batch programming in Windows and shell programming in Linux or Unix.
The source code for the whole ImageMagick application is available for free. This allows a user to change or modify the code, add new functions and recompile the code. Thus ImageMagick is extensible. However, usually, users would rather use a script to do a series of commands that are available from ImageMagick to get the desired result. This requires less time and is much more simple. Thus ImageMagick is also expandable.
PORTABILITY
ImageMagick was primarily designed for the Unix/Linux machines. But today, there are ports of ImageMagick available for other popular Operating Systems including Windows 95/98/2000, Macintosh and OS/2 [15].
Page 15 of 88
INTERNET
ImageMagick is well suited for web applications. It allows the dynamic creation of images and multiple APIs (C, C++, Java, Python and PERL) are available, any of which can be used be used to field a web application [15].
AUTOMATION
Massive automation can be achieved on platforms that allow good scripting. In this regard, Unix and Linux scripts can automatically and easily modify images as per the conditions set by the user. This is also one of the reasons for ImageMagicks suitability as a back end for a an image processing web application.
ADOBE PHOTOSHOP
DESCRIPTION
Photoshop is one of the most powerful and popular graphics applications in the (Windows) market today [6]. The current version (version 6) is the latest in this series of products and has built on the stability and performance of its predecessors. Photoshop can also be obtained in a suite of (Adobe Systems Incorporated) applications that allow a high degree of flexibility and collaboration within the applications contained in the suite. Photoshop is not a true image processing application. Photoshop has been primarily designed for creative arts or artists or for users aspiring to be a similar profession. Photoshop has been included in the study because it offers an enormous amount of image processing functions to assist the user in getting better artistic results.
Page 16 of 88
USABILITY
A Photoshop user would be faced with a GUI that is familiar to any Windows user. Photoshop contains similar menu systems (menus file, edit, ) and toolbars (standard toolbar tool buttons new, open, save, ) as any standard windows application. Thus in Photoshop, most users would not be spending additional time learning basic operations as they are identical to standard Windows applications. Graphic design in Photoshop is based on toolboxes and palettes. As is almost standard in all graphic design applications, Photoshop uses floating toolboxes and palettes. This means that a particular toolbox or palette can be dragged around to a position the user wants and will be visible at all times, that is, it will be on top of the application. This allows fast access to frequently used tools and customized familiarity; a different configuration could be easily changed into a particular configuration by just dragging and moving the toolboxes and palettes around. This also means that most users that have been using other image processing applications should find at least some familiarity when they switch over to Photoshop.
USER LEVEL
Photoshop is a high-level image processor. Users are not required to write any code to perform any image processing functions. This makes Photoshop ideal to the novice user. Users without a mathematical background and theories involved in image processing will also like what Photoshop has to offer. This is because Photoshop offers all image processing functions with a GUI front-end. A typical result of selecting an image processing function will give the user a dialog window (if it is not already open) with (possibly) all the options that that function offers. The user can change any values in these options until such time as the user is completely satisfied. Usually, the user would be able to preview the changes in real time from within the function itself. This improves the usability of the software.
Page 17 of 88
EXPANDABILITY
To expand Photoshop, that is, to add more image processing functionality, a user would have to install a plug-in. This would be additional software that can be run from within the Photoshop environment. With the enormous popularity of Photoshop, there are a number of plug-ins available both from the maker of Photoshop and third party vendors. These plug-ins are available as both commercial software which a user will have to buy and free software.
Writing a plug-in
Photoshop comes with its own collection of APIs for programmers wanting to write plug-ins. Plug-ins are thus written to conform to these APIs. This involves intimate knowledge of programming (usually C, C++ or other languages). Further, the programmer must be familiar with the image processing libraries and the functions it contains to effectively leverage the power behind the Photoshop image-processing engine. The programmer must also be familiar with at least some of the mathematics involved image processing. For example a convolution operation requires a matrix of input values. The mathematical knowledge would let the programmer know what these values are and how they could be effectively manipulated. Knowledge of the Photoshop image processing libraries would allow the programmer to program efficiently using the Photoshop image-processing engine. The programming knowledge would allow the programmer to link these aspects to create a new image processing function. In conclusion, writing plug-ins is not something that the average user or even an advanced user could achieve with ease. It is more suitable, to buy commercial plug-ins or contract another company to write a plug-in that is suited to the users needs.
Using a plug-in
A plug-in would install itself quite easily if it were correctly written. After installation, the plug-in tool appears and behaves just as a native tool would. A user familiar with Photoshop itself should not find a big difference between using native tools and the plug-in.
Page 18 of 88
EXTENSIBILITY
Photoshop is propriety software developed by Adobe Systems Incorporated. Adobe has not released the source code for Photoshop and as is the nature of propriety software, only the owner is allowed to change it. Therefore, a feature such as a particular print order that is not supported by Photoshop could not be added by a third person, user or programmer. Only Adobe can add such features.
PORTABILITY
Photoshop is available only for the Windows platform. This makes it virtually impossible for a user relying on another operating system to make an attempt at using Photoshop for image processing needs because it is unlikely that the user would dual boot or run another operating system on a virtual machine for the sole purpose of using Photoshop.
Photoshop uses two methods for image processing. A user could make changes directly to the image. Simple operations such as image transformations are usually done with direct image manipulation. The second method, which is much more powerful and flexible, is to use layers. A layer is simply a set of modifications that can be individually altered. An image seen through that layer would be modified as per the settings on that layer. To make additional changes, a user could modify, add or delete the layers properties or apply another layer on top. Layers are also used to achieve image animations.
Page 19 of 88
AUTOMATION
Photoshop has no methods to automate a sequence of image modifications. Some features such as the layers feature [16], reduce the work load to apply the same modifications on multiple images, but true automation is not available.
Page 20 of 88
PROJECT
PROBLEM DESCRIPTION
In brief, this project requires an image-processing component that is reusable, lightweight, easy to use and flexible. Specifically, this component will be based on the JAI API, which is the Java extension that provides complex image processing functions. Further, this component would be a graphical component and should provide a rapid application development environment (in image processing terms). A user should be able to draw up a sequence of changes by placing image processing tools and connecting them in the order that the user wants. Further areas of relevance include the ability to field this component or field an application containing this component on the Internet, both easily and efficiently. The ability to use this component just as any other Java component (buttons, labels and so on), gives a Java programmer quick access to this component without involving any undue hardship.
Page 21 of 88
real time image modification can be seen as the user keeps changing the available options. This component can also be fielded on the Internet in the form of a Java Applet. The advantage here is that much of the processing power already resides on the users computer (in the form of a JVM and JAI API) and this component would be acting as a front-end to this existing resource base. Where these resources are not available, they have to be downloaded only once and are available from the Internet for free. This component has also been designed with the future in mind. As the JAI API is upgraded, the newer tools can be added without modifying and recompiling this component. This component can also be extended easily to add newer features such as the undo function. This is done by providing a clear step-by-step instruction guide to the developer on achieving this.
STANDARD TOOLBAR
Most current graphical applications have common standard tools. The most basic of these would be the standard toolbar. Usually this toolbar is always visible and is located at the top of the window. This toolbar contains the most basic operations including file operations (new, open, save, print), clipboard operations (cut, copy, paste) and other commonly used tools such as undo and redo. Most of these operations would be included in our component and thus a standard toolbar was included at the top of the component. Operations that were included in this toolbar are file operations (new, open, save), clipboard operations (cut, copy, paste), a
Page 22 of 88
delete and execute button. The delete button would delete the selected item and the execute button would run the design created by the user. A message bar, used to display messages to the user, was also added to the standard toolbar.
DESIGN AREA
This would be the area in which the user would create an image processing design. This process would involve pasting image-processing tools and moving them around within this area. It would also require a connector object that will connect the tools on this area to form a logical sequence of modifications for the input image(s). Further, design environments (for designing anything) provide some common and basic features that help the user. These include a visual grid and the ability to automatically snap objects to particular grid locations. This forces the tools and objects on the design area to be aligned to the grid and evenly spaced. These features are visually appealing to the user. The design area had to be appealing and easy to use. A visual grid and the ability to automatically snap objects to the grid were added to the drawing area. Further, the requirement to be able to move all objects on this area required that a drag feature be built into this sub-component that would handle the moving of all objects within this design area. Other enhancements include: The easy differentiating of the selected object from the rest of the objects on this area. Changing the appearance of a correctly connected connector object from hanging connector objects, including arrow pointers into the direction of the connection. Messages to the status bar to inform the user of what has happened in response to a user event.
Page 23 of 88
MODIFIER TOOLBAR
This toolbar contains the tools specific to our component and image processing. Thus, there is nothing to compare this toolbar with. The following reasoning has been used to design this toolbar. Some tools, notably the ones that are not associated with JAI, would be used more frequently. These include, an input tool (used to select the image to process in the design), a connector tool (used to connect the tools on the design area), an output tool (to declare where the design ends) and a viewer tool (a help tool to display the image at that point in the design). These tools would be visible to the user at all times. The tools associated with JAI would be divided into logical categories. This would help in un-congesting this toolbar. The user would be able to select different JAI tools by selecting the corresponding category from a combobox. This would load the appropriate tools onto the toolbar. For example, the image processing operations Add, Subtract, Multiply and Divide would be in a category called Arithmetic as these are all arithmetic operations. Thus, this toolbar would contain the most frequently used tools followed by a combobox which would allow the user to select a category of JAI tools the user wants to use. The method of adding these tools to the design area would be to click the tool on the toolbar and then by clicking on the point in the design area where you want to add the tool. This would add the tool that was clicked on to the design area, at the point (the closest snap to point) the user clicked.
Page 24 of 88
undo function, there should be a clear and precise way of adding the necessary button(s) and corresponding code with a minimal amount work. This area is important because a need may arise in the future for a particular feature in the core component. The ability to quickly upgrade the component is an increase in productivity (or even revenue if releasing commercially). Extensibility involves adding code to the core component. For a person (programmer) not involved in building this component and not knowing what kind of data structures and relations are used, this might seem to be a difficult task. This problem is similar to a programmer writing a program to communicate or extend an existing program. Most of the current applications in the world come with their own APIs to alleviate this problem. The programmer would write the program conforming to this API and it is the API that communicates with the core component. Thus, it protects the programmer from having to know any internal, implementation specific details. This general method [8] can be applied to our component on a smaller scale. Whilst APIs are generally quite big, our component is quite small and this makes it even easier. However, there is one major difference. For our component, we would need to write the source code for the core component as well (as stated in the above API comparison). To achieve this, we would be using interfaces to communicate between the major subcomponents in our image-processing component. Lets look at the example raised previously, that is, the addition of an undo function and lets assume that this function is going to be added to the standard toolbar. We know that interfaces are used to communicate between the major sub-components. If we look at the interface used by the standard toolbar we would see all the methods used by the standard toolbar to communicate to the other sub-components. To this interface we add the method that will be used to handle the undo function. Further, well have to add some code to the standard toolbar sub-component, possibly to create a button conforming to the formatting used in the standard toolbar and calling the undo method in the interface in response to a user event (clicking on the button). This would be the part that is visible to the user (the button on the toolbar). Next, we take a look at the sub-component that implements the standard toolbar interface, that is, the subcomponent that actually contains the code for the methods in the standard toolbar
Page 25 of 88
interface. To this, we add the extra method we defined in the standard toolbar interface, and write the code that will implement the undo function. This is the standard procedure that will be used to extend our component. The general procedure used to extend our component is as follows: 1) Determine the function and its behaviour that is going to be added to our component. 2) Determine where on the component (the sub-component to which) you want to add it. For our component it will be either the standard toolbar or the modifier toolbar. 3) Determine the interface used by the sub-component. For our component it will be the interface used or by the the standard toolbar toolbar (called (called StandardToolbarInterface) ModifierToolbarInterface). 4) Add the appropriate method to this interface that will be used by the function that is going to be added. 5) Add the appropriate code to the sub-component that uses this interface so that a user would be able to generate that event. For our component, this event would be usually generated by a button. Most of the formatting will be automatically set on button creation. The programmer will have to connect the event generated when the user clicks on this button to the method from the interface. 6) Add the appropriate code to the sub-component that implements this interface. This would be where the code that executes the new function resides. For our component this would be the design area (called DrawingCanvas). By following this procedure, extra features can be added to the core component. This highly modular design also provides additional advantages such as programming in parallel by multiple programmers. In all, three files are modified. When a function to be added is finalised and added to the appropriate interface, other programmers can simultaneously write the code for the other two files. These programmers are able to modifier
Page 26 of 88
work independently of each other, as all they need is the interface. Furthermore, while there would be some final integration testing of the new component, much testing can be achieved individually (including compilation) while the other part is still being written. This saves time, reduces the requirement that all programmers be familiar with the component (familiarity with the sub-component is enough) and thus increases efficiency in fielding extensibility to our component.
Practical Example: adding an undo function. Note: the example shows where the code would go but not the complete code itself. File one:
public interface StandardToolbarInterface { // all the methods that are already contained // add the new method here public void undo(); }
Page 27 of 88
File two:
public class StandardToolbar extends JToolbar { StandardToolbarInterface sti; // class constructor public StandardToolbar(StandardToolbarInterface sti, ...) { this.sti = sti; // existing code // create toolbutton, similar to below sample code ToolButton tb = new ToolButton() { public void actionPerformed(...) { // on clicking the button undo method is // executed from the interface object sti.undo(); } }; // add this button to the toolbar } }
File three:
public class DrawingCanvas implements StandardToolbarInterface { // all the methods that are already contained public void undo() { // implement the undo function } }
Page 28 of 88
Page 29 of 88
The following method was designed for modularising the JAI tools of our component. JAI tools are divided into logical categories. For example, category Arithmetic would contain the arithmetic operations Add, Subtract, Multiply and Divide. Each such category would be packaged as a module of JAI tools. Each such module would contain a configuration file describing the JAI tools contained within the module so that it can be loaded into our component. Addition of JAI tools to an existing module is not expected (though possible), as modules can be made by third parties who may want to retain control over their modules and thus disallow any changes to their modules. The general procedure used to create a module of JAI tools is as follows: 1) 2) Determine the category and the tools that will be contained in the module. Extend the class provided by the core component to implement the JAI tools. As stated earlier, the tools on the design area have certain formatting and properties. Extending the class gives the new JAI tool the same formatting and properties. The JAI tool itself only have to implement a few methods. 3) Any access to resources if required, such as extra images, should be handled from within JAI tool itself. Again, the class supplied by the core component handles the setting of tool icons and other general settings. 4) Create the configuration file. This is a text file and should be named the same as the module name followed by a .config. The first line should contain the string that will become the category name. The following lines should contain the full path to the JAI tools contained within the module. The order of listing of the JAI tools would be the order of appearance of the tools on the toolbar. Following this procedure, makes it quick and easy to add more image processing tools. Much of the work required is already done for the programmer. The highly modular design results in the following advantages. The programmers are only allowed to create and modify the files within the modules they are creating, which allows them to add extras to the JAI tools that they are writing while at the same time not changing any of the existing tools or the core component. This maintains consistency among all the tools. Multiple programmers can work simultaneously on different modules or even the
Page 30 of 88
tools contained in the same module. Again, these programmers are able to work independently of each other, as all of them are following the specification required by the core component. Complete individual testing can be attained before packaging saving valuable production time. Compatibility is virtually guaranteed if the programmer followed the specification provided by the core component. The highly modular design also protects the programmer from having to know any of the internal workings of the core component. The specification provides the (minimal) methods that have to be implemented. The programmer has discretion to add more. This usage of modules has one other important advantage. Namely, modules can be traded commercially.
Page 31 of 88
Practical Example: adding an threshold function. Note: the example shows where the code would go but not the complete code itself. File one:
public class JAI_Threshold extends AbstractCanvasButton { // implement the required methods public void setProperties() { // implement code } public void updateImage() { // implement code } // re implement methods that stray from the default // implementation } public class HelperClass { // code }
Note: The JAI tool extends the class supplied by the core component. The programmer can have any number of helper classes. File two: The configuration file, category name and full path class name of all JAI tools contained in the module
Threshold JAI_Threshold
Page 32 of 88
COMPONENT SPECIFICATION
Image Processing Bean Version 1.0; Specification Version 1.0. [11] Author: Riyaz Mansoor
Thesis Project for Software Engineering. Department: Computer Science and Electrical Engineering. Faculty: Engineering. University of Queensland. October 2001.
Page 33 of 88
OVERVIEW.
Software specifications are nearly always very abstract. The specification does not talk about implementing data structures, even less, the implementing language. However, this specification requires a component, similar to a re-usable Unix widget, for the Java Advanced Imaging (JAI) Application Programming Interface (API). Thus, we already know what language this component would be implemented in and hence have a good idea of the final product. In Java, such components are implemented as a JavaBean (or bean for short). Hence, the title of this specification. Despite the fact that we already have prior knowledge of the final product, the specification is kept as abstract as possible. The Image Processing Bean (IPB) is a JavaBeans component, which brings together the many image processing features present in the JAI API. The IPB would have a fully featured Graphical User Interface (GUI). The IPB would not have any keyboard shortcuts. This is in part because the IPB is not a full application and due to the fact that a shortcut key in the IPB may conflict with another shortcut key in the host application. However, this issue is raised in the expected changes section. The aim of the IPB would be to shorten the time taken to modify an image (or streaming images) by providing the user with a friendly GUI based environment that allows the user to see what's being modified/created approximately on the fly. It is approximate because the user will have to design and run it to see the output. As all JavaBeans, the IPB would be fully compatible with all java graphical components. For example: the IPB could be added to Sun Microsystems' Forte software suite and be used as one would use a java button.
Page 34 of 88
NOTES.
The methodology used in referencing objects and their properties is based on the Object Oriented Development (OOD) concept. For example: ipb.pathfilename_GV.value refers to the value of the pathfilename_GV property of the ipb object. Some properties have been overloaded. For example: a string.value property would be the literal value of the string but clipboard.value property would be whatever is contained in the clipboard. In the latter case, value is used in the abstract and is to be used logically. The details of such properties or objects are left to the higher-level designer/implementer. Event names used are logical names and has been used to show that an event of that type has occurred. The higher-level designers/implementers are not explicitly tied to using these names in their schemas, as specific situations may not warrant such names. This specification talks drag and drop in abstract. The designer or the programmer may choose to implement it in a similar but not exact way. For example, clicking a button and clicking the canvas may create the desired tool at the clicked position, which gives the desired drag and drop effect.
NOTATION.
The following symbols have been used for: Symbol := == != Description denotes value assignment denotes equivalency of values denotes non equivalence of values
The following rules are used to name constants, variables and types.
Page 35 of 88
All global constants are in title case, postfixed with _GC. Example: GlobalConstant_GC All global variables are in title case, postfixed with _GV. Example: GlobalVariable_GV All types are in lower case, postfixed with _T. Example: type_T All warning messages are in title case, postfixed with _WM. Example: WarningMessage_WM All exception messages are in title case, postfixed with _EM. Example: ExceptionMessage_EM All component identifiers are prefixed with three logical identifying characters in lowercase and an underscore character. Example: mod_modifier for modifier type objects. Component Type panel_T grid_T modifier_T Sample pnl_Main grd_Grid mod_Morph Background grid on which to draw Image modifier Description
Quick reference table for formatting of text: Identifier Keyword Event Names Variables Formatting Bold only Bold and Italics only Bold and Underline only
Some pseudocode syntax rules: Keyword new is used to show the creation of a new object. Keyword this is used to reference the object on which the event occured.
Page 36 of 88
DECLARATIONS.
This section specifies the constants, warnings, exceptions and events that are going to be used in the IPB. Respective values and descriptions are given in the following subsections.
This section lists and describes the all the global constants and global variables used in the IPB. All global constants and global variables are in lowercase, post fixed with "_GC" for constants and post fixed with "_GV" for variables. Name projectdirty_GV modulesdirectory_GV projectdirty_GV gridsize_GC Type boolean_T string_T string_T integer_T 15 pixels Value
Page 37 of 88
EXCEPTIONS.
This section lists and describes all possible messages that a user may get during interaction with the IPB. All message identifiers are lowercase, post fixed with "_EM" for exception messages or "_WM" for warning messages.
Exception Messages:
Name MediaOut_EM
Message Text The canvas can contain only have one "media_out" object.
ViewerHandleIncoming_EM
The incoming handle of this viewer is already taken. Only one instance allowed.
ViewerHandleOutcoming_EM
The outgoing handle of this viewer is already taken. Only one instance allowed.
Warning Messages:
Name ProjectDirty_WM
Message Text Current project has been modified. Proceeding may erase changes.
Page 38 of 88
EVENTS.
This section lists and describes all possible events that may be triggered by a user during interaction with the IPB. Event Name click_new click_open click_save click_cut click_copy click_paste click_delete click_execute change_category Description clicking the new icon on the standard toolbar clicking the open icon on the standard toolbar clicking the save icon on the standard toolbar clicking the cut icon on the standard toolbar clicking the copy icon on the standard toolbar clicking the paste icon on the standard toolbar clicking the delete icon on the standard toolbar clicking the execute button on the standard toolbar selecting a different modifier category from the modifier toolbar drag_media_in dragging the media_in button on to canvas from the modifier toolbar drag_media_out dragging the media_out button on to the canvas from the modifier toolbar drag_viewer dragging the viewer button on to the canvas from the imaging toolbar drag_connector dragging the connector button on to the canvas from the imaging toolbar drag_modifier dragging a modifier on to the canvas from the imaging toolbar click_media_in click_media_out clicking the media_in object on the canvas clicking the media_out object on the canvas
Page 39 of 88
clicking a viewer object on the canvas clicking a connector connector object on the canvas clicking a modifier object on the canvas moving a placeholder object of a connector on the canvas by dragging
moving the media_in object on canvas by dragging moving the media_out object on canvas by dragging moving a viewer object on canvas by dragging moving a modifier object on canvas by dragging double clicking a modifier object on canvas
Page 40 of 88
STATE MACHINE.
INPUTS:
 Events generated by clicking the buttons: cmd_new cmd_cut cmd_delete cmd_open cmd_copy cmd_execute cmd_save cmd_paste
Events generated by dragging the following buttons on the canvas: cmd_input cmd_connector cmd_output cmd_viewer
Event generated by selecting a different category from the cmb_Category combo box. Event generated by single clicking any of the following types objects on the canvas: input_T connector_T output_T modifier_T viewer_T
Event generated by double clicking any of the following objects on the canvas: input_T modifier_T output_T viewer_T
Event generated by dragging and placing the placeholder of a connector object on any type of the following objects: input_T modifier_T output_T viewer_T
Page 41 of 88
OUTPUTS:
    Warning/Exception messages displayed via dialog boxes. Property change dialog boxes in response to double clicking modifier buttons on the canvas. Updates to the drawing area. Image modification as per user requirements when user wants the results.
STATE VARIABLE[S]:
Ipb
IPB_T
/* the following variables are used (as shorthand) throughout this specification */ stb := ipb.tbr_standard mtb := ipb.tbr_modifier cnv := ipb.pnl_canvas standardtoolbar_T modifiertoolbar_T canvas_T
INITIAL STATE:
ipb.projectdirty_GV.value := false /* IPB state */ ipb.modulesdirectory_GV.value := "modules/" ipb.pathfilenme_GV.value := null cnv.setInitState() /* canvas state */ /* modifier toolbar state */ for each mod in ipb.modulesdirectory_GV.value do if (mtb.isModuleValid(mod)) then mtb.tbr_modifiers.append(mtb.loadModifiers(mod)) mtb.cmb_category.append(mtb.getCategory(mod)) end if end for
Page 42 of 88
while (true) do select case user_generated_event case click_new if (not cnv.projectdirty_GV.value) or else
(cnv.dlgWarning(ProjectDirty_WM))) then string_T fn := openDialogBox() if (fn != null) then cnv.projectdirty_GV.value := false cnv := cnv.readFromDisk(fn) cnv.pathfilename_GV := fn end if end if
case click_save if (cnv.projectdirty_GV.value) then if (cnv.pathfilename_GV.value == null) then cnv.pathfilename_GV.value := saveDialogBox() if (cnv.pathfilename_GV.value != null) then cnv.writeToDisk(ipb.pathfilename_GV.value)
Page 43 of 88
case click_cut if (cnv.selected.value != null)) and then (cnv.selected.type == modifier_T) then modifier_T mt := cnv.selected.value removeHandles(mt) stb.clp_clipboard.value := mt cnv.selected.value := null cnv.mod_modifiers.remove(mt) end if
case click_copy if (cnv.selected.value != null)) and then (cnv.selected.type == modifier_T) then modifier_T mt := new modifier(ipb.selected.value) removeHandles(mt) stb.clp_clipboard.value := mt end if
case click_paste if (stb.clp_clipboard.value != null) and then (stb.clp_clipboard.value.type == modifier_T) then modifier_T mt := stb.clp_clipboard.value cnv.mod_modifiers.add(mt) end if
Image Processing in Java  Riyaz Mansoor Page 44 of 88
case click_delete if (cnv.selected.value != null)) then removeHandles(cnv.selected.value) select case cnv.selected.type case input_T cnv.med_incomings.remove(cnv.selected.value) case output_T cnv.med_media_out.value := null case viewer_T cnv.vwr_viewers.remove(cnv.selected.value) case connector_T connector_T ct := ipb.selected.value handle_T ht1 := ct.hdl_handle1.value handle_T ht2 := ct.hdl_handle2.value for each hdl in { ht1, ht2 } do Object_T ob := hdl.attached_to.value /* connectors are bi-directional */ Ob.hdl_outgoings.remove(ht1) Ob.hdl_incomings.remove(ht1) Ob.hdl_outgoings.remove(ht2) Ob.hdl_incomings.remove(ht2) end for case modifier_T cnv.mod_modifiers.remove(cnv.selected.value) end select cnv.selected.value := null end if
Page 45 of 88
end if
case drag_media_out if (cnv.media_out.value != null) then cnv.dlgException(MediaOut_EM) exit procedure end if media_T mt := new media_out() cnv.media_out.value := mt
Page 46 of 88
case click_connector if (cnv.selected.value != null) then if (cnv.selected.type == connector_T) then connector_T ct := cnv.selected.value ct.hdl_handle1.bdr_border.setVisible(false) ct.hdl_handle2.bdr_border.setVisible(false) else cnv.selected.bdr_border.setVisible(false) end if end if cnv.selected.value := this this.hdl_handle1.bdr_border.setVisible(true) this.hdl_handle2.bdr_border.setVisible(true)
case click_media_in | click_media_out | click_viewer | click_modifer if (cnv.selected.value != null) then if (cnv.selected.type == connector_T) then connector_T ct := cnv.selected.value ct.hdl_handle1.bdr_border.setVisible(false) ct.hdl_handle2.bdr_border.setVisible(false) else cnv.selected.bdr_border.setVisible(false) end if end if cnv.selected.value := this this.bdr_border.setVisible(true)
Page 47 of 88
case move_placeholder position_T pt := new position() this.pos_position := pt select case cnv.objectAt(pt).type case input_T cnv.hdl_outgoings.add(this) case output_T cnv.hdl_incomings.add(this) case viewer_T viewer_T vt := cnv.objectAt(pt).value if (cnv.isCloserToLeftOf(vt, pt)) then if (vt.hdl_incoming.value != null) then ipb.dlgException(ViewerHandleIncoming_EM) exit procedure else vt.hdl_incoming.value := this end if end if if (vt.hdl_outgoing.value != null) then cnv.dlgException(ViewerHandleOutgoing_EM) exit procedure else vt.hdl_outgoinging.value := this end if case modifier_T modifier_T mt := cnv.objectAt(pt).value if (cnv.isCloserToLeftOf(mt.pos_position, pt)) then mt.hdl_incomings.add(this) else mt.hdl_outgoing.add(this) end if end select
Page 48 of 88
case
dbclick_modifier dbclick_viewer
dbclick_media_in
dbclick_media_out
this.openProperties()
Page 49 of 88
FUNCTIONS.
The methods add() and remove() are general methods whose functions are to add and remove the supplied object from the object on which this method is called on.
mtb.isModuleValid(module_T) : boolean_T A module represents a logical group of modifiers. This method checks that the supplied module_T object is a valid module and returns true if it is valid, or false if it is not.
mtb.tbr_modifiers.add(COLLECTION OF modifier_T) Adds the supplied collection of modifier_T objects to this collection. Each such supplied collection is assumed to correspond to one category only and the category name is used to retrieve its corresponding collection of modifier tools.
Page 50 of 88
mtb.loadModifiers(module_T) : COLLECTION OF modifier_T This method reads the supplied module object and returns the collection of modifier_T objects contained in them. The supplied module object is assumed to be valid.
mtb.getCategory(file_T) : string_T Returns the name of the category that this module file_T object represents. The supplied module file_T object is assumed to be a valid.
mtb.cmb_category.append(string_T) Adds the category name represented by the supplied string_T object to the cmb_category combobox.
cnv.dlgWarning(string_T) : boolean_T Displays a warning message, in the form of a dialog box with options to press Yes or No. The former would indicate a willingness to proceed without regard to consequences and returns true to the caller while the latter would indicate a willingness to immediately abort the action and returns false to the caller. The message displayed depends on the supplied value.
openDialogBox() : string_T Opens a standard "open dialog box" to select a file to open. Returns a string_T object representing the file selected or null if nothing was selected by the user.
Page 51 of 88
cnv.readFromDisk(string_T) : canvas_T Reads from disk the file represented by the supplied value. If the file is a valid canvas_T file, create the canvas_T object and return it. If the file selected is invalid, give an appropriate exception message and return null.
saveDialogBox() : string_T Opens a standard "save dialog box" to create/select a file to save. Returns a string_T object representing the file to be created or selected or null if nothing was selected by the user.
cnv.writeToDisk(string_T) Writes to the file represented by the supplied string_T object, the current canvas object.
removeHandles(Object_T ob) for each hdl in ob.hdl_incomings do hdl.attached_to.value := null end for for each hdl in ob.hdl_outgoings do hdl.attached_to.value := null end for ob.hdl_incomings := null ob.hdl_outgoings := null
cnv.dlgException(string_T)
Page 52 of 88
Displays an exception message, in the form of a dialog box with one option to press OK. The message displayed depends on the supplied value.
cnv.checkProjectValidity() : boolean_T Checks the canvas for any hanging objects and that all connectors are connected. Give an appropriate exception message to all cases that violate these rules. If there are no violations return a true, otherwise a false.
cnv.showResult() : window_T Returns a new window_T object containing all attached viewers and the output. Note: some of the methods and functions that are needed to do this have been hidden. It is expected that this would be handled in a later stage. An example of such a method would be the method that returns the modified image, which would be contained in all modifier_T objects.
updatePosition() Updates the position of the object on which this method was called. This is in response to user moving objects around on the canvas.
cnv.objectAt(position_T) : object_T Returns the object that is present at the supplied position on the canvas. Returns null if no object is present.
Page 53 of 88
Uses the gridsize_GC and the supplied object_T object size and the supplied position_T position to check if supplied position fell to the left or right of the supplied object_T object. Returns true if the second position is closer to the left side of the object or false if not.
openProperties() Opens a dialog box which will allow the user to manipulate the properties of the object this method was called on.
mtb.tbr_modifiers.getModifiers(string_T) : COLLECTION OF modifier_T Returns the collection of modifier_T objects that correspond to the category represented by the supplied string_T object.
Page 54 of 88
TYPES.
COMPONENT TYPES.
handle_T : tuple of { phd_placeholder hdl_other pos_position attached_to placeholder_T handle_T position_T { input_T | output_T | viewer_T | modifier_T }
} These are the entities that link objects on the canvas to each other. A handle contains a link to another handle attached to another object, there by creating a link between these two objects.
Page 55 of 88
A connector shows the physical link between handles on the canvas as a line. Connectors can be deleted where as handles cannot be individually deleted.
input_T : tuple of { CONST icon med_incoming bdr_border pos_position con_outgoings icon_T media_T border_T position_T COLLECTION OF handle_T
} This is a special class that handles the graphic/media to be modified. It is the bridge between the external input and the IPB. The border is shown if it is clicked (to show that it has been selected) and then can be deleted.
Page 56 of 88
This is a special class that handles the output from the IPB to an acceptable media format to the user. Alternatively, the user could just view it on the screen. The border is shown if it is clicked (to show that it has been selected) and then can be deleted.
viewer_T : tuple of { CONST icon bdr_border pos_position hdl_incoming hdl_outgoing icon_T border_T position_T handle_T handle_T
} This is a user help tool. The viewer does not modify the image in anyway. The border is shown if it is clicked (to show that it has been selected) and then can be deleted.
modifier_T : tuple of { CONST icon bdr_border pos_position con_incomings con_outgoings icon_T border_T position_T COLLECTION OF handle_T COLLECTION OF handle_T
Page 57 of 88
} All image modifiers (eg: lenses, distortions, ...) are of this type. The border is shown if it is clicked (to show that it has been selected) and then can be deleted. For modifiers only, when selected, it can be "cut" or "copied" to the clipboard. It is expected that the above properties would be implemented in a separate "modifier API" and this API would be used to implement the actual modifiers which would be packaged as modules logically grouped together into categories.
canvas_T : tuple of { CONST grd_grid CONST gridsize_GC projectdirty_GV grid_T integer_T boolean_T
modulesdirectory_GV string_T pathfilename_GV med_incomings med_media_out vwr_viewers mod_modifiers con_connectors selected string_T COLLECTION OF input_T output_T COLLECTION OF viewer_T COLLECTION OF modifier_T COLLECTION OF connector_T { input_T | output_T | viewer_T | connector_T | modifier_T }
Page 58 of 88
This is the drawing area where the user would "draw" up the changes to be made to an input media. The member "selected" is used in the "cut", "copy" and "paste" operations. Only modifier_T objects is allowed the before mentioned operations as a modifier may have numerous custom properties and setting them all again every time for trivial differences is too inefficient.
standardtoolbar_T : tuple of { cmd_new cmd_open cmd_save cmd_cut cmd_copy cmd_paste cmd_delete cmd_execute lbl_status button_T button_T button_T button_T button_T button_T button_T button_T label_T
} This is the standard toolbar which lies at the top of the IPB and contains the standard tool options similar to any other GUI. A label masquerades as a status bar filling the rest of the space on this toolbar.
Page 59 of 88
} This is the modifier toolbar that lies at the bottom of the IPB and contains the tools used to modify and manipulate images. This toolbar also contains media in/out buttons, viewers and connectors, and a combobox which lists the logical categories into which the modifier tools are divided. The modifier tools that are currently available are contained in mod_modifiers. tbr_modifiers is a collection of toolbars, each toolbar containing a logical category of modifier tools. A toolbar in tbr_modifiers is retrieved when the corresponding category is selected from the cmb_categories combobox.
} This is the IPB. The IPB consists of a standard toolbar on top, an image modifying toolbar at the bottom and a drawing canvas between them and environment variables.
Page 60 of 88
GENERAL TYPES
This section specifies the general types used in the IPB. The details of these types is left for the higher level designer or programmer.
Type
Description
icon_T grid_T media_T border_T placeholder_T position_T button_T label_T combobox_T string_T integer_T boolean_T
16x16 pixel gif picture background grid on drawig area generic type that handles graphics this is a unique setting which shows that the object has been selected a draggable "box" to be used to connect objects to connectors the position with respect to object on which it is standard GUI button standard GUI label standard GUI combo box a string an integer a Boolean
Page 61 of 88
EXPECTED CHANGES.
    Undo/Redo facility. Keyboard shortcuts for commands. A check to disallow a connector be connected to both ends of the same object A checking algorithm that checks that images have not been connected in a cyclic fashion.
Page 62 of 88
COMPONENT DESIGN
The following design illustrations have been done in Universal Modelling Language (UML). To understand these illustrations, a working knowledge of UML and Object Oriented Programming is required.
Page 63 of 88
Page 64 of 88
DRAWING AREA
The below UML diagram shows how the drawing area is designed [12]. The drawing area implements four interfaces, which are used to interact with their corresponding calling objects. The GridOperations interface controls how the drawing area is seen to the user. The grid width, style and colours are set using this interface. The grid also drawing by this interface. The DrawingCanvasMouseOperations interface controls all mouse actions that occur on the drawing area regardless of whether they occurred on an object on the drawing area or not. These include mouse clicks (used to select any object on the drawing area), mouse drag (used to move all tools (buttons) on the drawing area). The mouse action to drag/move modifier tools from the toolbar to the drawing area is also controlled by this interface. The CanvasButtonInterface interface is used by all canvas buttons, namely to validate and update itself by asking the drawing area to verify that the design is correct and proceed to update. The StandardToolbarInterface interface is used by the standard toolbar to interact with the drawing area. A single method is defined for each button that appears on the standard toolbar. The ModifierToolbarInterface interface is used by the modifier toolbar to interact with the drawing area. Controls what tools are to be readied to be added to the drawing area.
Page 65 of 88
Page 66 of 88
MODULE DESIGN
The above UML diagram shows how a module is designed. A module consists of multiple tools. Each tool must implement the ModifierInterface which used by clipboard operations such as cut and copy. All modifier tools are extensions of the AbstractCanvasButton class and only implements the methods that need to be updated (different) from the parent class.
Page 67 of 88
CONCLUSION
PRODUCT EVALUATION
A final product was created to the specification and design given above in this document. The product met all requirements given in the above specification. However, only a few (six) JAI operations were implemented for the final testing of the product. These six operations were divided into two categories and thus were in two different modules. The component was tested with no modules, with one module and two modules. Each time, the component loaded correctly with the available tools (if available). Each tool button on each toolbar was tested individually. The drawing area was tested with a variable number of tools and connectors on them, and checked if mouse operations (drag, move and click) worked correctly for all objects on the drawing area. Clipboard functions were tested for modifier tools on the drawing area. Property setting functions for modifier tools (all six) were checked. All of these tests passed. The component was also tested with invalid modules. The component executed correctly by dumping the module when an error state was reached. Finally a simple design was created on the drawing area. The design executed correctly giving the expected output. More complex designs were created and they also gave the correct output. It should be noted that the save and open function were not completed for this component. The completed part for both of these functions worked correctly. One very important feature that was not in the specification was implemented. This was an on the fly check of the modified image. This involved double clicking any tool on the drawing area, which, if connected correctly, opened up the properties window with the modified image up to that point. Further, modifier tools with custom properties were made to show real-time image modification in response to changes the user makes to its settings. Thus, less time was wasted in running the whole design.
Page 68 of 88
Other features that were implemented but was not in the specification were arrows on connectors showing the direction of the connection, special highlighting of connectors that were connected correctly and tool tips for all tools in the component. All these features worked correctly.
FUTURE DEVELOPMENT
The above mentioned on the fly check could be extended to show changes to images that lie higher up on the hierarchy, such as the final output. Thus, a user would be able to see real-time changes, say, of the final output by changing settings on other tools. This would further boost productivity. Scripting ability could also be added to the component. This would be the major change, if I were to do a future version of this product. The specification and the resulting design had no requirement for scripting capability to be built into the component. Therefore, it is expected that this change may result in significantly more work than a simple extension or an addition of a feature. This would also allow the component to be used in a non-graphical sense, to create a design from within the script, and get the final output. The parts that were not finished, saving a design and opening a design, is expected to be implemented in the next upgrade of the product or in a new release. Other standard features can be added to this component. These include undo and redo functions and the ability to handle multiple designs.
Page 69 of 88
APPENDIX
The interfaces used in this component.
/** * @file * @created * @modified */ HandleObject.java August September 2001 2001
package rmanchu.thesis.ipb;
import java.awt.Point;
/** * This interface represents the API used to manipulate handles. * * @author rmanchu
/** * Type "Incoming" handle. Attached to the input side of a * <code>CanvasButtonInterface</code> object. */ public final static int INCOMING = 0;
/** * Type "Outgoing" handle. Attached to the output side of a * <code>CanvasButtonInterface</code> object. */ public final static int OUTGOING = 1;
/** * Type "Hanging" handle. Not Attached to a * <code>CanvasButtonInterface</code> object. */ public final static int HANGING = 2;
Page 70 of 88
/** * Sets the handle to which this object is linked to. This method is * used to create the "tree" which is the design the user has * drawn up on the drawing canvas. * * @param hi The handle to which this object will be linked to. * @see #getNext */ public void setNext(HandleObject hi);
/** * Returns the handle to which this object is linked to. This method is * used to go through the "tree" which is the design the user has * drawn up on the drawing canvas. * * @return The handle to which this object is linked to. * @see #setNext */ public HandleObject getNext();
/** * Same method as found in <code>Componenet</code>. Put here to get access * to this method. * * @param p The point to set the location of this handle object on. * @see java.awt.Component#setLocation */ public void setLocation(Point p);
/** * Same method as found in <code>Componenet</code>. Put here to get access * to this method. * * @return The point representing location of this handle object. * @see java.awt.Component#getLocation */ public Point getLocation();
/** * Centers this handle to the supplied location. Gives a more * "attached" feel when seen on the drawing canvas. * * @param p The point to center this handle on. * @see #getCenteredLocation */ public void setCenteredLocation(Point p);
Page 71 of 88
/** * Returns the centered location of this handle. * * @return The centered location of this handle. * @see #getCenteredLocation */ public Point getCenteredLocation();
/** * Sets the <code>CanvasButton</code> object that this handle * is attached to. * * @param cb The <code>CanvasButton</code> object that this handle * will be attached to.
/** * Returns the <code>CanvasButton</code> object that this handle * is attached to. * * @param The <code>CanvasButton</code> object that this handle * is attached to.
/** * Sets the type of this handle object. The types could be <P> * <UL> * * * <LI>HandleObject.INCOMING</LI> <LI>HandleObject.OUTGOING</LI> <LI>HandleObject.HANGING</LI>
* </UL> * <P> * * @param type The type of this handle object. * @throws IllegalArgumentException if "type" does not corresspond to the * above values.
Page 72 of 88
/** * Returns the type of this handle object. The types could be <P> * <UL> * * * <LI>HandleObject.INCOMING</LI> <LI>HandleObject.OUTGOING</LI> <LI>HandleObject.HANGING</LI>
* </UL> * <P> * * @return The type of this handle object. * @see setType */ public int getType();
package rmanchu.thesis.ipb;
/** * The API used to manipulate the grid properties on the drawing canvas. * * @author rmanchu
/** * Sets the stroke to be used when painting the grid. * * @param stk The stroke to be used when painting the grid. */ public void setGridStroke(Stroke stk);
Page 73 of 88
/** * Sets the foreground and background colors of this grid. * * @param fgColor The new foreground color. * @param bgColor The new background color. */ public void setGridColors(Color fgColor, Color bgColor);
/** * Sets the grid spacing to the supplied value. * * @param gs The new grid spacing length. */ public void setGridSpacing(int gs);
/** * Returns the spacing length used for this grid. * * @return The grid spacing length. */ public int getGridSpacing();
/** * Draws the grid using the grid properties * * @param g2 The graphics object used to draw the grid. */ public void paintGrid(Graphics2D g2);
Page 74 of 88
package rmanchu.thesis.ipb;
import java.awt.Point;
/** * The API used by the standard toolbar to interface with the drawing canvas. * * @author rmanchu
/** * Sets the supplied canvas object as the object that's selected on the * drawing canvas. * * @param obj The object to be be set as selected. */ public void setSelected(CanvasObject co);
/** * Returns the selected canvas object on the drawing canvas. * * @return The canvas object that's selected. */ public CanvasObject getSelected();
/** * Sets the supplied <code>state</code> as the modified state of the project. * If a <code>true</code> is supplied it means the project has been * modified and is in need of saving and vice versa. * * @param state The new state of the project. A <code>true</code> if * the project has been modified and is in need of saving.
Page 75 of 88
/** * Returns the modified state of the project. If a <code>true</code> is * returned, the project is in need of being saved and vice versa. * * @return The current modified state of the project. * @see setProjectModified */ public boolean getProjectModified();
/** * Adds the ready object to the drawing canvas. If there is no ready * object nothing is added. * * @param xPos Position on x-axis to add the object. * @param yPos Position on y-zxix to add the object. */ public boolean addObjectToAdd(double xPos, double yPos);
/** * Returns the closest point in the grid corresponding to the supplied point. * * @param xPos The x-axis position. * @param yPos The y-axis position. * @return The point that corresponds closest to the supplied position valus. */ public Point snapToGrid(double xPos, double yPos);
/** * Instructs to redraw the whole drawing canvas. */ public void reDraw();
/** * Returns true if a connector was clicked after setting the connector as * the selected object. * * @param xPos The x-axis position of click. * @param yPos The y-axis position of click. */ public boolean clickedConnector(double xPos, double yPos);
/** * Unselects any selected object on the drawing canvas. */ public void clearSelected();
Page 76 of 88
package rmanchu.thesis.ipb;
import java.awt.Point;
import java.util.Vector;
import javax.swing.JComponent;
/** * This interface represents the API used by all objects on the drawing * canvas. * * @author rmanchu
/** * Sets the selected state of this object. A selected is seen different * from an unselected object. * * @param state The new selected state of this object. */ public void setSelected(boolean state);
/** * Returns the selected state of this object. If a <code>true</code> * is returned, this object is selected. * * @return The selected state of this object. */ public boolean getSelected();
/** * Returns <code>true</code> if object statisfies all references. Every * object has a minimum set of links to other objects on the drawing * canvas and meeting this requirment returns a <code>true</code>. * * @return Returns true if object satisfies all references. */ public boolean isReferencesValid();
Page 77 of 88
/** * Adds this object to the supplied <code>JComponent</code> at the * supplied point and to the supplied <code>container</code> list. This * list may be <code>null</code> if not required * * @param jc The parent component onto which this object will be placed. * @param p The point at which this object will be placed. * @param container The list of similar objects into which this object * * @see remove */ public void add(JComponent jc, Point p, Vector container); will be added as well, if not null.
/** * Removes this object from its parent component and from the list of * such components. * * @see add */ public void remove();
/** * Clears all references from this object and to this object. This * essentially makes this object ready for garbage collection. */ public void clearAllReferences();
Page 78 of 88
package rmanchu.thesis.ipb;
import java.awt.Rectangle;
import java.util.Enumeration;
import javax.swing.Icon;
import javax.media.jai.PlanarImage;
/** * This interface extends the <code>CanvasObjectInterface</code> for * the button tools that are added to the drawing canvas and adds * more methods to handle them. * * @author rmanchu
* @version 1.0 * @see CanvasObjectInterface * @see CanvasButton */ public interface CanvasButton extends CanvasObject {
/** * Attaches the supplied handle to this object using the <code>xPos</code> * value to determine whether its an incoming handle or an outgoing handle. * If <code>xPos</code> is less than half the width of this object then * the supplied handle is made an incoming handle and attached or * vice versa. * * @param hi The handle to add to this canvas button. * @param xPos The x-axis position. * @see HandleObject */ public void addHandle(HandleObject hi, int xPos);
Page 79 of 88
/** * Removes the supplied handle from this object. The handle is checked * to determine whether it is incoming or outgoing and is removed * accordingly. * * @param hi The handle to add to this canvas button. * @see HandleObject * @see #removeHandle */ public void removeHandle(HandleObject ho);
/** * Sets the modified graphic at this object according to the users design * on the drawing canvas. This <code>image</code> is constructed from * the preceeding <code>CanvasButtonInterface</code> objects and with * any custom properties of this object. * * @param image The new internal graphic image for this object. * @see #getImage */ public void setImage(PlanarImage image);
/** * Returns the modified graphic at this object according to the users design * on the drawing canvas. * * @return The Icon representing the internal graphic for the project. * @see #setImage */ public PlanarImage getImage();
/** * Sets the updated state of the internal graphic. If a <code>true</code> * is supplied image does not need updation and thus no preceeding * <code>CanvasButtonInterface</code> objects needs updation as well. If a * <code>false</code is supplied, all preceeding * <code>CanvasButtonInterface</code> objects are checked and updated * if necessary. * * @param state The new internal graphic updated state. * @see #getImageUpdateState */ public void setImageUpdateState(boolean state);
/** * Returns the updated state of the internal graphic. * * @return <code>true</code> if internal graphics needs no updating. * @see #setImageUpdateState */
Page 80 of 88
/** * Same method as found in <code>Componenet</code>. Put here to get access * to this method. * * @param r The rectangle representing the new bounds for this object. * @see java.awt.Component#setBounds */ public void setBounds(Rectangle r);
/** * Same method as found in <code>Componenet</code>. Put here to get access * to this method. * * @return The rectangle representing the bounds of this object. * @see java.awt.Component#getBounds */ public Rectangle getBounds();
/** * Updates the supplied handle position only so that the handle appear * correctly with respect to this object. This method is for efficiency. * * @param hi The handle to update. */ public void updateHandle(HandleObject hi);
/** * Updates all the handle positions so that the handles appear correctly with * respect to this object. */ public void updateHandles();
/** * Updates the internal graphic at this object according to the users design * on the drawing canvas. Updation occurs by going through and updating all * preceeding <code>CanvasButtonInterface</code> objects and updating * them as well. */ public void updateImage();
/** * Sets the custom properties of this object. Expected to be implemented * separately for each tool. */ public void setProperties();
Page 81 of 88
/** * Sets the interface used to communicate with the drawing canvas * * @param cbi Interface used to communicate with the drawing canvas */ public void setCanvasButtonInterface(CanvasButtonInterface cbi);
/** * Returns an enumeration of all attached incoming handles. * * @return An enumeration of all incoming handles. */ public Enumeration getIncomingHandles();
/** * Returns an enumeration of all attached outgoing handles. * * @return An enumeration of all outgoing handles. */ public Enumeration getOutgoingHandles();
package rmanchu.thesis.ipb;
/** * Updates the drawing canvas from the supplied cb. * * @param cb The object to parse the tree on. */ public boolean updateCanvas(CanvasButton cb);
/** * Sets all tools on the drawing canvas as not updated. */ public boolean validateCanvas(CanvasButton cb);
Page 82 of 88
package rmanchu.thesis.ipb;
/** * The API used by the standard toolbar to interface with the drawing canvas. * * @author rmanchu
/** * Executes the actions associated with the clicking of the <B>new</B> * standard tool button. */ public void execNew();
/** * Executes the actions associated with the clicking of the <B>open</B> * standard tool button. */ public void execOpen();
/** * Executes the actions associated with the clicking of the <B>save</B> * standard tool button. */ public void execSave();
/** * Executes the actions associated with the clicking of the <B>cut</B> * standard tool button. */ public void execCut();
/** * Executes the actions associated with the clicking of the <B>copy</B> * standard tool button. */ public void execCopy();
Page 83 of 88
/** * Executes the actions associated with the clicking of the <B>paste</B> * standard tool button. */ public void execPaste();
/** * Executes the actions associated with the clicking of the <B>delete</B> * standard tool button. */ public void execDelete();
/** * Executes the actions associated with the clicking of the <B>execute</B> * standard tool button. */ public void execExecute();
package rmanchu.thesis.ipb;
/** * This interface represents the API used by the all the tools on * the modifier toolbar. These tools are<br> * The standard tools:<br> * <ul> * * * * * <li>Media Input</li> <li>Connector</li> <li>Media Output</li> <li>Image Viewer</li> <li>De-Selector</li>
* </ul> * The modifier tools: All the modifier tools. * * @author rmanchu
Page 84 of 88
/** * Readies the supplied <code>CanvasObject</code> to be added to the * drawing canvas. * * @param co The <code>CanvasObject</code> to be added to the drawing canvas. */ public void setCanvasObjectToAdd(CanvasObject co);
/** * Returns the <code>CanvasObject</code> that has been readied to be added * to the drawing canvas. A <code>null</code> is returned if no * <code>CanvasObject</code> is ready to be added. * * @return The object to be added to the drawing canvas. */ public CanvasObject getCanvasObjectToAdd();
/** * Sets the supplied <code>state</code> as the modified state of the project. * If a <code>true</code> is supplied it means the project has been * modified and is in need of saving and vice versa. * * @param state The new state of the project. A <code>true</code> if * the project has been modified and is in need of saving.
/** * Returns the modified state of the project. If a <code>true</code> is * returned, the project is in need of being saved and vice versa. * * @return The current modified state of the project. * @see setProjectModified */ public boolean getProjectModified();
Page 85 of 88
package rmanchu.thesis.ipb;
Page 86 of 88
BIBLIOGRAPHY
[1] Theo Pavlidis, Algorithms for Graphics and Image Processing, Computer Science Press, 1982. [2] [3] [4] [5] John C. Russ, The Image Processing Handbook, CRC Press, 1995. Ernest L. Hall, Computer Image Processing, Academic Press, 1979. David Bistry [et al.], Complete Guide to MMX Technology, McGraw-Hill 1997. Joe King, Matlab for Engineers  Second Edition, Addison-Wesley Publishing Co., 1998. [6] Barry Haynes, Photoshop 6 Artistry  Mastering the Digital Image, New Riders Publishing, 2001. [7] Lawrence H. Rodriguez, Building Imaging Applications with Java Technology, Addison-Wesley Publishing Co., 2001. [8] Michael J. Laslo, Object-Oriented Programming featuring Graphical Applications in Java, Addison-Wesley Publishing Co., 2001. [9] Mitchell Waite [et al.], Data Structures and Algorithms in Java, Waite Group Press, 1999. [10] Matthew Robinson [et al.], Swing, Manning [11] Daniel M Hoffman, Software Design, Automated Testing and Maintenance, International Thompson Computer Press, 1995. [12] C. T. Arrington, Enterprise Java with UML, John Wiley and Sons, 2001. [13] www.intel.com [14] www.microsoft.com
Page 87 of 88
Page 88 of 88