Image::Thumbnail
================

NAME
   Image::Thumbnail - Simple thumbnails with GD/ImageMagick/Imager

INSTALLATION

To install this module type the following:

  perl Makefile.PL
  make
  make test
  make install

SYNOPSIS
           use Image::Thumbnail 0.6;

           # Create a thumbnail from 'test.jpg' as 'test_t.jpg'
           # using ImageMagick, Imager, or GD.
           my $t = new Image::Thumbnail(
                   size       => 55,
                   create     => 1,
                   input      => 'test.jpg',
                   outputpath => 'test_t.jpg',
           );

           my $t = new Image::Thumbnail(
                   size       => "55x75",
                   create     => 1,
                   module     => "Image::Magick",
                   input      => $imageObject,
                   outputpath => 'test_t.jpg',
           );

           # Create a thumbnail from 'test.jpg' as 'test_t.jpg'
           # using GD.
           my $t = new Image::Thumbnail(
                   module     => 'GD',
                   size       => 55,
                   create     => 1,
                   input      => 'test.jpg',
                   outputpath => 'test_t.jpg',
           );

           # Create a thumbnail from 'test.jpg' as 'test_t.jpg'
           # using Imager.
           my $t = new Image::Thumbnail(
                   module     => 'Imager',
                   size       => 55,
                   create     => 1,
                   input      => 'test.jpg',
                   outputpath => 'test_t.jpg',
           );

           # Create a thumbnail as 'test_t.jpg' from an ImageMagick object
           # using ImageMagick, or GD.
           my $t = new Image::Thumbnail(
                   size       => "55x25",
                   create     => 1,
                   input      => $my_image_magick_object,
                   outputpath => 'test_t.jpg',
           );

           # Create four more of ever-larger sizes
           for (1..4){
                   $t->{size} = 55+(10*$_);
                   $t->create;
           }

           exit;

DESCRIPTION
   This module was created to answer the FAQ, 'How do I simply create a
   thumbnail with pearl?' (*sic*). It allows you to easily make thumbnail
   images from files, objects or 'blobs', using either the ImageMagick,
   Imager or GD libraries.

   Thumbnails created can either be saved as image files or accessed as
   objects via the "object" field: see create.

PREREQUISITES
   One of "Image::Magick", "Imager", or "GD".

CONSTRUCTOR new
   Parameters are supplied as a hash or hash-like list of name/value pairs:
   See the "SYNOPSIS".

 REQUIRED PARAMETERS
   size
       The size you with the longest side of the thumbnail to be. This may
       be provided as a single integer, or as an ImageMagick-style
       'geometry' such as "100x120".

   input
       You must the "input" parameter as one of:

       Input file path
           A scalar that is an absolute path to an image to use as the
           source file.

       Object
           An object-reference created by your chosen package. Naturally
           you can't supply this field if you haven't specified a "module"
           field (see above).

       Blob
           A reference to a scalar that is the raw binary image data,
           perhaps drawn from a database BLOB column, perhaps from a file.

       The formerly required input fields should be considered depricated,
       and although they will be kept in the API for this release, they
       will eventually be removed.

 OPTIONAL PARAMETERS
   module ( GD | ImageMagick | Imager )
       If you wish to use a specific module, place its name here. You must
       have the module you require already installed!

       Supplying no name will allow ImageMagick, then Imager to be tried
       before GD.

   create
       Put any value in this field if you wish the constructor to call the
       "create" method automatically before returning.

   inputtype, outputtype
       If you are using "GD", you can explicitly set the input and output
       formats for the image file, provided you use a string that can be
       evaluated to a "GD"-supported image format (see GD).

       Default behaviour is to attempt to ascertin the file type and to
       create the thumbnail in the same format. If the type cannot be
       defined (you are using "GD", have supplied the "object" field and
       not the "outputtype" field) then the output file format defaults to
       "jpeg".

   depth
       Sets colour depth in ImageMagick - GD only supports 8-bit.

       The ImageMagick manpage (see
       <http://www.imagemagick.org/www/ImageMagick.html#opti>). says:

   density
       ImageMagick only: sets the pixel density. Must be a valid
       ImageMagick 'geometry' value (that is, two numbers giving the *x*
       and *y* dimensions, delimited by a lower-case *x*. Default value is
       "96x96".

   quality
       ImageMagick/Imager only: an integer from 1 to 100 to specify the
       thumbnail quality. Defaults to 50.

   attr
       If you are using ImageMagick, this field should contain a hash of
       ImageMagick attributes to pass to the ImageMagick "Set" command when
       the thumbnail is created. Any errors these may generate are not yet
       caught.

   CHAT
       Put any value in this field for real-time process info.

 PARAMETERS SET
       x,y The dimension of the thumbnail produced.

 ERRORS
       As of version 0.4, any errors are stored in the fields "error",
       warnings in "warning".

       Any errors will be printed to "STDOUT". If they completely prevent
       processing, they will be fatal ("croak"ed). If partial processing
       has taken place by the explicit or implicit calling of the "create"
       method, then the field of the same name will have value.

       Depending on how far processing has proceded, other fields may have
       useful values: the "module" field will contain the name of the
       module used; the "object" field may contain an object of the module
       used; the "thumb" field may contain a thumbnail image.

METHOD create
       Creates a thumbnail using the supplied object. This method is called
       automatically if you construct with the "create" field flagged.

       Sets the following fields:

       module
           Will contain the name of the module used (set by this module if
           not by the user);

       object
           Will contain an instance of the module used;

       thumb
           Will contain the thumbnail image.

       Returns c<undef> on failure.

EXPORT
       None.

CHANGES
       Please see the file CHANGES in the distribution tar.

SEE ALSO
       perl, Image::Epeg, GD, Imager, Image::Magick,
       Image::Magick::Thumbnail, Image::GD::Thumbnail.

AUTHOR
       Lee Goddard <cpan-at-leegoddard-dot-net>

       Thanks to Sam Tregar, Himmy and Chris Laco.

COPYRIGT
       Copyright (C) Lee Godadrd 2001-2005. All rights reserved. Supplied
       under the same terms as Perl itself.