NAME
Global::Rainbow::Map - make the world look like a rainbow, but usefully
SYNOPSIS
my $map = Global::Rainbow::Map->new(
gb => 'red',
ca => 'orange',
in => 'yellow',
nz => 'green',
au => 'blue',
lk => 'purple',
);
print $map->svg;
DESCRIPTION
Global::Rainbow::Map generates a map of the world (Robinson projection) with each country shaded whatever colour you like. In fact, you can even choose colours that don't appear in the rainbow... like magenta!
The possibilities for such a module are clearly endless. If you had a table listing per-capita alcohol consumption, you could create a map of the world in different colours to illustrate per-capita alcohol consumption. Or if you had a table of which countries had won the most Olympic medals for swimming, then you could create a map of the world in different colours to illustrate which countries had won the most Olympic medals for swimming.
The template map used is Wikipedia's public domain blank world map http://en.wikipedia.org/wiki/File:BlankMap-World6.svg, the 14 Feb 2012 revision.
Constructor
new(%colours)
-
Creates a new map. The hash is a list of country code to colour pairings.
Country codes are typically ISO 3166-1 two letter codes. If you don't know the code for a particular country, Locale::Country can help you out. There are a number of additional codes like "eu" (the whole European Union) and "aq" (Antarctica). These codes are all lower case.
Colours can be hexadecimal codes like '#ff0000' or named colours from the SVG or X11 palettes. Countries not coloured will remain a pale grey.
Hash keys which do not match the regular expression
/^[a-z][a-z0-9-]*[a-z0-9]$/
, in particular hash keys starting with a hyphen are reserved for future use.
Object Methods
The useful ones:
svg
-
Returns the coloured SVG map as a string.
libxml_document
-
Returns the same coloured SVG map, but as an XML::LibXML::Document.
Somewhat less useful for everyday use, but may be useful for people subclassing this module...
countries
-
Returns the list of country codes which have been explicitly assigned a colour (i.e. the keys to the hash given in the constructor).
colour_for_country($country_code)
-
Returns the colour for a country, as a blessed Color::Library::Color object.
Will return undef if the country has not been explicitly assigned a colour.
generate_css
-
Generates the CSS that would be inserted into the SVG output.
Class Methods
Again, these are mostly useful for people subclassing the module.
get_template
-
Returns the template used for maps as an XML::LibXML::Document.
Fetching the template and modifying it using DOM methods will affect all maps subsequently generated for the lifetime of the process. So beware.
clone_template
-
As per
get_template
, but returns a clone of the template.
BUGS
Please report any bugs to http://rt.cpan.org/Dist/Display.html?Queue=Global-Rainbow-Map.
SEE ALSO
http://commons.wikimedia.org/wiki/File_talk:BlankMap-World6.svg/Documentation.
http://www.biotele.com/magenta.html.
AUTHOR
Toby Inkster <tobyink@cpan.org>.
COPYRIGHT AND LICENCE
Toby Inkster, 2012. No rights reserved.
To the extent possible under law, Toby Inkster has waived all copyright and related or neighboring rights to Global::Rainbow::Map. This work is published from: United Kingdom.
http://creativecommons.org/publicdomain/zero/1.0/.
DISCLAIMER OF WARRANTIES
THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.