diff options
-rwxr-xr-x | lib/App/Dthumb.pm | 207 |
1 files changed, 207 insertions, 0 deletions
diff --git a/lib/App/Dthumb.pm b/lib/App/Dthumb.pm index 2a4ae27..b718766 100755 --- a/lib/App/Dthumb.pm +++ b/lib/App/Dthumb.pm @@ -1,5 +1,40 @@ package App::Dthumb; + +=head1 NAME + +App::Dthumb - Generate thumbnail index for a set of images + +=head1 SYNOPSIS + + use App::Dthumb; + use Getopt::Long qw(:config no_ignore_case); + + my $opt = {}; + + GetOptions( + $opt, + qw{ + help|h + size|d=i + spacing|s=f + no-lightbox|L + no-names|n + quality|q=i + version|v + }, + ); + + my $dthumb = App::Dthumb->new($opt); + $dthumb->run(); + +=head1 VERSION + +This manual documents App::Dthumb version 0.1 + +=cut + + use strict; use warnings; use autodie; @@ -18,6 +53,67 @@ our $VERSION = '0.1'; STDERR->autoflush(1); + +=head1 METHODS + +=head2 new($conf) + +Returns a new B<App::Dthumb> object. As you can see in the SYNOPSIS, $conf is +designed so that it can be directly fed by B<Getopt::Long>. + +Valid hash keys are: + +=over + +=item B<help> => I<bool> + +If true, prints a short help message to STDOUT and quits + +Default: false + +=item B<size> => I<int> + +Maximum image size in pixels, either width or height (depending on image +orientation) + +Default: 200 + +=item B<spacing> => I<float> + +Spacing between image boxes. 1.0 means each box is exactly as wide as the +maximum image width (see B<size>), 1.1 means slightly larger, et cetera + +Default: 1.1 + +=item B<no-lightbox> => I<bool> + +Do not show include javascript lightbox code + +Default: false + +=item B<no-names> => I<bool> + +Do not show image name below thumbnail + +Default: false + +=item B<quality> => I<0 .. 100> + +Thumbnail image quality + +Default: 75 + +=item B<version> => I<bool> + +If true, prints version information to STDOUT and quits + +Default: false + +=back + +=cut + + sub new { my ($obj, $conf) = @_; my $ref = {}; @@ -45,6 +141,14 @@ sub new { return bless($ref, $obj); } + +=head2 run + +Run dthumb. Read all files, create thumbnails, write index.xhtml, and so on. + +=cut + + sub run { my ($self) = @_; @@ -56,6 +160,22 @@ sub run { $self->write_out_html(); } + +=head1 INTERNALS + +The following methods are internal only and do not need to be called by +external scripts. This documentation is only for people working on +B<App::Dthumb> itself. All of them are object-oriented, so need to be called +as $dthumb->something(). + +=head2 check_cmd_flags + +Check if version/help flags in the config are set. If so, print the +corresponding text to STDOUT and quit. + +=cut + + sub check_cmd_flags { my ($self) = @_; @@ -69,6 +189,16 @@ sub check_cmd_flags { } } + +=head2 read_directories + +Store all image files in the current directory in $self->{files} (arrayref), +and all files in F<.thumbs> which do not have a corresponding full-size image +in $self->{old_thumbnails}. $self->{files} is sorted case-insensitively. + +=cut + + sub read_directories { my ($self) = @_; my $thumbdir = $self->{config}->{dir_thumbs}; @@ -104,6 +234,18 @@ sub read_directories { ); } + +=head2 create_files + +Makes sure the F<.thumbs> directory exists. + +If $self->{conf}->{lightbox} is true (which is the default), also creates the +F<.dthumb> directory and fills it with F<lightbox.js>, F<overlay.png>, +F<loading.gif> and F<close.gif>. + +=cut + + sub create_files { my ($self) = @_; my $thumbdir = $self->{config}->{dir_thumbs}; @@ -127,6 +269,15 @@ sub create_files { } } + +=head2 delete_old_thumbnails + +Unlink all no longer required thumbnails (those saved in +$self->{old_thumbnails}). + +=cut + + sub delete_old_thumbnails { my ($self) = @_; my $thumbdir = $self->{config}->{dir_thumbs}; @@ -136,6 +287,15 @@ sub delete_old_thumbnails { } } + +=head2 create_thumbnails + +Iterate over all files in $self->{files}, print a progress bar to STDERR and +call B<create_thumbnail_html> and B<create_thumbnail_image> for each. + +=cut + + sub create_thumbnails { my ($self) = @_; @@ -152,6 +312,14 @@ sub create_thumbnails { print "\n"; } + +=head2 create_thumbnail_html($file) + +Append the necessary lines for $file to the HTML. + +=cut + + sub create_thumbnail_html { my ($self, $file) = @_; my $div_width = $self->{config}->{size} * $self->{config}->{spacing}; @@ -183,6 +351,15 @@ sub create_thumbnail_html { $self->{html} .= "</div>\n"; } + +=head2 create_thumbnail_image($file) + +Load F<$file> and save a resized version in F<.thumbs/$file>. Returns if the +thumbnail file already exists, so far it doesn't do any further checks. + +=cut + + sub create_thumbnail_image { my ($self, $file) = @_; my $thumbdir = $self->{config}->{dir_thumbs}; @@ -209,6 +386,14 @@ sub create_thumbnail_image { $thumb->save("${thumbdir}/${file}"); } + +=head2 write_out_html + +Write the cached HTML data to F<index.xhtml>. + +=cut + + sub write_out_html { my ($self) = @_; @@ -236,3 +421,25 @@ sub write_out_html { #} 1; + +__END__ + +=head1 DEPENDENCIES + +=over + +=item * App::Dthumb::Data + +=item * Image::Imlib2 + +=item * Time::Progress + +=back + +=head1 AUTHOR + +Copyright (C) 2009-2011 by Daniel Friesel E<gt>derf@chaosdorf.deE<lt> + +=head1 LICENSE + + 0. You just DO WHAT THE FUCK YOU WANT TO. |