Gluas is a gimp plug-in providing a enviroment for testing algorithms for image processing. The environment contains a simple editor for entering the algorithms. It uses the lua interpreter.
Gluas can be downloaded from Gluas download page, to be able to use gluas properly you also need an installation of The GIMP.
Note | |
---|---|
Note that the author doesn't know the windows installation procedure in detail. Any contribution to clarify would be welcome. |
The gluas installer on the website provides for a system wide installation of gluas, this is the easiest way to install gluas,
Caution | |
---|---|
If The GIMP has been installed in a location where the user does not have write privileges, you need to do a per user install. |
Procedure 2.1. Installing gluas from source
Preqrequisites
You need The GIMP's developer files (headers), as well as an installed lua runtime, with development files (headers). In Debian™ the following packages, and their dependencies need to be installed:
For syntax highlighting libgtksourceview must be installed as well.
Download
The latest release of the gluas source can be found in the files subfolder of the gluas website. The latest version is the version with the highest version number, at the time of writing that was 0.1.19.
At the commandline, entering:
wget http://pippin.gimp.org/plug-ins/gluas/files/gluas-0.1.19.tar.gz
should be sufficient to complete this step, although checking for a never version using a web browser is recommended.
Extract
tar xvzf gluas-0.1.19.tar.gz
The characters after the command tar indicates what the tar applications should do, the meaning of the used characters are:
extract
verbose
ungzip (uncompress, replace this with
j
, for .tar.bz2
files)
the input to tar is a file (as opposed to data coming on standard input)
Enter the gluas directory
cd gluas-0.1.19
Configure
./configure
This will prepare compilation of the gluas plug-in for your specific system, if any components/packages that are needed are not found, the configure script will complain.
Tip | |
---|---|
Running configure takes a little while, prepare a cup of tea while it runs. |
Make
make
Compiling gluas should not take a long time, the binary produced can either be manually placed in the users private plug-in folder, or be installed systemwide.
Relax | |
---|---|
If you are following the previous tip, you can now drink your tea. |
Install
We need to be the super user to install the application, thus we need to become root.
su Password: joshua
Caution | |
---|---|
If you already are root, ask someone who knows why this is stupid. |
Now we issue the command to do the actual installation of our compiled program.
make install
The next time you start the Gimp, gluas should be available from the menu system at:
-> -> .The enviroment set up when processing starts, sets the global variables width and height, functions for setting and getting pixels are provided
A programming tutorial for lua is out of scope for this document, the samples given elsewhere in this document should provide a feel for the language, some peculiarities of lua is explained here, look at The lua website, for a short overview when reading sample code Lua Short Reference might come in handy.
There are functions to set and get individual pixels, they are of the form:
v get_value(
x, y)
;
set_value(
x, y, v)
;
See the section called “Gluas reference” for more functions, and details.
All values used in gluas are floating point values, unless mandated by the color model, the normal range is from 0.0 to 1.0. This range is used instead of an more arbitary range like 0-255, 0-42, 0-100 or 0-65535.
The width and height of the image in pixels can be accessed through global variables with those names.
The GIMP takes care of modifying only the portions that are part of the current selection, as well as blending old and new pixel values for partially selected pixels.
The coordinates of the boundingbox of the selection can be accessed through global variables, see bound_x0, bound_y0 and bound_x1, bound_y1.
When pixels are set, they don't immediatly overwrite the original pixel values. This is to facilitate area operations. When multipass algorithms are implemented, like a two pass blur, the changes can be comitted to the source buffer by issuing
A mischellaneus collections of samples reside at The gluas gallery. As well as part of the work in progress Images Processing using gluas.
In the following sample the code needed for a simple thresholding filter is documented.
Figure 2.2. basic gluas program
for y=0, height-1 do for x=0, width-1 do v = get_value (x,y) if v < 0.5 then v=1.0 else v=0.0 end set_value (x,y,v) end progress (y/height) end
By either pressing the button with gears, or pressing F5 gluas will apply the algorihm described. If any processing errors occur an error panel will appear at the top of the gluas window.
Gluas uses the core lua language for processing, but extends it with some functions specific to interaction with The GIMP.
r,g,b,a get_rgba(
x, y)
;
Returns the Red, Green, Blue and Alpha components for the coordinates specified by the x,y parameters. The values are taken from the source image which is the original pixel data, unless flush() has been invoked.
RGB values within gluas are values between 0.0 and 1.0.
set_rgba(
x, y, r, g, b, a)
;
Sets a pixel, using the specified Red, Green, Blue and Alpha component values.
r,g,b get_rgb(
x, y)
;
set_rgb(
x, y, r, g, b)
;
Functions similar to the RGBA varieties, note that the set_rgb function will not preserve the alpha value of the pixel, but boost it to 1.0 (full opacity).
h,s,l get_hsl(
x, y)
;
set_hsl(
x, y, h, s, l)
;
Hue, Saturation, Lightness pixel value setters and getters.
h,s,v get_hsv(
x, y)
;
set_hsv(
x, y, h, s, v)
;
Hue, Saturation, Value pixel value setters and getters. Value is calculated by gimp as MAX(MAX(r,g),b), i.e. the R,G or B component with the largest value.
l,a,b get_lab(
x, y)
;
set_lab(
x, y, l, a, b)
;
CIE Lab pixel setter and getter functions. .
progress(
percentage)
;
Update the progress bar in The GIMP's statusbar to the given percentage, useful when giving user feedback.
flush(
)
;
Copies the data from the temporary output image buffer, over the data
in the source image buffer. This makes it possible to do additional
processing steps (the values returned with getters will be the values
previously set with setters prior to the flush()
).
flush()
is mostly useful when implementing
multipass algorithms, like a decomposed blur.
In order to know the dimensions, and some other aspects of the image, some numeric constants are also imported into the lua enviroment you program in.
The width of the input image, in pixels.
The height of the input image, in pixels.
When expanding the properties pane in the gluas editor, a slider shows up, the value of this slider can be accessed through this global variable.
Note that the program is run each time the mouse button is released on a new value.
It is also possible to generate animations that can be played back with The GIMP's Animation plug-ins. Then the value of user_data varies from 0.0 to 1.0.
The upper left coordinate of the bounding box of the current selection, may be used to speed up calculations by not taking unselected areas into account.
The bottom right coordinate of the bounding box of the current selection, may be used to speed up calculations by not taking unselected areas into account.
Marco Pontello has developed a Project Dogwaffle plug-in, DogLua, , which is compatible with the core gluas functionality.
Artweaver (a freeware image painting program) also have support for lua. Artweaver lua scripting interface plug-in.