--- loncom/homework/randomlylabel.pm 2004/02/23 23:54:14 1.18 +++ loncom/homework/randomlylabel.pm 2004/03/16 23:08:23 1.19 @@ -2,7 +2,7 @@ # The LearningOnline Network with CAPA # randomlabel.png: composite together text and images into 1 image # -# $Id: randomlylabel.pm,v 1.18 2004/02/23 23:54:14 albertel Exp $ +# $Id: randomlylabel.pm,v 1.19 2004/03/16 23:08:23 albertel Exp $ # # Copyright Michigan State University Board of Trustees # @@ -201,11 +201,38 @@ sub handler { } $image->copy($subimage,$x,$y,0,0,$subimage->getBounds()); } elsif ($type eq 'LABEL') { - my ($x,$y,$text,$font,$color)=split(':',$ENV{"cgi.$id.OBJ$i"}); + my ($x,$y,$text,$font,$color,$direction)= + split(':',$ENV{"cgi.$id.OBJ$i"}); $text=&Apache::lonnet::unescape($text); my $imcolor=&get_color_from_hexstring($image,$color); - my $height=GD::Font->Giant->height; - $image->string(GD::gdGiantFont,$x,$y-$height,$text,$imcolor); + my $type='normal'; + my ($height,$fontref); + if ($font eq 'tiny') { + $height=GD::Font->Tiny->height; + $fontref=GD::gdTinyFont; + } elsif ($font eq 'small') { + $height=GD::Font->Small->height; + $fontref=GD::gdSmallFont; + } elsif ($font eq 'medium') { + $height=GD::Font->MediumBold->height; + $fontref=GD::gdMediumBoldFont; + } elsif ($font eq 'large') { + $height=GD::Font->Large->height; + $fontref=GD::gdLargeFont; + } elsif ($font eq 'giant' || !defined($font)) { + $height=GD::Font->Giant->height; + $fontref=GD::gdGiantFont; + } else { + $type='ttf'; + } + if ($type eq 'normal' && $direction eq 'vertical') { + $image->stringUp($fontref,$x,$y-$height,$text,$imcolor); + } elsif ($type eq 'normal') { + $image->string($fontref,$x,$y-$height,$text,$imcolor); + } elsif ($type eq 'ttf') { + my ($fontname,$ptsize)=split(/\s+/,$font); + $image->stringFT($imcolor,$fontname,$ptsize,90,$x,$y,$text); + } } else { &Apache::lonnet::logthis("randomlylabel unable to handle object of type $type"); }