NAME
Image::Heatmap - Build heatmap images
DESCRIPTION
Will effortlessly convert latitude/longitude coordinates into a graphical heatmap of the geographical region relative the number of points outlined.
http://is.gd/jvew are two examples of such images built by early versions of this module.
METHODS
new
Will instantiate and return a blessed scalar reference to an integer representing the 'object id' (incremented unique integer for each object).
Does not use any 3rd party modules such as Moose or Class::Accessor to obtain good object management. Albeit a potentially better design, I simply didn't want to mess with it.
process
Will generate the heatmap, saving a file of chosen type (based off file suffix) to the location defined in 'output' (see ATTRIBUTES)
ATTRIBUTES
processes
Default: 1
Will define the number of processes to use for the image processing. Will only add each plot to the full image with the processes, where the final image will be generated with only a single process. Furthermore, being the module will iterate over the set twice (for reasons I will leave out), the first iteration will, too, only be processed in single-thread mode.
If one (1) process is selected, only one process will be used throughout the use of this module. If > 1 is required, there will be n + 1, where the parent will fork the number of processes requested and block on their completion.
statement
Will accept the statement handle the module will use. At the time of this writing, this is the only method of giving a list of lat/long to the module (see TODO).
The module will assume the statement handle to take zero bind parameters and assume (at least) two column names: 'latitude' and 'longitude', respectively. A defficiency of these requirements will kill the processing.
my $image = Image::Heatmap->new();
my $dbh = DBI->new( 'dsn', 'user', 'pass', {} );
# Note that because the requirement of the named columns, if the columns of
# the table do not match, you should select them as named columns.
my $sth = $dbh->prepare('select lat AS latitude, long AS longitude from table');
map
A string representng the readable location of the mapping image the plots will be layered upon.
tmp_dir
Default: /tmp/
Used primarily when using multiple-processes, will cache some images along the way in the specified directory.
output
Default: heatmap.png
The literal path to the heatmap image. Will be of the type specified by it's file suffix.
parent
Used by the module, will hold the process id of the parent process.
thumbnail
OPTIONAL
The literal path to the heatamp thumbnail image.
thumbnail_scale
OPTIONAL
The scale of the thumbnail, relative to the size of the map.
colors
Default: colors.png
The semi-literal path to the color swatch that will be used for the plots. If the file cannot be found, File::Find will be used to hunt it down within the directory root of the module its self. 'colors.png' is provided in this module.
plot_base
Default: bolilla.png
The semi-literal path to the plot that will be used as the basis for each plot added to the heatmap. If the file cannot be found, File::Find will be used to hunt it down within the directory root of the module. 'bolilla.png' is provided in this distribution and is a 64px square image.
plot_size
Default: 64
The size, in pixels, of the plot image that will be used. Will scale the image at 'plot_base' to be a square with a width and height the size defined here.
image_width
The width of the image that will be mapped. May be defined, but will otherwise be taken from the demensions defined by the image.
image_height
The height of the image that will be mapped. May be defined, but will otherwise be taken from the demensions defined by the image.
zoom
Default: 1
Will zoom the view 'n' times the size of the image.
As, by default, the module will plot relative to the entire planet, zooming is useful (in conjunction with {x,y}_adjust) to view a particular area of Earth rather then the planet as a whole.
x_adjust
Will adjust the view by 'n' pixels relative to the x pan of a cartesian plane.
Useful with the zoom factor when concentrating on a particular area on Earth rather than the planet as a whole.
y_adjust
Will adjust the view by 'n' pixels relative to the y pan of a cartesian plane.
Useful with the zoom factor when concentrating on a particular area on Earth rather than the planet as a whole.
width
Will define the width, in pixels, of the plot area. Will default to the width of the mapped image.
height
Will define the height, in pixels, of the plot area. Will default to the height of the mapped image.
EXAMPLES
use Image::Heatmap;
use DBI;
my $heatmap = Image::Heatmap->new();
my $dbh = DBI->connect( 'dsn', 'username', 'password', {} );
my $sth = $dbh->prepare('select latitude, lon AS longitude from table');
$heatmap->statement( $sth );
$heatmap->process();
$heatmap->tmp_dir('/tmp');
$heatmap->output('/tmp/heatmap.gif');
$heatmap->process();
$heatmap->output('/tmp/heatmap.jpg');
$heatmap->process();
$heatmap->output('/tmp/heatmap.png');
$heatmap->process();
SEE ALSO
TODO
- More input methods
-
At the time of this writing, the only method of which to give this module coordinates to plot is via a DBI statement handle with specifically named columns. This is useful, but not what everyone would necessarily want and it is my goal (not promise ;) ) to add this at some time in the future.
- $VERSION > 1
-
There are a few known bugs and missing unit tests that prevent me from making this module's $VERSION >= 1. It is my goal to fix this and release it as a 'production ready' module.
AUTHOR
Trevor Hall, <wazzuteke@cpan.org>
COPYRIGHT AND LICENSE
Copyright (C) 2009 by Trevor Hall
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.