X-Git-Url: https://git.distorted.org.uk/~mdw/tgal/blobdiff_plain/fd972456d42c0d1e5031e4d12ae2ae74384e1582..548ad771d89100cdd1cda2ffa7e3dc085a6ba154:/mason/dhandler diff --git a/mason/dhandler b/mason/dhandler index 4676769..8c151ba 100755 --- a/mason/dhandler +++ b/mason/dhandler @@ -83,20 +83,28 @@ Failed to find ‘<% $path |h %>’. } (my $nosl = $path) =~ s!/$!!; - my $size = "medthumb"; + my @size = ("smallthumb", "medthumb", "bigthumb"); my %tn; - my (%nd, %nf); - for my $f (@$ff) - { $tn{$f} = TrivGal::Image->new($path . $f->name)->scale($size); } + my %count; + for my $f (@$ff) { + my $img = TrivGal::Image->new($path . $f->name); + for my $size (@size) { $tn{$f}{$size} = $img->scale($size); } + } for my $d (@$dd) { my $p = join_paths $path, $d->name; my ($ddd, $fff, $iii); ($ddd, $fff, $iii) = listdir join_paths $IMGROOT, $p; - $nd{$d} = @$ddd; $nf{$d} = @$fff; + + my $count = ""; + $count .= scalar(@$ddd) . "/" if @$ddd; + $count .= scalar(@$fff) if @$fff; + $count{$d} = $count; + DIR: for (;;) { if (defined $iii) { my $index = join_paths $p, $iii->name; - $tn{$d} = TrivGal::Image->new($index)->scale($size); + my $img = TrivGal::Image->new($index); + for my $size (@size) { $tn{$d}{$size} = $img->scale($size); } last DIR; } if (!@$ddd) { $tn{$d} = undef; last DIR; } @@ -124,28 +132,30 @@ Failed to find ‘<% $path |h %>’. % % if (@$dd) {

Subfolders

+% for my $size (@size) { +% } % } % % if (@$ff) {

Images

+% for my $size (@size) { +% } % } %
@@ -222,16 +232,26 @@ Failed to find ‘<% $path |h %>’. my $urldir = join_paths $SCRIPTURL, $dir; my ($dd, $ff, $ii) = listdir $realdir; my @thumbsz = qw{smallthumb medthumb bigthumb}; + my @imgsz = sort { $SIZE{$a} <=> $SIZE{$b} } keys %SIZE; + my ($wd, $ht, $max); my %tn; - my $vw; + my %vw; my $fi = undef; FILE: for (my $i = 0; $i < @$ff; $i++) { my $f = $ff->[$i]; my $img = TrivGal::Image->new(join_paths $dir, $f->name); for my $sz (@thumbsz) { $tn{$f->name}{$sz} = $img->scale($sz); } - if ($ff->[$i]->name eq "$base$ext") - { $fi = $i; $vw = $img->scale("medium"); } + if ($ff->[$i]->name eq "$base$ext") { + $fi = $i; + ($wd, $ht) = ($img->wd, $img->ht); + $max = $img->sz; + SIZE: for my $sc (@imgsz) { + my $sz = $SIZE{$sc}; + last SIZE if $max < $sz; + $vw{$sc} = $img->scale($sc); + } + } } defined $fi or die "image not found in its folder?"; my $this = $ff->[$fi]; @@ -267,13 +287,39 @@ Failed to find ‘<% $path |h %>’. %
% if ($link{prev}) { - + % } - + +% my ($hoff, $voff) = (60, 480); +% SIZE: for (my $i = 0; $i < @imgsz; $i++) { +% my $scale = $imgsz[$i]; +% last SIZE unless exists $vw{$scale}; +% my $scsz = $SIZE{$scale}; +% my $f = $scsz/$max; +% my ($thiswd, $thisht) = map int, ($f*$wd + $hoff, $f*$ht + $voff); + +% } + "> + % if ($link{next}) { - + % }
%