276 lines
6.9 KiB
Perl
276 lines
6.9 KiB
Perl
package WebGUI::Storage::Image;
|
|
|
|
=head1 LEGAL
|
|
|
|
-------------------------------------------------------------------
|
|
WebGUI is Copyright 2001-2005 Plain Black Corporation.
|
|
-------------------------------------------------------------------
|
|
Please read the legal notices (docs/legal.txt) and the license
|
|
(docs/license.txt) that came with this distribution before using
|
|
this software.
|
|
-------------------------------------------------------------------
|
|
http://www.plainblack.com info@plainblack.com
|
|
-------------------------------------------------------------------
|
|
|
|
=cut
|
|
|
|
use Image::Magick;
|
|
use strict;
|
|
use WebGUI::Id;
|
|
use WebGUI::Session;
|
|
use WebGUI::Storage;
|
|
use WebGUI::Utility;
|
|
|
|
our @ISA = qw(WebGUI::Storage);
|
|
|
|
|
|
=head1 NAME
|
|
|
|
Package WebGUI::Storage::Image
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
Extends WebGUI::Storage to add image manipulation operations.
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
use WebGUI::Storage::Image;
|
|
|
|
|
|
=head1 METHODS
|
|
|
|
These methods are available from this class:
|
|
|
|
my $boolean = $self->generateThumbnail($filename);
|
|
my $url = $self->getThumbnailUrl;
|
|
my $boolean = $self->isImage;
|
|
|
|
=cut
|
|
|
|
|
|
#-------------------------------------------------------------------
|
|
|
|
=head2 addFileFromCaptcha ( )
|
|
|
|
Generates a captcha image (105px x 26px) and returns the filename and challenge string (6 random characters). For more information about captcha, consult the Wikipedia here: http://en.wikipedia.org/wiki/Captcha
|
|
|
|
=cut
|
|
|
|
sub addFileFromCaptcha {
|
|
my $self = shift;
|
|
my $challenge;
|
|
srand;
|
|
$challenge.= ('A'..'Z')[rand(26)] foreach (1..6);
|
|
my $filename = "captcha.".WebGUI::Id::generate().".png";
|
|
my $image = Image::Magick->new();
|
|
$image->Set(size=>'105x26');
|
|
$image->ReadImage('xc:white');
|
|
$image->AddNoise(noise=>"Multiplicative");
|
|
$image->Annotate(font=>$session{config}{webguiRoot}."/lib/default.ttf", pointsize=>30, skewY=>0, skewX=>0, gravity=>'center', fill=>'white', antialias=>'true', text=>$challenge);
|
|
$image->Blur(geometry=>"1");
|
|
$image->Set(type=>"Grayscale");
|
|
$image->Border(fill=>'black', width=>1, height=>1);
|
|
$image->Write($self->getPath($filename));
|
|
return ($filename, $challenge);
|
|
}
|
|
|
|
|
|
#-------------------------------------------------------------------
|
|
|
|
=head2 generateThumbnail ( filename, [ thumbnailSize ] )
|
|
|
|
Generates a thumbnail for this image.
|
|
|
|
=head3 filename
|
|
|
|
The file to generate a thumbnail for.
|
|
|
|
=head3 thumbnailSize
|
|
|
|
The size in pixels of the thumbnail to be generated. If not specified the thumbnail size in the global settings will be used.
|
|
|
|
=cut
|
|
|
|
sub generateThumbnail {
|
|
my $self = shift;
|
|
my $filename = shift;
|
|
my $thumbnailSize = shift || $session{setting}{thumbnailSize};
|
|
unless (defined $filename) {
|
|
WebGUI::ErrorHandler::error("Can't generate a thumbnail when you haven't specified a file.");
|
|
return 0;
|
|
}
|
|
unless ($self->isImage($filename)) {
|
|
WebGUI::ErrorHandler::error("Can't generate a thumbnail for something that's not an image.");
|
|
return 0;
|
|
}
|
|
my $image = Image::Magick->new;
|
|
my $error = $image->Read($self->getPath($filename));
|
|
if ($error) {
|
|
WebGUI::ErrorHandler::error("Couldn't read image for thumbnail creation: ".$error);
|
|
return 0;
|
|
}
|
|
my ($x, $y) = $image->Get('width','height');
|
|
my $n = $thumbnailSize;
|
|
if ($x > $n || $y > $n) {
|
|
my $r = $x>$y ? $x / $n : $y / $n;
|
|
$image->Scale(width=>($x/$r),height=>($y/$r));
|
|
$image->Sharpen('0.0x1.0');
|
|
}
|
|
$error = $image->Write($self->getPath.'/'.'thumb-'.$filename);
|
|
if ($error) {
|
|
WebGUI::ErrorHandler::error("Couldn't create thumbnail: ".$error);
|
|
return 0;
|
|
}
|
|
return 1;
|
|
}
|
|
|
|
#-------------------------------------------------------------------
|
|
|
|
=head2 getFiles ( )
|
|
|
|
Returns an array reference of the files in this storage location.
|
|
|
|
=cut
|
|
|
|
sub getFiles {
|
|
my $self = shift;
|
|
my $files = $self->SUPER::getFiles;
|
|
my @newFiles;
|
|
foreach my $file (@{$files}) {
|
|
next if $file =~ /^thumb-/;
|
|
push (@newFiles,$file);
|
|
}
|
|
return \@newFiles;
|
|
}
|
|
|
|
#-------------------------------------------------------------------
|
|
|
|
=head2 getSizeInPixels ( filename )
|
|
|
|
Returns the width and height in pixels of the specified file.
|
|
|
|
=head3 filename
|
|
|
|
The name of the file to get the size of.
|
|
|
|
=cut
|
|
|
|
sub getSizeInPixels {
|
|
my $self = shift;
|
|
my $filename = shift;
|
|
unless (defined $filename) {
|
|
WebGUI::ErrorHandler::error("Can't check the size when you haven't specified a file.");
|
|
return 0;
|
|
}
|
|
unless ($self->isImage($filename)) {
|
|
WebGUI::ErrorHandler::error("Can't check the size of something that's not an image.");
|
|
return 0;
|
|
}
|
|
my $image = Image::Magick->new;
|
|
my $error = $image->Read($self->getPath($filename));
|
|
if ($error) {
|
|
WebGUI::ErrorHandler::error("Couldn't read image to check the size of it: ".$error);
|
|
return 0;
|
|
}
|
|
return $image->Get('width','height');
|
|
}
|
|
|
|
#-------------------------------------------------------------------
|
|
|
|
=head2 getThumbnailUrl ( filename )
|
|
|
|
Returns the URL to a thumbnail for a given image.
|
|
|
|
=head3 filename
|
|
|
|
The file to retrieve the thumbnail for.
|
|
|
|
=cut
|
|
|
|
sub getThumbnailUrl {
|
|
my $self = shift;
|
|
my $filename = shift;
|
|
return $self->getUrl("thumb-".$filename);
|
|
}
|
|
|
|
|
|
#-------------------------------------------------------------------
|
|
|
|
=head2 isImage ( filename )
|
|
|
|
Checks to see that the file specified is an image. Returns a 1 or 0 depending upon the result.
|
|
|
|
=head3 filename
|
|
|
|
The file to check.
|
|
|
|
=cut
|
|
|
|
sub isImage {
|
|
my $self = shift;
|
|
my $filename = shift;
|
|
return isIn($self->getFileExtension($filename), qw(jpeg jpg gif png))
|
|
}
|
|
|
|
|
|
#-------------------------------------------------------------------
|
|
|
|
=head2 resize ( filename [, width, height ] )
|
|
|
|
Resizes the specified image by the specified height and width. If either is omitted the iamge will be scaleed proportionately to the non-omitted one.
|
|
|
|
=head3 filename
|
|
|
|
The name of the file to resize.
|
|
|
|
=head3 width
|
|
|
|
The new width of the image in pixels.
|
|
|
|
=head3 height
|
|
|
|
The new height of the image in pixels.
|
|
|
|
=cut
|
|
|
|
sub resize {
|
|
my $self = shift;
|
|
my $filename = shift;
|
|
my $width = shift;
|
|
my $height = shift;
|
|
unless (defined $filename) {
|
|
WebGUI::ErrorHandler::error("Can't resize when you haven't specified a file.");
|
|
return 0;
|
|
}
|
|
unless ($self->isImage($filename)) {
|
|
WebGUI::ErrorHandler::error("Can't resize something that's not an image.");
|
|
return 0;
|
|
}
|
|
unless ($width || $height) {
|
|
WebGUI::ErrorHandler::error("Can't resize with no resizing parameters.");
|
|
return 0;
|
|
}
|
|
my $image = Image::Magick->new;
|
|
my $error = $image->Read($self->getPath($filename));
|
|
if ($error) {
|
|
WebGUI::ErrorHandler::error("Couldn't read image for resizing: ".$error);
|
|
return 0;
|
|
}
|
|
my ($x, $y) = $image->Get('width','height');
|
|
if ($width && !$height) { # proportional scale by width
|
|
$height = $width / $x * $y;
|
|
} elsif (!$width && $height) { # proportional scale by height
|
|
$width = $height * $x / $y;
|
|
}
|
|
$image->Scale(width=>$width, height=>$height);
|
|
$error = $image->Write($self->getPath($filename));
|
|
if ($error) {
|
|
WebGUI::ErrorHandler::error("Couldn't create thumbnail: ".$error);
|
|
return 0;
|
|
}
|
|
return 1;
|
|
}
|
|
|
|
|
|
1;
|
|
|